xref: /aosp_15_r20/external/llvm/test/CodeGen/Thumb2/2010-06-21-TailMergeBug.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=thumbv7-apple-darwin -O3 -relocation-model=pic -arm-atomic-cfg-tidy=0 | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; rdar://8115404
3*9880d681SAndroid Build Coastguard Worker; Tail merging must not split an IT block.
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker%struct.FILE = type { i8*, i32, i32, i16, i16, %struct.__sbuf, i32, i8*, i32 (i8*)*, i32 (i8*, i8*, i32)*, i64 (i8*, i64, i32)*, i32 (i8*, i8*, i32)*, %struct.__sbuf, %struct.__sFILEX*, i32, [3 x i8], [1 x i8], %struct.__sbuf, i32, i64 }
6*9880d681SAndroid Build Coastguard Worker%struct._RuneCharClass = type { [14 x i8], i32 }
7*9880d681SAndroid Build Coastguard Worker%struct._RuneEntry = type { i32, i32, i32, i32* }
8*9880d681SAndroid Build Coastguard Worker%struct._RuneLocale = type { [8 x i8], [32 x i8], i32 (i8*, i32, i8**)*, i32 (i32, i8*, i32, i8**)*, i32, [256 x i32], [256 x i32], [256 x i32], %struct._RuneRange, %struct._RuneRange, %struct._RuneRange, i8*, i32, i32, %struct._RuneCharClass* }
9*9880d681SAndroid Build Coastguard Worker%struct._RuneRange = type { i32, %struct._RuneEntry* }
10*9880d681SAndroid Build Coastguard Worker%struct.__sFILEX = type opaque
11*9880d681SAndroid Build Coastguard Worker%struct.__sbuf = type { i8*, i32 }
12*9880d681SAndroid Build Coastguard Worker
13*9880d681SAndroid Build Coastguard Worker@finput = external global %struct.FILE*           ; <%struct.FILE**> [#uses=1]
14*9880d681SAndroid Build Coastguard Worker@_DefaultRuneLocale = external global %struct._RuneLocale ; <%struct._RuneLocale*> [#uses=0]
15*9880d681SAndroid Build Coastguard Worker@token_buffer = external global [1025 x i8], align 4 ; <[1025 x i8]*> [#uses=1]
16*9880d681SAndroid Build Coastguard Worker@.str73 = external constant [6 x i8], align 4     ; <[6 x i8]*> [#uses=0]
17*9880d681SAndroid Build Coastguard Worker@.str174 = external constant [5 x i8], align 4    ; <[5 x i8]*> [#uses=0]
18*9880d681SAndroid Build Coastguard Worker@.str275 = external constant [6 x i8], align 4    ; <[6 x i8]*> [#uses=0]
19*9880d681SAndroid Build Coastguard Worker@.str376 = external constant [5 x i8], align 4    ; <[5 x i8]*> [#uses=0]
20*9880d681SAndroid Build Coastguard Worker@.str477 = external constant [6 x i8], align 4    ; <[6 x i8]*> [#uses=0]
21*9880d681SAndroid Build Coastguard Worker@.str578 = external constant [6 x i8], align 4    ; <[6 x i8]*> [#uses=0]
22*9880d681SAndroid Build Coastguard Worker@.str679 = external constant [7 x i8], align 4    ; <[7 x i8]*> [#uses=0]
23*9880d681SAndroid Build Coastguard Worker@.str780 = external constant [6 x i8], align 4    ; <[6 x i8]*> [#uses=0]
24*9880d681SAndroid Build Coastguard Worker@.str881 = external constant [5 x i8], align 4    ; <[5 x i8]*> [#uses=0]
25*9880d681SAndroid Build Coastguard Worker@.str982 = external constant [6 x i8], align 4    ; <[6 x i8]*> [#uses=0]
26*9880d681SAndroid Build Coastguard Worker@.str1083 = external constant [9 x i8], align 4   ; <[9 x i8]*> [#uses=0]
27*9880d681SAndroid Build Coastguard Worker@.str1184 = external constant [7 x i8], align 4   ; <[7 x i8]*> [#uses=0]
28*9880d681SAndroid Build Coastguard Worker@.str1285 = external constant [16 x i8], align 4  ; <[16 x i8]*> [#uses=0]
29*9880d681SAndroid Build Coastguard Worker@.str1386 = external constant [12 x i8], align 4  ; <[12 x i8]*> [#uses=0]
30*9880d681SAndroid Build Coastguard Worker@.str1487 = external constant [5 x i8], align 4   ; <[5 x i8]*> [#uses=0]
31*9880d681SAndroid Build Coastguard Worker@llvm.used = external global [1 x i8*]            ; <[1 x i8*]*> [#uses=0]
32*9880d681SAndroid Build Coastguard Worker
33*9880d681SAndroid Build Coastguard Workerdefine fastcc i32 @parse_percent_token() nounwind {
34*9880d681SAndroid Build Coastguard Workerentry:
35*9880d681SAndroid Build Coastguard Worker; CHECK: pop
36*9880d681SAndroid Build Coastguard Worker; CHECK: pop
37*9880d681SAndroid Build Coastguard Worker; CHECK: pop
38*9880d681SAndroid Build Coastguard Worker; CHECK: pop
39*9880d681SAndroid Build Coastguard Worker; CHECK: pop
40*9880d681SAndroid Build Coastguard Worker; CHECK: pop
41*9880d681SAndroid Build Coastguard Worker; CHECK: pop
42*9880d681SAndroid Build Coastguard Worker; Do not convert into single stream code. BranchProbability Analysis assumes
43*9880d681SAndroid Build Coastguard Worker; that branches which goes to "ret" instruction have lower probabilities.
44*9880d681SAndroid Build Coastguard Worker  switch i32 undef, label %bb7 [
45*9880d681SAndroid Build Coastguard Worker    i32 37, label %bb43
46*9880d681SAndroid Build Coastguard Worker    i32 48, label %bb5
47*9880d681SAndroid Build Coastguard Worker    i32 50, label %bb4
48*9880d681SAndroid Build Coastguard Worker    i32 60, label %bb2
49*9880d681SAndroid Build Coastguard Worker    i32 61, label %bb6
50*9880d681SAndroid Build Coastguard Worker    i32 62, label %bb3
51*9880d681SAndroid Build Coastguard Worker    i32 123, label %bb1
52*9880d681SAndroid Build Coastguard Worker  ]
53*9880d681SAndroid Build Coastguard Worker
54*9880d681SAndroid Build Coastguard Workerbb1:                                              ; preds = %entry
55*9880d681SAndroid Build Coastguard Worker  ret i32 8
56*9880d681SAndroid Build Coastguard Worker
57*9880d681SAndroid Build Coastguard Workerbb2:                                              ; preds = %entry
58*9880d681SAndroid Build Coastguard Worker  ret i32 15
59*9880d681SAndroid Build Coastguard Worker
60*9880d681SAndroid Build Coastguard Workerbb3:                                              ; preds = %entry
61*9880d681SAndroid Build Coastguard Worker  ret i32 16
62*9880d681SAndroid Build Coastguard Worker
63*9880d681SAndroid Build Coastguard Workerbb4:                                              ; preds = %entry
64*9880d681SAndroid Build Coastguard Worker  ret i32 17
65*9880d681SAndroid Build Coastguard Worker
66*9880d681SAndroid Build Coastguard Workerbb5:                                              ; preds = %entry
67*9880d681SAndroid Build Coastguard Worker  ret i32 9
68*9880d681SAndroid Build Coastguard Worker
69*9880d681SAndroid Build Coastguard Workerbb6:                                              ; preds = %entry
70*9880d681SAndroid Build Coastguard Worker  ret i32 18
71*9880d681SAndroid Build Coastguard Worker
72*9880d681SAndroid Build Coastguard Workerbb7:                                              ; preds = %entry
73*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %bb.i.i, label %bb1.i.i
74*9880d681SAndroid Build Coastguard Worker
75*9880d681SAndroid Build Coastguard Workerbb.i.i:                                           ; preds = %bb7
76*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %bb43, label %bb12
77*9880d681SAndroid Build Coastguard Worker
78*9880d681SAndroid Build Coastguard Workerbb1.i.i:                                          ; preds = %bb7
79*9880d681SAndroid Build Coastguard Worker  unreachable
80*9880d681SAndroid Build Coastguard Worker
81*9880d681SAndroid Build Coastguard Workerbb9:                                              ; preds = %bb.i.i2
82*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %bb10, label %bb11
83*9880d681SAndroid Build Coastguard Worker
84*9880d681SAndroid Build Coastguard Workerbb10:                                             ; preds = %bb9
85*9880d681SAndroid Build Coastguard Worker  br label %bb11
86*9880d681SAndroid Build Coastguard Worker
87*9880d681SAndroid Build Coastguard Workerbb11:                                             ; preds = %bb10, %bb9
88*9880d681SAndroid Build Coastguard Worker  %p.0 = phi i8* [ undef, %bb10 ], [ %p.1, %bb9 ] ; <i8*> [#uses=1]
89*9880d681SAndroid Build Coastguard Worker  %0 = load %struct.FILE*, %struct.FILE** @finput, align 4       ; <%struct.FILE*> [#uses=1]
90*9880d681SAndroid Build Coastguard Worker  %1 = tail call i32 @getc(%struct.FILE* %0) nounwind ; <i32> [#uses=0]
91*9880d681SAndroid Build Coastguard Worker  br label %bb12
92*9880d681SAndroid Build Coastguard Worker
93*9880d681SAndroid Build Coastguard Workerbb12:                                             ; preds = %bb11, %bb.i.i
94*9880d681SAndroid Build Coastguard Worker  %p.1 = phi i8* [ %p.0, %bb11 ], [ getelementptr inbounds ([1025 x i8], [1025 x i8]* @token_buffer, i32 0, i32 0), %bb.i.i ] ; <i8*> [#uses=2]
95*9880d681SAndroid Build Coastguard Worker  %2 = icmp ult i32 undef, 128                    ; <i1> [#uses=1]
96*9880d681SAndroid Build Coastguard Worker  br i1 %2, label %bb.i.i2, label %bb1.i.i3
97*9880d681SAndroid Build Coastguard Worker
98*9880d681SAndroid Build Coastguard Workerbb.i.i2:                                          ; preds = %bb12
99*9880d681SAndroid Build Coastguard Worker  %3 = load i32, i32* null, align 4                    ; <i32> [#uses=1]
100*9880d681SAndroid Build Coastguard Worker  %4 = lshr i32 %3, 8                             ; <i32> [#uses=1]
101*9880d681SAndroid Build Coastguard Worker  %.lobit.i1 = and i32 %4, 1                      ; <i32> [#uses=1]
102*9880d681SAndroid Build Coastguard Worker  %.not = icmp ne i32 %.lobit.i1, 0               ; <i1> [#uses=1]
103*9880d681SAndroid Build Coastguard Worker  %or.cond = or i1 %.not, undef                   ; <i1> [#uses=1]
104*9880d681SAndroid Build Coastguard Worker  br i1 %or.cond, label %bb9, label %bb14
105*9880d681SAndroid Build Coastguard Worker
106*9880d681SAndroid Build Coastguard Workerbb1.i.i3:                                         ; preds = %bb12
107*9880d681SAndroid Build Coastguard Worker  unreachable
108*9880d681SAndroid Build Coastguard Worker
109*9880d681SAndroid Build Coastguard Workerbb14:                                             ; preds = %bb.i.i2
110*9880d681SAndroid Build Coastguard Worker  store i8 0, i8* %p.1, align 1
111*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %bb43, label %bb15
112*9880d681SAndroid Build Coastguard Worker
113*9880d681SAndroid Build Coastguard Workerbb15:                                             ; preds = %bb14
114*9880d681SAndroid Build Coastguard Worker  unreachable
115*9880d681SAndroid Build Coastguard Worker
116*9880d681SAndroid Build Coastguard Workerbb43:                                             ; preds = %bb14, %bb.i.i, %entry
117*9880d681SAndroid Build Coastguard Worker  %.0 = phi i32 [ 7, %entry ], [ 24, %bb.i.i ], [ 9, %bb14 ] ; <i32> [#uses=1]
118*9880d681SAndroid Build Coastguard Worker  ret i32 %.0
119*9880d681SAndroid Build Coastguard Worker}
120*9880d681SAndroid Build Coastguard Worker
121*9880d681SAndroid Build Coastguard Workerdeclare i32 @getc(%struct.FILE* nocapture) nounwind
122*9880d681SAndroid Build Coastguard Worker
123*9880d681SAndroid Build Coastguard Workerdeclare i32 @strcmp(i8* nocapture, i8* nocapture) nounwind readonly
124*9880d681SAndroid Build Coastguard Worker
125*9880d681SAndroid Build Coastguard Workerdeclare i32 @__maskrune(i32, i32)
126*9880d681SAndroid Build Coastguard Worker
127*9880d681SAndroid Build Coastguard Workerdeclare i32 @ungetc(i32, %struct.FILE* nocapture) nounwind
128