; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -mtriple=arm-eabi %s -o - | FileCheck %s --check-prefix=ARM
; RUN: llc -mtriple=thumbv6t2-eabi %s -o - | FileCheck %s --check-prefix=THUMB2
; RUN: llc -mtriple=thumb-eabi %s -o - | FileCheck %s --check-prefix=THUMB
define i32 @t9(i32 %v) nounwind readnone {
; ARM-LABEL: t9:
; ARM: @ %bb.0: @ %entry
; ARM-NEXT: add r0, r0, r0, lsl #3
; ARM-NEXT: mov pc, lr
;
; THUMB2-LABEL: t9:
; THUMB2: @ %bb.0: @ %entry
; THUMB2-NEXT: add.w r0, r0, r0, lsl #3
; THUMB2-NEXT: bx lr
;
; THUMB-LABEL: t9:
; THUMB: @ %bb.0: @ %entry
; THUMB-NEXT: movs r1, #9
; THUMB-NEXT: muls r0, r1, r0
; THUMB-NEXT: bx lr
entry:
%0 = mul i32 %v, 9
ret i32 %0
}
define i32 @t7(i32 %v) nounwind readnone {
; ARM-LABEL: t7:
; ARM: @ %bb.0: @ %entry
; ARM-NEXT: rsb r0, r0, r0, lsl #3
; ARM-NEXT: mov pc, lr
;
; THUMB2-LABEL: t7:
; THUMB2: @ %bb.0: @ %entry
; THUMB2-NEXT: rsb r0, r0, r0, lsl #3
; THUMB2-NEXT: bx lr
;
; THUMB-LABEL: t7:
; THUMB: @ %bb.0: @ %entry
; THUMB-NEXT: movs r1, #7
; THUMB-NEXT: muls r0, r1, r0
; THUMB-NEXT: bx lr
entry:
%0 = mul i32 %v, 7
ret i32 %0
}
define i32 @t5(i32 %v) nounwind readnone {
; ARM-LABEL: t5:
; ARM: @ %bb.0: @ %entry
; ARM-NEXT: add r0, r0, r0, lsl #2
; ARM-NEXT: mov pc, lr
;
; THUMB2-LABEL: t5:
; THUMB2: @ %bb.0: @ %entry
; THUMB2-NEXT: add.w r0, r0, r0, lsl #2
; THUMB2-NEXT: bx lr
;
; THUMB-LABEL: t5:
; THUMB: @ %bb.0: @ %entry
; THUMB-NEXT: movs r1, #5
; THUMB-NEXT: muls r0, r1, r0
; THUMB-NEXT: bx lr
entry:
%0 = mul i32 %v, 5
ret i32 %0
}
define i32 @t3(i32 %v) nounwind readnone {
; ARM-LABEL: t3:
; ARM: @ %bb.0: @ %entry
; ARM-NEXT: add r0, r0, r0, lsl #1
; ARM-NEXT: mov pc, lr
;
; THUMB2-LABEL: t3:
; THUMB2: @ %bb.0: @ %entry
; THUMB2-NEXT: add.w r0, r0, r0, lsl #1
; THUMB2-NEXT: bx lr
;
; THUMB-LABEL: t3:
; THUMB: @ %bb.0: @ %entry
; THUMB-NEXT: movs r1, #3
; THUMB-NEXT: muls r0, r1, r0
; THUMB-NEXT: bx lr
entry:
%0 = mul i32 %v, 3
ret i32 %0
}
define i32 @t12288(i32 %v) nounwind readnone {
; ARM-LABEL: t12288:
; ARM: @ %bb.0: @ %entry
; ARM-NEXT: add r0, r0, r0, lsl #1
; ARM-NEXT: lsl r0, r0, #12
; ARM-NEXT: mov pc, lr
;
; THUMB2-LABEL: t12288:
; THUMB2: @ %bb.0: @ %entry
; THUMB2-NEXT: add.w r0, r0, r0, lsl #1
; THUMB2-NEXT: lsls r0, r0, #12
; THUMB2-NEXT: bx lr
;
; THUMB-LABEL: t12288:
; THUMB: @ %bb.0: @ %entry
; THUMB-NEXT: movs r1, #3
; THUMB-NEXT: lsls r1, r1, #12
; THUMB-NEXT: muls r0, r1, r0
; THUMB-NEXT: bx lr
entry:
%0 = mul i32 %v, 12288
ret i32 %0
}
define i32 @tn9(i32 %v) nounwind readnone {
; ARM-LABEL: tn9:
; ARM: @ %bb.0: @ %entry
; ARM-NEXT: add r0, r0, r0, lsl #3
; ARM-NEXT: rsb r0, r0, #0
; ARM-NEXT: mov pc, lr
;
; THUMB2-LABEL: tn9:
; THUMB2: @ %bb.0: @ %entry
; THUMB2-NEXT: add.w r0, r0, r0, lsl #3
; THUMB2-NEXT: rsbs r0, r0, #0
; THUMB2-NEXT: bx lr
;
; THUMB-LABEL: tn9:
; THUMB: @ %bb.0: @ %entry
; THUMB-NEXT: movs r1, #8
; THUMB-NEXT: mvns r1, r1
; THUMB-NEXT: muls r0, r1, r0
; THUMB-NEXT: bx lr
entry:
%0 = mul i32 %v, -9
ret i32 %0
}
define i32 @tn7(i32 %v) nounwind readnone {
; ARM-LABEL: tn7:
; ARM: @ %bb.0: @ %entry
; ARM-NEXT: sub r0, r0, r0, lsl #3
; ARM-NEXT: mov pc, lr
;
; THUMB2-LABEL: tn7:
; THUMB2: @ %bb.0: @ %entry
; THUMB2-NEXT: sub.w r0, r0, r0, lsl #3
; THUMB2-NEXT: bx lr
;
; THUMB-LABEL: tn7:
; THUMB: @ %bb.0: @ %entry
; THUMB-NEXT: movs r1, #6
; THUMB-NEXT: mvns r1, r1
; THUMB-NEXT: muls r0, r1, r0
; THUMB-NEXT: bx lr
entry:
%0 = mul i32 %v, -7
ret i32 %0
}
define i32 @tn5(i32 %v) nounwind readnone {
; ARM-LABEL: tn5:
; ARM: @ %bb.0: @ %entry
; ARM-NEXT: add r0, r0, r0, lsl #2
; ARM-NEXT: rsb r0, r0, #0
; ARM-NEXT: mov pc, lr
;
; THUMB2-LABEL: tn5:
; THUMB2: @ %bb.0: @ %entry
; THUMB2-NEXT: add.w r0, r0, r0, lsl #2
; THUMB2-NEXT: rsbs r0, r0, #0
; THUMB2-NEXT: bx lr
;
; THUMB-LABEL: tn5:
; THUMB: @ %bb.0: @ %entry
; THUMB-NEXT: movs r1, #4
; THUMB-NEXT: mvns r1, r1
; THUMB-NEXT: muls r0, r1, r0
; THUMB-NEXT: bx lr
entry:
%0 = mul i32 %v, -5
ret i32 %0
}
define i32 @tn3(i32 %v) nounwind readnone {
; ARM-LABEL: tn3:
; ARM: @ %bb.0: @ %entry
; ARM-NEXT: sub r0, r0, r0, lsl #2
; ARM-NEXT: mov pc, lr
;
; THUMB2-LABEL: tn3:
; THUMB2: @ %bb.0: @ %entry
; THUMB2-NEXT: sub.w r0, r0, r0, lsl #2
; THUMB2-NEXT: bx lr
;
; THUMB-LABEL: tn3:
; THUMB: @ %bb.0: @ %entry
; THUMB-NEXT: movs r1, #2
; THUMB-NEXT: mvns r1, r1
; THUMB-NEXT: muls r0, r1, r0
; THUMB-NEXT: bx lr
entry:
; CHECK-LABEL: tn3:
; CHECK: sub r0, r0, r0, lsl #2
%0 = mul i32 %v, -3
ret i32 %0
}
define i32 @tn12288(i32 %v) nounwind readnone {
; ARM-LABEL: tn12288:
; ARM: @ %bb.0: @ %entry
; ARM-NEXT: sub r0, r0, r0, lsl #2
; ARM-NEXT: lsl r0, r0, #12
; ARM-NEXT: mov pc, lr
;
; THUMB2-LABEL: tn12288:
; THUMB2: @ %bb.0: @ %entry
; THUMB2-NEXT: sub.w r0, r0, r0, lsl #2
; THUMB2-NEXT: lsls r0, r0, #12
; THUMB2-NEXT: bx lr
;
; THUMB-LABEL: tn12288:
; THUMB: @ %bb.0: @ %entry
; THUMB-NEXT: ldr r1, .LCPI9_0
; THUMB-NEXT: muls r0, r1, r0
; THUMB-NEXT: bx lr
; THUMB-NEXT: .p2align 2
; THUMB-NEXT: @ %bb.1:
; THUMB-NEXT: .LCPI9_0:
; THUMB-NEXT: .long 4294955008 @ 0xffffd000
entry:
; CHECK-LABEL: tn12288:
; CHECK: sub r0, r0, r0, lsl #2
; CHECK: lsl{{.*}}#12
%0 = mul i32 %v, -12288
ret i32 %0
}