annotate test/CodeGen/AVR/dynalloca.ll @ 128:c347d3398279 default tip

fix
author mir3636
date Wed, 06 Dec 2017 14:37:17 +0900
parents 803732b1fca8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
1 ; RUN: llc < %s -march=avr | FileCheck %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
2
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
3 declare void @foo(i16*, i16*, i8*)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
4
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
5 define void @test1(i16 %x) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
6 ; CHECK-LABEL: test1:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
7 ; CHECK: out 61, r28
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
8 ; SP copy
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
9 ; CHECK-NEXT: in [[SPCOPY1:r[0-9]+]], 61
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
10 ; CHECK-NEXT: in [[SPCOPY2:r[0-9]+]], 62
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
11 ; allocate first dynalloca
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
12 ; CHECK: in {{.*}}, 61
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
13 ; CHECK: in {{.*}}, 62
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
14 ; CHECK: sub
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
15 ; CHECK: sbc
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
16 ; CHECK: in r0, 63
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
17 ; CHECK-NEXT: cli
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
18 ; CHECK-NEXT: out 62, {{.*}}
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
19 ; CHECK-NEXT: out 63, r0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
20 ; CHECK-NEXT: out 61, {{.*}}
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
21 ; Test writes
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
22 ; CHECK: std Z+12, {{.*}}
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
23 ; CHECK: std Z+13, {{.*}}
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
24 ; CHECK: std Z+7, {{.*}}
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
25 ; CHECK-NOT: std
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
26 ; Test SP restore
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
27 ; CHECK: in r0, 63
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
28 ; CHECK-NEXT: cli
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
29 ; CHECK-NEXT: out 62, [[SPCOPY2]]
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
30 ; CHECK-NEXT: out 63, r0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
31 ; CHECK-NEXT: out 61, [[SPCOPY1]]
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
32 %a = alloca [8 x i16]
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
33 %vla = alloca i16, i16 %x
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
34 %add = shl nsw i16 %x, 1
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
35 %vla1 = alloca i8, i16 %add
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
36 %arrayidx = getelementptr inbounds [8 x i16], [8 x i16]* %a, i16 0, i16 2
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
37 store i16 3, i16* %arrayidx
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
38 %arrayidx2 = getelementptr inbounds i16, i16* %vla, i16 6
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
39 store i16 4, i16* %arrayidx2
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
40 %arrayidx3 = getelementptr inbounds i8, i8* %vla1, i16 7
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
41 store i8 44, i8* %arrayidx3
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
42 %arraydecay = getelementptr inbounds [8 x i16], [8 x i16]* %a, i16 0, i16 0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
43 call void @foo(i16* %arraydecay, i16* %vla, i8* %vla1)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
44 ret void
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
45 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
46
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
47 declare void @foo2(i16*, i64, i64, i64)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
48
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
49 ; Test that arguments are passed through pushes into the call instead of
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
50 ; allocating the call frame space in the prologue. Also test that SP is restored
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
51 ; after the call frame is restored and not before.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
52 define void @dynalloca2(i16 %x) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
53 ; CHECK-LABEL: dynalloca2:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
54 ; CHECK: in [[SPCOPY1:r[0-9]+]], 61
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
55 ; CHECK: in [[SPCOPY2:r[0-9]+]], 62
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
56 ; CHECK: push
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
57 ; CHECK-NOT: st
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
58 ; CHECK-NOT: std
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
59 ; CHECK: call
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
60 ; Call frame restore
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
61 ; CHECK-NEXT: in r30, 61
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
62 ; CHECK-NEXT: in r31, 62
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
63 ; CHECK-NEXT: adiw r30, 8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
64 ; CHECK-NEXT: in r0, 63
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
65 ; CHECK-NEXT: cli
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
66 ; CHECK-NEXT: out 62, r31
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
67 ; CHECK-NEXT: out 63, r0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
68 ; CHECK-NEXT: out 61, r30
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
69 ; SP restore
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
70 ; CHECK: in r0, 63
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
71 ; CHECK-NEXT: cli
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
72 ; CHECK-NEXT: out 62, r7
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
73 ; CHECK-NEXT: out 63, r0
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
74 ; CHECK-NEXT: out 61, r6
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
75 %vla = alloca i16, i16 %x
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
76 call void @foo2(i16* %vla, i64 0, i64 0, i64 0)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
77 ret void
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
78 }