1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=thumbv7-apple-darwin -relocation-model=pic | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker; Thumb2 target should reorder the bb's in order to use tbb / tbh. 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Worker %struct.R_flstr = type { i32, i32, i8* } 6*9880d681SAndroid Build Coastguard Worker %struct._T_tstr = type { i32, %struct.R_flstr*, %struct._T_tstr* } 7*9880d681SAndroid Build Coastguard Worker@_C_nextcmd = external global i32 ; <i32*> [#uses=3] 8*9880d681SAndroid Build Coastguard Worker@.str31 = external constant [28 x i8], align 1 ; <[28 x i8]*> [#uses=1] 9*9880d681SAndroid Build Coastguard Worker@_T_gtol = external global %struct._T_tstr* ; <%struct._T_tstr**> [#uses=2] 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Workerdeclare i32 @strlen(i8* nocapture) nounwind readonly 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Workerdeclare void @Z_fatal(i8*) noreturn nounwind 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Workerdeclare noalias i8* @calloc(i32, i32) nounwind 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Worker; Jump tables are not anchored next to the TBB/TBH any more. Make sure the 18*9880d681SAndroid Build Coastguard Worker; correct address is still calculated (i.e. via a PC-relative symbol *at* the 19*9880d681SAndroid Build Coastguard Worker; TBB/TBH). 20*9880d681SAndroid Build Coastguard Workerdefine i32 @main(i32 %argc, i8** nocapture %argv) nounwind { 21*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: main: 22*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: adr {{r[0-9]+}}, LJTI 23*9880d681SAndroid Build Coastguard Worker; CHECK: [[PCREL_ANCHOR:LCPI[0-9]+_[0-9]+]]: 24*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: tbb [pc, {{r[0-9]+}}] 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Worker; CHECK: LJTI0_0: 27*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .data_region jt8 28*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte (LBB{{[0-9]+_[0-9]+}}-([[PCREL_ANCHOR]]+4))/2 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Workerentry: 31*9880d681SAndroid Build Coastguard Worker br label %bb42.i 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Workerbb1.i2: ; preds = %bb42.i 34*9880d681SAndroid Build Coastguard Worker br label %bb40.i 35*9880d681SAndroid Build Coastguard Worker 36*9880d681SAndroid Build Coastguard Workerbb5.i: ; preds = %bb42.i 37*9880d681SAndroid Build Coastguard Worker %0 = or i32 %argc, 32 ; <i32> [#uses=1] 38*9880d681SAndroid Build Coastguard Worker br label %bb40.i 39*9880d681SAndroid Build Coastguard Worker 40*9880d681SAndroid Build Coastguard Workerbb7.i: ; preds = %bb42.i 41*9880d681SAndroid Build Coastguard Worker call void @_T_addtol(%struct._T_tstr** @_T_gtol, i32 0, i8* null) nounwind 42*9880d681SAndroid Build Coastguard Worker unreachable 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Workerbb15.i: ; preds = %bb42.i 45*9880d681SAndroid Build Coastguard Worker call void @_T_addtol(%struct._T_tstr** @_T_gtol, i32 2, i8* null) nounwind 46*9880d681SAndroid Build Coastguard Worker unreachable 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Workerbb23.i: ; preds = %bb42.i 49*9880d681SAndroid Build Coastguard Worker %1 = call i32 @strlen(i8* null) nounwind readonly ; <i32> [#uses=0] 50*9880d681SAndroid Build Coastguard Worker unreachable 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Workerbb33.i: ; preds = %bb42.i 53*9880d681SAndroid Build Coastguard Worker store i32 0, i32* @_C_nextcmd, align 4 54*9880d681SAndroid Build Coastguard Worker %2 = call noalias i8* @calloc(i32 21, i32 1) nounwind ; <i8*> [#uses=0] 55*9880d681SAndroid Build Coastguard Worker unreachable 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Workerbb34.i: ; preds = %bb42.i 58*9880d681SAndroid Build Coastguard Worker %3 = load i32, i32* @_C_nextcmd, align 4 ; <i32> [#uses=1] 59*9880d681SAndroid Build Coastguard Worker %4 = add i32 %3, 1 ; <i32> [#uses=1] 60*9880d681SAndroid Build Coastguard Worker store i32 %4, i32* @_C_nextcmd, align 4 61*9880d681SAndroid Build Coastguard Worker %5 = call noalias i8* @calloc(i32 22, i32 1) nounwind ; <i8*> [#uses=0] 62*9880d681SAndroid Build Coastguard Worker unreachable 63*9880d681SAndroid Build Coastguard Worker 64*9880d681SAndroid Build Coastguard Workerbb35.i: ; preds = %bb42.i 65*9880d681SAndroid Build Coastguard Worker %6 = call noalias i8* @calloc(i32 20, i32 1) nounwind ; <i8*> [#uses=0] 66*9880d681SAndroid Build Coastguard Worker unreachable 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard Workerbb37.i: ; preds = %bb42.i 69*9880d681SAndroid Build Coastguard Worker %7 = call noalias i8* @calloc(i32 14, i32 1) nounwind ; <i8*> [#uses=0] 70*9880d681SAndroid Build Coastguard Worker unreachable 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard Workerbb39.i: ; preds = %bb42.i 73*9880d681SAndroid Build Coastguard Worker call void @Z_fatal(i8* getelementptr ([28 x i8], [28 x i8]* @.str31, i32 0, i32 0)) nounwind 74*9880d681SAndroid Build Coastguard Worker unreachable 75*9880d681SAndroid Build Coastguard Worker 76*9880d681SAndroid Build Coastguard Workerbb40.i: ; preds = %bb42.i, %bb5.i, %bb1.i2 77*9880d681SAndroid Build Coastguard Worker br label %bb42.i 78*9880d681SAndroid Build Coastguard Worker 79*9880d681SAndroid Build Coastguard Workerbb42.i: ; preds = %bb40.i, %entry 80*9880d681SAndroid Build Coastguard Worker switch i32 %argc, label %bb39.i [ 81*9880d681SAndroid Build Coastguard Worker i32 67, label %bb33.i 82*9880d681SAndroid Build Coastguard Worker i32 70, label %bb35.i 83*9880d681SAndroid Build Coastguard Worker i32 77, label %bb37.i 84*9880d681SAndroid Build Coastguard Worker i32 83, label %bb34.i 85*9880d681SAndroid Build Coastguard Worker i32 97, label %bb7.i 86*9880d681SAndroid Build Coastguard Worker i32 100, label %bb5.i 87*9880d681SAndroid Build Coastguard Worker i32 101, label %bb40.i 88*9880d681SAndroid Build Coastguard Worker i32 102, label %bb23.i 89*9880d681SAndroid Build Coastguard Worker i32 105, label %bb15.i 90*9880d681SAndroid Build Coastguard Worker i32 116, label %bb1.i2 91*9880d681SAndroid Build Coastguard Worker ] 92*9880d681SAndroid Build Coastguard Worker} 93*9880d681SAndroid Build Coastguard Worker 94*9880d681SAndroid Build Coastguard Workerdeclare void @_T_addtol(%struct._T_tstr** nocapture, i32, i8*) nounwind 95