1 ; RUN: llc -mtriple=aarch64-apple-ios -O0 -stop-after=irtranslator -global-isel -verify-machineinstrs %s -o - 2>&1 | FileCheck %s
4 ; CHECK-LABEL: name: test_stack_slots
6 ; CHECK-DAG: - { id: [[STACK0:[0-9]+]], type: default, offset: 0, size: 1,
7 ; CHECK-DAG: - { id: [[STACK8:[0-9]+]], type: default, offset: 1, size: 1,
8 ; CHECK: [[LHS_ADDR:%[0-9]+]]:_(p0) = G_FRAME_INDEX %fixed-stack.[[STACK0]]
9 ; CHECK: [[LHS:%[0-9]+]]:_(s8) = G_LOAD [[LHS_ADDR]](p0) :: (invariant load 1 from %fixed-stack.[[STACK0]], align 0)
10 ; CHECK: [[RHS_ADDR:%[0-9]+]]:_(p0) = G_FRAME_INDEX %fixed-stack.[[STACK8]]
11 ; CHECK: [[RHS:%[0-9]+]]:_(s8) = G_LOAD [[RHS_ADDR]](p0) :: (invariant load 1 from %fixed-stack.[[STACK8]], align 0)
12 ; CHECK: [[SUM:%[0-9]+]]:_(s8) = G_ADD [[LHS]], [[RHS]]
13 ; CHECK: [[SUM32:%[0-9]+]]:_(s32) = G_SEXT [[SUM]](s8)
14 ; CHECK: %w0 = COPY [[SUM32]](s32)
15 define signext i8 @test_stack_slots([8 x i64], i8 signext %lhs, i8 signext %rhs) {
16 %sum = add i8 %lhs, %rhs
20 ; CHECK-LABEL: name: test_call_stack
21 ; CHECK: [[C42:%[0-9]+]]:_(s8) = G_CONSTANT i8 42
22 ; CHECK: [[C12:%[0-9]+]]:_(s8) = G_CONSTANT i8 12
23 ; CHECK: [[SP:%[0-9]+]]:_(p0) = COPY %sp
24 ; CHECK: [[C42_OFFS:%[0-9]+]]:_(s64) = G_CONSTANT i64 0
25 ; CHECK: [[C42_LOC:%[0-9]+]]:_(p0) = G_GEP [[SP]], [[C42_OFFS]](s64)
26 ; CHECK: G_STORE [[C42]](s8), [[C42_LOC]](p0) :: (store 1 into stack, align 0)
27 ; CHECK: [[SP:%[0-9]+]]:_(p0) = COPY %sp
28 ; CHECK: [[C12_OFFS:%[0-9]+]]:_(s64) = G_CONSTANT i64 1
29 ; CHECK: [[C12_LOC:%[0-9]+]]:_(p0) = G_GEP [[SP]], [[C12_OFFS]](s64)
30 ; CHECK: G_STORE [[C12]](s8), [[C12_LOC]](p0) :: (store 1 into stack + 1, align 0)
31 ; CHECK: BL @test_stack_slots
32 define void @test_call_stack() {
33 call signext i8 @test_stack_slots([8 x i64] undef, i8 signext 42, i8 signext 12)
37 ; CHECK-LABEL: name: test_128bit_struct
41 ; CHECK: BL @take_128bit_struct
42 define void @test_128bit_struct([2 x i64]* %ptr) {
43 %struct = load [2 x i64], [2 x i64]* %ptr
44 call void @take_128bit_struct([2 x i64]* null, [2 x i64] %struct)
48 ; CHECK-LABEL: name: take_128bit_struct
49 ; CHECK: {{%.*}}:_(p0) = COPY %x0
50 ; CHECK: {{%.*}}:_(s64) = COPY %x1
51 ; CHECK: {{%.*}}:_(s64) = COPY %x2
52 define void @take_128bit_struct([2 x i64]* %ptr, [2 x i64] %in) {
53 store [2 x i64] %in, [2 x i64]* %ptr
57 ; CHECK-LABEL: name: test_split_struct
58 ; CHECK: [[STRUCT:%[0-9]+]]:_(s128) = G_LOAD {{.*}}(p0)
59 ; CHECK: [[LO:%[0-9]+]]:_(s64) = G_EXTRACT [[STRUCT]](s128), 0
60 ; CHECK: [[HI:%[0-9]+]]:_(s64) = G_EXTRACT [[STRUCT]](s128), 64
62 ; CHECK: [[SP:%[0-9]+]]:_(p0) = COPY %sp
63 ; CHECK: [[OFF:%[0-9]+]]:_(s64) = G_CONSTANT i64 0
64 ; CHECK: [[ADDR:%[0-9]+]]:_(p0) = G_GEP [[SP]], [[OFF]]
65 ; CHECK: G_STORE [[LO]](s64), [[ADDR]](p0) :: (store 8 into stack, align 0)
67 ; CHECK: [[SP:%[0-9]+]]:_(p0) = COPY %sp
68 ; CHECK: [[OFF:%[0-9]+]]:_(s64) = G_CONSTANT i64 8
69 ; CHECK: [[ADDR:%[0-9]+]]:_(p0) = G_GEP [[SP]], [[OFF]]
70 ; CHECK: G_STORE [[HI]](s64), [[ADDR]](p0) :: (store 8 into stack + 8, align 0)
71 define void @test_split_struct([2 x i64]* %ptr) {
72 %struct = load [2 x i64], [2 x i64]* %ptr
73 call void @take_split_struct([2 x i64]* null, i64 1, i64 2, i64 3,
79 ; CHECK-LABEL: name: take_split_struct
81 ; CHECK-DAG: - { id: [[LO_FRAME:[0-9]+]], type: default, offset: 0, size: 8
82 ; CHECK-DAG: - { id: [[HI_FRAME:[0-9]+]], type: default, offset: 8, size: 8
84 ; CHECK: [[LOPTR:%[0-9]+]]:_(p0) = G_FRAME_INDEX %fixed-stack.[[LO_FRAME]]
85 ; CHECK: [[LO:%[0-9]+]]:_(s64) = G_LOAD [[LOPTR]](p0) :: (invariant load 8 from %fixed-stack.[[LO_FRAME]], align 0)
87 ; CHECK: [[HIPTR:%[0-9]+]]:_(p0) = G_FRAME_INDEX %fixed-stack.[[HI_FRAME]]
88 ; CHECK: [[HI:%[0-9]+]]:_(s64) = G_LOAD [[HIPTR]](p0) :: (invariant load 8 from %fixed-stack.[[HI_FRAME]], align 0)
89 define void @take_split_struct([2 x i64]* %ptr, i64, i64, i64,
92 store [2 x i64] %in, [2 x i64]* %ptr