; Show that we know how to translate mul. ; NOTE: We use -O2 to get rid of memory stores. ; REQUIRES: allow_dump ; Compile using standalone assembler. ; RUN: %p2i --filetype=asm -i %s --target=arm32 --args -O2 \ ; RUN: | FileCheck %s --check-prefix=ASM ; Show bytes in assembled standalone code. ; RUN: %p2i --filetype=asm -i %s --target=arm32 --assemble --disassemble \ ; RUN: --args -O2 | FileCheck %s --check-prefix=DIS ; Compile using integrated assembler. ; RUN: %p2i --filetype=iasm -i %s --target=arm32 --args -O2 \ ; RUN: | FileCheck %s --check-prefix=IASM ; Show bytes in assembled integrated code. ; RUN: %p2i --filetype=iasm -i %s --target=arm32 --assemble --disassemble \ ; RUN: --args -O2 | FileCheck %s --check-prefix=DIS define internal i32 @MulTwoRegs(i32 %a, i32 %b) { %v = mul i32 %a, %b ret i32 %v } ; ASM-LABEL:MulTwoRegs: ; DIS-LABEL:: ; IASM-LABEL:MulTwoRegs: ; ASM: mul r0, r0, r1 ; DIS: e0000190 ; IASM-NOT: mul define internal i64 @MulTwoI64Regs(i64 %a, i64 %b) { %v = mul i64 %a, %b ret i64 %v } ; ASM-LABEL:MulTwoI64Regs: ; DIS-LABEL:: ; IASM-LABEL:MulTwoI64Regs: ; ASM: mul r3, r0, r3 ; ASM-NEXT: mla r1, r2, r1, r3 ; ASM-NEXT: # r3 = def.pseudo ; ASM-NEXT: umull r0, r3, r0, r2 ; ASM-NEXT: # r3 = def.pseudo r0 ; ASM-NEXT: add r3, r3, r1 ; DIS: e0030390 ; DIS-NEXT: e0213192 ; DIS-NEXT: e0830290 ; DIS-NEXT: e0833001 ; IASM-NOT: mul ; IASM-NOT: mla ; IASM-NOT: umull ; IASM-NOT: add