; Ensure that multiplication is lowered to function calls when the multiplier ; unit is not available in the hardware and that function calls are not used ; when the multiplier unit is available in the hardware. ; ; RUN: llc < %s -march=mblaze | FileCheck -check-prefix=FUN %s ; RUN: llc < %s -march=mblaze -mattr=+div | FileCheck -check-prefix=DIV %s define i8 @test_i8(i8 %a, i8 %b) { ; FUN-LABEL: test_i8: ; DIV-LABEL: test_i8: %tmp.1 = udiv i8 %a, %b ; FUN-NOT: idiv ; FUN: brlid ; DIV-NOT: brlid ; DIV: idiv %tmp.2 = sdiv i8 %a, %b ; FUN-NOT: idiv ; FUN: brlid ; DIV-NOT: brlid ; DIV-NOT: idiv ; DIV: idivu %tmp.3 = add i8 %tmp.1, %tmp.2 ret i8 %tmp.3 ; FUN: rtsd ; DIV: rtsd } define i16 @test_i16(i16 %a, i16 %b) { ; FUN-LABEL: test_i16: ; DIV-LABEL: test_i16: %tmp.1 = udiv i16 %a, %b ; FUN-NOT: idiv ; FUN: brlid ; DIV-NOT: brlid ; DIV: idiv %tmp.2 = sdiv i16 %a, %b ; FUN-NOT: idiv ; FUN: brlid ; DIV-NOT: brlid ; DIV-NOT: idiv ; DIV: idivu %tmp.3 = add i16 %tmp.1, %tmp.2 ret i16 %tmp.3 ; FUN: rtsd ; DIV: rtsd } define i32 @test_i32(i32 %a, i32 %b) { ; FUN-LABEL: test_i32: ; DIV-LABEL: test_i32: %tmp.1 = udiv i32 %a, %b ; FUN-NOT: idiv ; FUN: brlid ; DIV-NOT: brlid ; DIV: idiv %tmp.2 = sdiv i32 %a, %b ; FUN-NOT: idiv ; FUN: brlid ; DIV-NOT: brlid ; DIV-NOT: idiv ; DIV: idivu %tmp.3 = add i32 %tmp.1, %tmp.2 ret i32 %tmp.3 ; FUN: rtsd ; DIV: rtsd }