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