; 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=+mul | FileCheck -check-prefix=MUL %s define i8 @test_i8(i8 %a, i8 %b) { ; FUN: test_i8: ; MUL: test_i8: %tmp.1 = mul i8 %a, %b ; FUN-NOT: mul ; FUN: brlid ; MUL-NOT: brlid ret i8 %tmp.1 ; FUN: rtsd ; MUL: rtsd ; MUL: mul } define i16 @test_i16(i16 %a, i16 %b) { ; FUN: test_i16: ; MUL: test_i16: %tmp.1 = mul i16 %a, %b ; FUN-NOT: mul ; FUN: brlid ; MUL-NOT: brlid ret i16 %tmp.1 ; FUN: rtsd ; MUL: rtsd ; MUL: mul } define i32 @test_i32(i32 %a, i32 %b) { ; FUN: test_i32: ; MUL: test_i32: %tmp.1 = mul i32 %a, %b ; FUN-NOT: mul ; FUN: brlid ; MUL-NOT: brlid ret i32 %tmp.1 ; FUN: rtsd ; MUL: rtsd ; MUL: mul }