xref: /aosp_15_r20/external/llvm/test/CodeGen/ARM/2009-02-16-SpillerBug.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=arm -mattr=+v6,+vfp2
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Workertarget triple = "arm-apple-darwin9"
4*9880d681SAndroid Build Coastguard Worker	%struct.FILE_POS = type { i8, i8, i16, i32 }
5*9880d681SAndroid Build Coastguard Worker	%struct.FIRST_UNION = type { %struct.FILE_POS }
6*9880d681SAndroid Build Coastguard Worker	%struct.FOURTH_UNION = type { %struct.STYLE }
7*9880d681SAndroid Build Coastguard Worker	%struct.GAP = type { i8, i8, i16 }
8*9880d681SAndroid Build Coastguard Worker	%struct.LIST = type { %struct.rec*, %struct.rec* }
9*9880d681SAndroid Build Coastguard Worker	%struct.SECOND_UNION = type { { i16, i8, i8 } }
10*9880d681SAndroid Build Coastguard Worker	%struct.STYLE = type { { %struct.GAP }, { %struct.GAP }, i16, i16, i32 }
11*9880d681SAndroid Build Coastguard Worker	%struct.THIRD_UNION = type { { [2 x i32], [2 x i32] } }
12*9880d681SAndroid Build Coastguard Worker	%struct.head_type = type { [2 x %struct.LIST], %struct.FIRST_UNION, %struct.SECOND_UNION, %struct.THIRD_UNION, %struct.FOURTH_UNION, %struct.rec*, { %struct.rec* }, %struct.rec*, %struct.rec*, %struct.rec*, %struct.rec*, %struct.rec*, %struct.rec*, %struct.rec*, %struct.rec*, i32 }
13*9880d681SAndroid Build Coastguard Worker	%struct.rec = type { %struct.head_type }
14*9880d681SAndroid Build Coastguard Worker@no_file_pos = external global %struct.FILE_POS		; <%struct.FILE_POS*> [#uses=1]
15*9880d681SAndroid Build Coastguard Worker@"\01LC13423" = external constant [23 x i8]		; <[23 x i8]*> [#uses=1]
16*9880d681SAndroid Build Coastguard Worker@"\01LC18972" = external constant [13 x i8]		; <[13 x i8]*> [#uses=1]
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Workerdefine fastcc void @FlushGalley(%struct.rec* %hd) nounwind {
19*9880d681SAndroid Build Coastguard Workerentry:
20*9880d681SAndroid Build Coastguard Worker	br label %RESUME
21*9880d681SAndroid Build Coastguard Worker
22*9880d681SAndroid Build Coastguard WorkerRESUME:		; preds = %bb520.preheader, %entry
23*9880d681SAndroid Build Coastguard Worker	br label %bb396
24*9880d681SAndroid Build Coastguard Worker
25*9880d681SAndroid Build Coastguard Workerbb122:		; preds = %bb396
26*9880d681SAndroid Build Coastguard Worker	switch i32 0, label %bb394 [
27*9880d681SAndroid Build Coastguard Worker		i32 1, label %bb131
28*9880d681SAndroid Build Coastguard Worker		i32 2, label %bb244
29*9880d681SAndroid Build Coastguard Worker		i32 4, label %bb244
30*9880d681SAndroid Build Coastguard Worker		i32 5, label %bb244
31*9880d681SAndroid Build Coastguard Worker		i32 6, label %bb244
32*9880d681SAndroid Build Coastguard Worker		i32 7, label %bb244
33*9880d681SAndroid Build Coastguard Worker		i32 11, label %bb244
34*9880d681SAndroid Build Coastguard Worker		i32 12, label %bb244
35*9880d681SAndroid Build Coastguard Worker		i32 15, label %bb244
36*9880d681SAndroid Build Coastguard Worker		i32 17, label %bb244
37*9880d681SAndroid Build Coastguard Worker		i32 18, label %bb244
38*9880d681SAndroid Build Coastguard Worker		i32 19, label %bb244
39*9880d681SAndroid Build Coastguard Worker		i32 20, label %bb396
40*9880d681SAndroid Build Coastguard Worker		i32 21, label %bb396
41*9880d681SAndroid Build Coastguard Worker		i32 22, label %bb396
42*9880d681SAndroid Build Coastguard Worker		i32 23, label %bb396
43*9880d681SAndroid Build Coastguard Worker		i32 24, label %bb244
44*9880d681SAndroid Build Coastguard Worker		i32 25, label %bb244
45*9880d681SAndroid Build Coastguard Worker		i32 26, label %bb244
46*9880d681SAndroid Build Coastguard Worker		i32 27, label %bb244
47*9880d681SAndroid Build Coastguard Worker		i32 28, label %bb244
48*9880d681SAndroid Build Coastguard Worker		i32 29, label %bb244
49*9880d681SAndroid Build Coastguard Worker		i32 30, label %bb244
50*9880d681SAndroid Build Coastguard Worker		i32 31, label %bb244
51*9880d681SAndroid Build Coastguard Worker		i32 32, label %bb244
52*9880d681SAndroid Build Coastguard Worker		i32 33, label %bb244
53*9880d681SAndroid Build Coastguard Worker		i32 34, label %bb244
54*9880d681SAndroid Build Coastguard Worker		i32 35, label %bb244
55*9880d681SAndroid Build Coastguard Worker		i32 36, label %bb244
56*9880d681SAndroid Build Coastguard Worker		i32 37, label %bb244
57*9880d681SAndroid Build Coastguard Worker		i32 38, label %bb244
58*9880d681SAndroid Build Coastguard Worker		i32 39, label %bb244
59*9880d681SAndroid Build Coastguard Worker		i32 40, label %bb244
60*9880d681SAndroid Build Coastguard Worker		i32 41, label %bb244
61*9880d681SAndroid Build Coastguard Worker		i32 42, label %bb244
62*9880d681SAndroid Build Coastguard Worker		i32 43, label %bb244
63*9880d681SAndroid Build Coastguard Worker		i32 44, label %bb244
64*9880d681SAndroid Build Coastguard Worker		i32 45, label %bb244
65*9880d681SAndroid Build Coastguard Worker		i32 46, label %bb244
66*9880d681SAndroid Build Coastguard Worker		i32 50, label %bb244
67*9880d681SAndroid Build Coastguard Worker		i32 51, label %bb244
68*9880d681SAndroid Build Coastguard Worker		i32 94, label %bb244
69*9880d681SAndroid Build Coastguard Worker		i32 95, label %bb244
70*9880d681SAndroid Build Coastguard Worker		i32 96, label %bb244
71*9880d681SAndroid Build Coastguard Worker		i32 97, label %bb244
72*9880d681SAndroid Build Coastguard Worker		i32 98, label %bb244
73*9880d681SAndroid Build Coastguard Worker		i32 99, label %bb244
74*9880d681SAndroid Build Coastguard Worker	]
75*9880d681SAndroid Build Coastguard Worker
76*9880d681SAndroid Build Coastguard Workerbb131:		; preds = %bb122
77*9880d681SAndroid Build Coastguard Worker	br label %bb396
78*9880d681SAndroid Build Coastguard Worker
79*9880d681SAndroid Build Coastguard Workerbb244:		; preds = %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122, %bb122
80*9880d681SAndroid Build Coastguard Worker	%0 = icmp eq %struct.rec* %stop_link.3, null		; <i1> [#uses=1]
81*9880d681SAndroid Build Coastguard Worker	br i1 %0, label %bb435, label %bb433
82*9880d681SAndroid Build Coastguard Worker
83*9880d681SAndroid Build Coastguard Workerbb394:		; preds = %bb122
84*9880d681SAndroid Build Coastguard Worker	call void (i32, i32, i8*, i32, %struct.FILE_POS*, ...) @Error(i32 1, i32 3, i8* getelementptr ([23 x i8], [23 x i8]* @"\01LC13423", i32 0, i32 0), i32 0, %struct.FILE_POS* @no_file_pos, i8* getelementptr ([13 x i8], [13 x i8]* @"\01LC18972", i32 0, i32 0), i8* null) nounwind
85*9880d681SAndroid Build Coastguard Worker	br label %bb396
86*9880d681SAndroid Build Coastguard Worker
87*9880d681SAndroid Build Coastguard Workerbb396:		; preds = %bb394, %bb131, %bb122, %bb122, %bb122, %bb122, %RESUME
88*9880d681SAndroid Build Coastguard Worker	%stop_link.3 = phi %struct.rec* [ null, %RESUME ], [ %stop_link.3, %bb394 ], [ %stop_link.3, %bb122 ], [ %stop_link.3, %bb122 ], [ %stop_link.3, %bb122 ], [ %stop_link.3, %bb122 ], [ %link.1, %bb131 ]		; <%struct.rec*> [#uses=7]
89*9880d681SAndroid Build Coastguard Worker	%headers_seen.1 = phi i32 [ 0, %RESUME ], [ %headers_seen.1, %bb394 ], [ 1, %bb122 ], [ 1, %bb122 ], [ 1, %bb122 ], [ 1, %bb122 ], [ %headers_seen.1, %bb131 ]		; <i32> [#uses=2]
90*9880d681SAndroid Build Coastguard Worker	%link.1 = load %struct.rec*, %struct.rec** null		; <%struct.rec*> [#uses=2]
91*9880d681SAndroid Build Coastguard Worker	%1 = icmp eq %struct.rec* %link.1, %hd		; <i1> [#uses=1]
92*9880d681SAndroid Build Coastguard Worker	br i1 %1, label %bb398, label %bb122
93*9880d681SAndroid Build Coastguard Worker
94*9880d681SAndroid Build Coastguard Workerbb398:		; preds = %bb396
95*9880d681SAndroid Build Coastguard Worker	unreachable
96*9880d681SAndroid Build Coastguard Worker
97*9880d681SAndroid Build Coastguard Workerbb433:		; preds = %bb244
98*9880d681SAndroid Build Coastguard Worker	call fastcc void @Promote(%struct.rec* %hd, %struct.rec* %stop_link.3, %struct.rec* null, i32 1) nounwind
99*9880d681SAndroid Build Coastguard Worker	br label %bb435
100*9880d681SAndroid Build Coastguard Worker
101*9880d681SAndroid Build Coastguard Workerbb435:		; preds = %bb433, %bb244
102*9880d681SAndroid Build Coastguard Worker	br i1 false, label %bb491, label %bb499
103*9880d681SAndroid Build Coastguard Worker
104*9880d681SAndroid Build Coastguard Workerbb491:		; preds = %bb435
105*9880d681SAndroid Build Coastguard Worker	br label %bb499
106*9880d681SAndroid Build Coastguard Worker
107*9880d681SAndroid Build Coastguard Workerbb499:		; preds = %bb499, %bb491, %bb435
108*9880d681SAndroid Build Coastguard Worker	%2 = icmp eq %struct.rec* null, null		; <i1> [#uses=1]
109*9880d681SAndroid Build Coastguard Worker	br i1 %2, label %bb520.preheader, label %bb499
110*9880d681SAndroid Build Coastguard Worker
111*9880d681SAndroid Build Coastguard Workerbb520.preheader:		; preds = %bb499
112*9880d681SAndroid Build Coastguard Worker	br label %RESUME
113*9880d681SAndroid Build Coastguard Worker}
114*9880d681SAndroid Build Coastguard Worker
115*9880d681SAndroid Build Coastguard Workerdeclare fastcc void @Promote(%struct.rec*, %struct.rec*, %struct.rec* nocapture, i32) nounwind
116*9880d681SAndroid Build Coastguard Worker
117*9880d681SAndroid Build Coastguard Workerdeclare void @Error(i32, i32, i8*, i32, %struct.FILE_POS*, ...) nounwind
118