xref: /aosp_15_r20/external/llvm/test/CodeGen/AArch64/shrink-wrap.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=aarch64-linux-gnu -o - %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker; Regression test for a crash in the ShrinkWrap pass not handling targets
4*9880d681SAndroid Build Coastguard Worker; requiring a register scavenger.
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Worker%type1 = type { i32, i32, i32 }
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker@g1 = external unnamed_addr global i32, align 4
9*9880d681SAndroid Build Coastguard Worker@g2 = external unnamed_addr global i1
10*9880d681SAndroid Build Coastguard Worker@g3 = external unnamed_addr global [144 x i32], align 4
11*9880d681SAndroid Build Coastguard Worker@g4 = external unnamed_addr constant [144 x i32], align 4
12*9880d681SAndroid Build Coastguard Worker@g5 = external unnamed_addr constant [144 x i32], align 4
13*9880d681SAndroid Build Coastguard Worker@g6 = external unnamed_addr constant [144 x i32], align 4
14*9880d681SAndroid Build Coastguard Worker@g7 = external unnamed_addr constant [144 x i32], align 4
15*9880d681SAndroid Build Coastguard Worker@g8 = external unnamed_addr constant [144 x i32], align 4
16*9880d681SAndroid Build Coastguard Worker@g9 = external unnamed_addr constant [144 x i32], align 4
17*9880d681SAndroid Build Coastguard Worker@g10 = external unnamed_addr constant [144 x i32], align 4
18*9880d681SAndroid Build Coastguard Worker@g11 = external unnamed_addr global i32, align 4
19*9880d681SAndroid Build Coastguard Worker@g12 = external unnamed_addr global [144 x [144 x i8]], align 1
20*9880d681SAndroid Build Coastguard Worker@g13 = external unnamed_addr global %type1*, align 8
21*9880d681SAndroid Build Coastguard Worker@g14 = external unnamed_addr global [144 x [144 x i8]], align 1
22*9880d681SAndroid Build Coastguard Worker@g15 = external unnamed_addr global [144 x [144 x i8]], align 1
23*9880d681SAndroid Build Coastguard Worker@g16 = external unnamed_addr global [144 x [144 x i8]], align 1
24*9880d681SAndroid Build Coastguard Worker@g17 = external unnamed_addr global [62 x i32], align 4
25*9880d681SAndroid Build Coastguard Worker@g18 = external unnamed_addr global i32, align 4
26*9880d681SAndroid Build Coastguard Worker@g19 = external unnamed_addr constant [144 x i32], align 4
27*9880d681SAndroid Build Coastguard Worker@g20 = external unnamed_addr global [144 x [144 x i8]], align 1
28*9880d681SAndroid Build Coastguard Worker@g21 = external unnamed_addr global i32, align 4
29*9880d681SAndroid Build Coastguard Worker
30*9880d681SAndroid Build Coastguard Workerdeclare fastcc i32 @foo()
31*9880d681SAndroid Build Coastguard Worker
32*9880d681SAndroid Build Coastguard Workerdeclare fastcc i32 @bar()
33*9880d681SAndroid Build Coastguard Worker
34*9880d681SAndroid Build Coastguard Workerdefine internal fastcc i32 @func(i32 %alpha, i32 %beta) {
35*9880d681SAndroid Build Coastguard Workerentry:
36*9880d681SAndroid Build Coastguard Worker  %v1 = alloca [2 x [11 x i32]], align 4
37*9880d681SAndroid Build Coastguard Worker  %v2 = alloca [11 x i32], align 16
38*9880d681SAndroid Build Coastguard Worker  %v3 = alloca [11 x i32], align 16
39*9880d681SAndroid Build Coastguard Worker  switch i32 undef, label %if.end.9 [
40*9880d681SAndroid Build Coastguard Worker    i32 4, label %if.then.6
41*9880d681SAndroid Build Coastguard Worker    i32 3, label %if.then.2
42*9880d681SAndroid Build Coastguard Worker  ]
43*9880d681SAndroid Build Coastguard Worker
44*9880d681SAndroid Build Coastguard Workerif.then.2:
45*9880d681SAndroid Build Coastguard Worker  %call3 = tail call fastcc i32 @bar()
46*9880d681SAndroid Build Coastguard Worker  br label %cleanup
47*9880d681SAndroid Build Coastguard Worker
48*9880d681SAndroid Build Coastguard Workerif.then.6:
49*9880d681SAndroid Build Coastguard Worker  %call7 = tail call fastcc i32 @foo()
50*9880d681SAndroid Build Coastguard Worker  unreachable
51*9880d681SAndroid Build Coastguard Worker
52*9880d681SAndroid Build Coastguard Workerif.end.9:
53*9880d681SAndroid Build Coastguard Worker  %tmp = load i32, i32* @g1, align 4
54*9880d681SAndroid Build Coastguard Worker  %rem.i = urem i32 %tmp, 1000000
55*9880d681SAndroid Build Coastguard Worker  %idxprom.1.i = zext i32 %rem.i to i64
56*9880d681SAndroid Build Coastguard Worker  %tmp1 = load %type1*, %type1** @g13, align 8
57*9880d681SAndroid Build Coastguard Worker  %v4 = getelementptr inbounds %type1, %type1* %tmp1, i64 %idxprom.1.i, i32 0
58*9880d681SAndroid Build Coastguard Worker  %.b = load i1, i1* @g2, align 1
59*9880d681SAndroid Build Coastguard Worker  %v5 = select i1 %.b, i32 2, i32 0
60*9880d681SAndroid Build Coastguard Worker  %tmp2 = load i32, i32* @g18, align 4
61*9880d681SAndroid Build Coastguard Worker  %tmp3 = load i32, i32* @g11, align 4
62*9880d681SAndroid Build Coastguard Worker  %idxprom58 = sext i32 %tmp3 to i64
63*9880d681SAndroid Build Coastguard Worker  %tmp4 = load i32, i32* @g21, align 4
64*9880d681SAndroid Build Coastguard Worker  %idxprom69 = sext i32 %tmp4 to i64
65*9880d681SAndroid Build Coastguard Worker  br label %for.body
66*9880d681SAndroid Build Coastguard Worker
67*9880d681SAndroid Build Coastguard Workerfor.body:
68*9880d681SAndroid Build Coastguard Worker  %v6 = phi i32 [ 0, %if.end.9 ], [ %v7, %for.inc ]
69*9880d681SAndroid Build Coastguard Worker  %a.0983 = phi i32 [ 1, %if.end.9 ], [ %a.1, %for.inc ]
70*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds [62 x i32], [62 x i32]* @g17, i64 0, i64 undef
71*9880d681SAndroid Build Coastguard Worker  %tmp5 = load i32, i32* %arrayidx, align 4
72*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %for.inc, label %if.else.51
73*9880d681SAndroid Build Coastguard Worker
74*9880d681SAndroid Build Coastguard Workerif.else.51:
75*9880d681SAndroid Build Coastguard Worker  %idxprom53 = sext i32 %tmp5 to i64
76*9880d681SAndroid Build Coastguard Worker  %arrayidx54 = getelementptr inbounds [144 x i32], [144 x i32]* @g3, i64 0, i64 %idxprom53
77*9880d681SAndroid Build Coastguard Worker  %tmp6 = load i32, i32* %arrayidx54, align 4
78*9880d681SAndroid Build Coastguard Worker  switch i32 %tmp6, label %for.inc [
79*9880d681SAndroid Build Coastguard Worker    i32 1, label %block.bb
80*9880d681SAndroid Build Coastguard Worker    i32 10, label %block.bb.159
81*9880d681SAndroid Build Coastguard Worker    i32 7, label %block.bb.75
82*9880d681SAndroid Build Coastguard Worker    i32 8, label %block.bb.87
83*9880d681SAndroid Build Coastguard Worker    i32 9, label %block.bb.147
84*9880d681SAndroid Build Coastguard Worker    i32 12, label %block.bb.111
85*9880d681SAndroid Build Coastguard Worker    i32 3, label %block.bb.123
86*9880d681SAndroid Build Coastguard Worker    i32 4, label %block.bb.135
87*9880d681SAndroid Build Coastguard Worker  ]
88*9880d681SAndroid Build Coastguard Worker
89*9880d681SAndroid Build Coastguard Workerblock.bb:
90*9880d681SAndroid Build Coastguard Worker  %arrayidx56 = getelementptr inbounds [144 x i32], [144 x i32]* @g6, i64 0, i64 %idxprom53
91*9880d681SAndroid Build Coastguard Worker  %tmp7 = load i32, i32* %arrayidx56, align 4
92*9880d681SAndroid Build Coastguard Worker  %shr = ashr i32 %tmp7, %v5
93*9880d681SAndroid Build Coastguard Worker  %add57 = add nsw i32 %shr, 0
94*9880d681SAndroid Build Coastguard Worker  %arrayidx61 = getelementptr inbounds [144 x [144 x i8]], [144 x [144 x i8]]* @g14, i64 0, i64 %idxprom53, i64 %idxprom58
95*9880d681SAndroid Build Coastguard Worker  %tmp8 = load i8, i8* %arrayidx61, align 1
96*9880d681SAndroid Build Coastguard Worker  %conv = zext i8 %tmp8 to i32
97*9880d681SAndroid Build Coastguard Worker  %add62 = add nsw i32 %conv, %add57
98*9880d681SAndroid Build Coastguard Worker  br label %for.inc
99*9880d681SAndroid Build Coastguard Worker
100*9880d681SAndroid Build Coastguard Workerblock.bb.75:
101*9880d681SAndroid Build Coastguard Worker  %arrayidx78 = getelementptr inbounds [144 x i32], [144 x i32]* @g10, i64 0, i64 %idxprom53
102*9880d681SAndroid Build Coastguard Worker  %tmp9 = load i32, i32* %arrayidx78, align 4
103*9880d681SAndroid Build Coastguard Worker  %shr79 = ashr i32 %tmp9, %v5
104*9880d681SAndroid Build Coastguard Worker  %add80 = add nsw i32 %shr79, 0
105*9880d681SAndroid Build Coastguard Worker  %add86 = add nsw i32 0, %add80
106*9880d681SAndroid Build Coastguard Worker  br label %for.inc
107*9880d681SAndroid Build Coastguard Worker
108*9880d681SAndroid Build Coastguard Workerblock.bb.87:
109*9880d681SAndroid Build Coastguard Worker  %arrayidx90 = getelementptr inbounds [144 x i32], [144 x i32]* @g9, i64 0, i64 %idxprom53
110*9880d681SAndroid Build Coastguard Worker  %tmp10 = load i32, i32* %arrayidx90, align 4
111*9880d681SAndroid Build Coastguard Worker  %shr91 = ashr i32 %tmp10, 0
112*9880d681SAndroid Build Coastguard Worker  %sub92 = sub nsw i32 0, %shr91
113*9880d681SAndroid Build Coastguard Worker  %arrayidx96 = getelementptr inbounds [144 x [144 x i8]], [144 x [144 x i8]]* @g15, i64 0, i64 %idxprom53, i64 %idxprom69
114*9880d681SAndroid Build Coastguard Worker  %tmp11 = load i8, i8* %arrayidx96, align 1
115*9880d681SAndroid Build Coastguard Worker  %conv97 = zext i8 %tmp11 to i32
116*9880d681SAndroid Build Coastguard Worker  %sub98 = sub nsw i32 %sub92, %conv97
117*9880d681SAndroid Build Coastguard Worker  br label %for.inc
118*9880d681SAndroid Build Coastguard Worker
119*9880d681SAndroid Build Coastguard Workerblock.bb.111:
120*9880d681SAndroid Build Coastguard Worker  %arrayidx114 = getelementptr inbounds [144 x i32], [144 x i32]* @g19, i64 0, i64 %idxprom53
121*9880d681SAndroid Build Coastguard Worker  %tmp12 = load i32, i32* %arrayidx114, align 4
122*9880d681SAndroid Build Coastguard Worker  %shr115 = ashr i32 %tmp12, 0
123*9880d681SAndroid Build Coastguard Worker  %sub116 = sub nsw i32 0, %shr115
124*9880d681SAndroid Build Coastguard Worker  %arrayidx120 = getelementptr inbounds [144 x [144 x i8]], [144 x [144 x i8]]* @g12, i64 0, i64 %idxprom53, i64 %idxprom69
125*9880d681SAndroid Build Coastguard Worker  %tmp13 = load i8, i8* %arrayidx120, align 1
126*9880d681SAndroid Build Coastguard Worker  %conv121 = zext i8 %tmp13 to i32
127*9880d681SAndroid Build Coastguard Worker  %sub122 = sub nsw i32 %sub116, %conv121
128*9880d681SAndroid Build Coastguard Worker  br label %for.inc
129*9880d681SAndroid Build Coastguard Worker
130*9880d681SAndroid Build Coastguard Workerblock.bb.123:
131*9880d681SAndroid Build Coastguard Worker  %arrayidx126 = getelementptr inbounds [144 x i32], [144 x i32]* @g5, i64 0, i64 %idxprom53
132*9880d681SAndroid Build Coastguard Worker  %tmp14 = load i32, i32* %arrayidx126, align 4
133*9880d681SAndroid Build Coastguard Worker  %shr127 = ashr i32 %tmp14, %v5
134*9880d681SAndroid Build Coastguard Worker  %add128 = add nsw i32 %shr127, 0
135*9880d681SAndroid Build Coastguard Worker  %add134 = add nsw i32 0, %add128
136*9880d681SAndroid Build Coastguard Worker  br label %for.inc
137*9880d681SAndroid Build Coastguard Worker
138*9880d681SAndroid Build Coastguard Workerblock.bb.135:
139*9880d681SAndroid Build Coastguard Worker  %arrayidx138 = getelementptr inbounds [144 x i32], [144 x i32]* @g4, i64 0, i64 %idxprom53
140*9880d681SAndroid Build Coastguard Worker  %tmp15 = load i32, i32* %arrayidx138, align 4
141*9880d681SAndroid Build Coastguard Worker  %shr139 = ashr i32 %tmp15, 0
142*9880d681SAndroid Build Coastguard Worker  %sub140 = sub nsw i32 0, %shr139
143*9880d681SAndroid Build Coastguard Worker  %arrayidx144 = getelementptr inbounds [144 x [144 x i8]], [144 x [144 x i8]]* @g20, i64 0, i64 %idxprom53, i64 %idxprom69
144*9880d681SAndroid Build Coastguard Worker  %tmp16 = load i8, i8* %arrayidx144, align 1
145*9880d681SAndroid Build Coastguard Worker  %conv145 = zext i8 %tmp16 to i32
146*9880d681SAndroid Build Coastguard Worker  %sub146 = sub nsw i32 %sub140, %conv145
147*9880d681SAndroid Build Coastguard Worker  br label %for.inc
148*9880d681SAndroid Build Coastguard Worker
149*9880d681SAndroid Build Coastguard Workerblock.bb.147:
150*9880d681SAndroid Build Coastguard Worker  %arrayidx150 = getelementptr inbounds [144 x i32], [144 x i32]* @g8, i64 0, i64 %idxprom53
151*9880d681SAndroid Build Coastguard Worker  %tmp17 = load i32, i32* %arrayidx150, align 4
152*9880d681SAndroid Build Coastguard Worker  %shr151 = ashr i32 %tmp17, %v5
153*9880d681SAndroid Build Coastguard Worker  %add152 = add nsw i32 %shr151, 0
154*9880d681SAndroid Build Coastguard Worker  %arrayidx156 = getelementptr inbounds [144 x [144 x i8]], [144 x [144 x i8]]* @g16, i64 0, i64 %idxprom53, i64 %idxprom58
155*9880d681SAndroid Build Coastguard Worker  %tmp18 = load i8, i8* %arrayidx156, align 1
156*9880d681SAndroid Build Coastguard Worker  %conv157 = zext i8 %tmp18 to i32
157*9880d681SAndroid Build Coastguard Worker  %add158 = add nsw i32 %conv157, %add152
158*9880d681SAndroid Build Coastguard Worker  br label %for.inc
159*9880d681SAndroid Build Coastguard Worker
160*9880d681SAndroid Build Coastguard Workerblock.bb.159:
161*9880d681SAndroid Build Coastguard Worker  %sub160 = add nsw i32 %v6, -450
162*9880d681SAndroid Build Coastguard Worker  %arrayidx162 = getelementptr inbounds [144 x i32], [144 x i32]* @g7, i64 0, i64 %idxprom53
163*9880d681SAndroid Build Coastguard Worker  %tmp19 = load i32, i32* %arrayidx162, align 4
164*9880d681SAndroid Build Coastguard Worker  %shr163 = ashr i32 %tmp19, 0
165*9880d681SAndroid Build Coastguard Worker  %sub164 = sub nsw i32 %sub160, %shr163
166*9880d681SAndroid Build Coastguard Worker  %sub170 = sub nsw i32 %sub164, 0
167*9880d681SAndroid Build Coastguard Worker  br label %for.inc
168*9880d681SAndroid Build Coastguard Worker
169*9880d681SAndroid Build Coastguard Workerfor.inc:
170*9880d681SAndroid Build Coastguard Worker  %v7 = phi i32 [ %v6, %for.body ], [ %v6, %if.else.51 ], [ %sub170, %block.bb.159 ], [ %add158, %block.bb.147 ], [ %sub146, %block.bb.135 ], [ %add134, %block.bb.123 ], [ %sub122, %block.bb.111 ], [ %sub98, %block.bb.87 ], [ %add86, %block.bb.75 ], [ %add62, %block.bb ]
171*9880d681SAndroid Build Coastguard Worker  %a.1 = phi i32 [ %a.0983, %for.body ], [ undef, %if.else.51 ], [ undef, %block.bb.159 ], [ undef, %block.bb.147 ], [ undef, %block.bb.135 ], [ undef, %block.bb.123 ], [ undef, %block.bb.111 ], [ undef, %block.bb.87 ], [ undef, %block.bb.75 ], [ undef, %block.bb ]
172*9880d681SAndroid Build Coastguard Worker  %cmp48 = icmp sgt i32 %a.1, %tmp2
173*9880d681SAndroid Build Coastguard Worker  br i1 %cmp48, label %for.end, label %for.body
174*9880d681SAndroid Build Coastguard Worker
175*9880d681SAndroid Build Coastguard Workerfor.end:
176*9880d681SAndroid Build Coastguard Worker  store i32 %tmp, i32* %v4, align 4
177*9880d681SAndroid Build Coastguard Worker  %hold_hash.i.7 = getelementptr inbounds %type1, %type1* %tmp1, i64 %idxprom.1.i, i32 1
178*9880d681SAndroid Build Coastguard Worker  store i32 0, i32* %hold_hash.i.7, align 4
179*9880d681SAndroid Build Coastguard Worker  br label %cleanup
180*9880d681SAndroid Build Coastguard Worker
181*9880d681SAndroid Build Coastguard Workercleanup:
182*9880d681SAndroid Build Coastguard Worker  %retval.0 = phi i32 [ %call3, %if.then.2 ], [ undef, %for.end ]
183*9880d681SAndroid Build Coastguard Worker  ret i32 %retval.0
184*9880d681SAndroid Build Coastguard Worker}
185