[ARM] More MVE compare vector splat combines for ANDs
[llvm-complete.git] / test / CodeGen / ARM / frame-register.ll
blobc008b21a2909ce0401a187cea6dafd0a6d83ff49
1 ; RUN: llc -mtriple arm-eabi -frame-pointer=all -filetype asm -o - %s \
2 ; RUN:     | FileCheck -check-prefix CHECK-ARM %s
4 ; RUN: llc -mtriple thumb-eabi -frame-pointer=all -filetype asm -o - %s \
5 ; RUN:     | FileCheck -check-prefix CHECK-THUMB %s
7 ; RUN: llc -mtriple arm-darwin -frame-pointer=all -filetype asm -o - %s \
8 ; RUN:     | FileCheck -check-prefix CHECK-DARWIN-ARM %s
10 ; RUN: llc -mtriple thumb-darwin -frame-pointer=all -filetype asm -o - %s \
11 ; RUN:     | FileCheck -check-prefix CHECK-DARWIN-THUMB %s
13 declare void @callee(i32)
15 define i32 @calleer(i32 %i) {
16 entry:
17   %i.addr = alloca i32, align 4
18   %j = alloca i32, align 4
19   store i32 %i, i32* %i.addr, align 4
20   %0 = load i32, i32* %i.addr, align 4
21   %add = add nsw i32 %0, 1
22   store i32 %add, i32* %j, align 4
23   %1 = load i32, i32* %j, align 4
24   call void @callee(i32 %1)
25   %2 = load i32, i32* %j, align 4
26   %add1 = add nsw i32 %2, 1
27   ret i32 %add1
30 ; CHECK-ARM: push {r11, lr}
31 ; CHECK-ARM: mov r11, sp
33 ; CHECK-THUMB: push {r7, lr}
34 ; CHECK-THUMB: add r7, sp, #0
36 ; CHECK-DARWIN-ARM: push {r7, lr}
37 ; CHECK-DARWIN-THUMB: push {r7, lr}