xref: /aosp_15_r20/external/llvm/test/CodeGen/Thumb2/thumb2-tbh.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
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