xref: /aosp_15_r20/external/llvm/test/CodeGen/ARM/2010-05-17-FastAllocCrash.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -regalloc=fast -optimize-regalloc=0 -verify-machineinstrs
2*9880d681SAndroid Build Coastguard Workertarget triple = "arm-pc-linux-gnu"
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker; This test case would accidentally use the same physreg for two virtregs
5*9880d681SAndroid Build Coastguard Worker; because allocVirtReg forgot to check if registers were already used in the
6*9880d681SAndroid Build Coastguard Worker; instruction.
7*9880d681SAndroid Build Coastguard Worker; This caused the RegScavenger to complain, but -verify-machineinstrs also
8*9880d681SAndroid Build Coastguard Worker; catches it.
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Worker%struct.CHESS_POSITION = type { i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i32, i32, i8, i8, [64 x i8], i8, i8, i8, i8, i8 }
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Worker@search = external global %struct.CHESS_POSITION  ; <%struct.CHESS_POSITION*> [#uses=1]
13*9880d681SAndroid Build Coastguard Worker@bishop_mobility_rr45 = external global [64 x [256 x i32]] ; <[64 x [256 x i32]]*> [#uses=1]
14*9880d681SAndroid Build Coastguard Worker
15*9880d681SAndroid Build Coastguard Workerdeclare fastcc i32 @FirstOne()
16*9880d681SAndroid Build Coastguard Worker
17*9880d681SAndroid Build Coastguard Workerdefine fastcc void @Evaluate() {
18*9880d681SAndroid Build Coastguard Workerentry:
19*9880d681SAndroid Build Coastguard Worker  br i1 false, label %cond_false186, label %cond_true
20*9880d681SAndroid Build Coastguard Worker
21*9880d681SAndroid Build Coastguard Workercond_true:                                        ; preds = %entry
22*9880d681SAndroid Build Coastguard Worker  ret void
23*9880d681SAndroid Build Coastguard Worker
24*9880d681SAndroid Build Coastguard Workercond_false186:                                    ; preds = %entry
25*9880d681SAndroid Build Coastguard Worker  br i1 false, label %cond_true293, label %bb203
26*9880d681SAndroid Build Coastguard Worker
27*9880d681SAndroid Build Coastguard Workerbb203:                                            ; preds = %cond_false186
28*9880d681SAndroid Build Coastguard Worker  ret void
29*9880d681SAndroid Build Coastguard Worker
30*9880d681SAndroid Build Coastguard Workercond_true293:                                     ; preds = %cond_false186
31*9880d681SAndroid Build Coastguard Worker  br i1 false, label %cond_true298, label %cond_next317
32*9880d681SAndroid Build Coastguard Worker
33*9880d681SAndroid Build Coastguard Workercond_true298:                                     ; preds = %cond_true293
34*9880d681SAndroid Build Coastguard Worker  br i1 false, label %cond_next518, label %cond_true397.preheader
35*9880d681SAndroid Build Coastguard Worker
36*9880d681SAndroid Build Coastguard Workercond_next317:                                     ; preds = %cond_true293
37*9880d681SAndroid Build Coastguard Worker  ret void
38*9880d681SAndroid Build Coastguard Worker
39*9880d681SAndroid Build Coastguard Workercond_true397.preheader:                           ; preds = %cond_true298
40*9880d681SAndroid Build Coastguard Worker  ret void
41*9880d681SAndroid Build Coastguard Worker
42*9880d681SAndroid Build Coastguard Workercond_next518:                                     ; preds = %cond_true298
43*9880d681SAndroid Build Coastguard Worker  br i1 false, label %bb1069, label %cond_true522
44*9880d681SAndroid Build Coastguard Worker
45*9880d681SAndroid Build Coastguard Workercond_true522:                                     ; preds = %cond_next518
46*9880d681SAndroid Build Coastguard Worker  ret void
47*9880d681SAndroid Build Coastguard Worker
48*9880d681SAndroid Build Coastguard Workerbb1069:                                           ; preds = %cond_next518
49*9880d681SAndroid Build Coastguard Worker  br i1 false, label %cond_next1131, label %bb1096
50*9880d681SAndroid Build Coastguard Worker
51*9880d681SAndroid Build Coastguard Workerbb1096:                                           ; preds = %bb1069
52*9880d681SAndroid Build Coastguard Worker  ret void
53*9880d681SAndroid Build Coastguard Worker
54*9880d681SAndroid Build Coastguard Workercond_next1131:                                    ; preds = %bb1069
55*9880d681SAndroid Build Coastguard Worker  br i1 false, label %cond_next1207, label %cond_true1150
56*9880d681SAndroid Build Coastguard Worker
57*9880d681SAndroid Build Coastguard Workercond_true1150:                                    ; preds = %cond_next1131
58*9880d681SAndroid Build Coastguard Worker  ret void
59*9880d681SAndroid Build Coastguard Worker
60*9880d681SAndroid Build Coastguard Workercond_next1207:                                    ; preds = %cond_next1131
61*9880d681SAndroid Build Coastguard Worker  br i1 false, label %cond_next1219, label %cond_true1211
62*9880d681SAndroid Build Coastguard Worker
63*9880d681SAndroid Build Coastguard Workercond_true1211:                                    ; preds = %cond_next1207
64*9880d681SAndroid Build Coastguard Worker  ret void
65*9880d681SAndroid Build Coastguard Worker
66*9880d681SAndroid Build Coastguard Workercond_next1219:                                    ; preds = %cond_next1207
67*9880d681SAndroid Build Coastguard Worker  br i1 false, label %cond_true1223, label %cond_next1283
68*9880d681SAndroid Build Coastguard Worker
69*9880d681SAndroid Build Coastguard Workercond_true1223:                                    ; preds = %cond_next1219
70*9880d681SAndroid Build Coastguard Worker  br i1 false, label %cond_true1254, label %cond_true1264
71*9880d681SAndroid Build Coastguard Worker
72*9880d681SAndroid Build Coastguard Workercond_true1254:                                    ; preds = %cond_true1223
73*9880d681SAndroid Build Coastguard Worker  br i1 false, label %bb1567, label %cond_true1369.preheader
74*9880d681SAndroid Build Coastguard Worker
75*9880d681SAndroid Build Coastguard Workercond_true1264:                                    ; preds = %cond_true1223
76*9880d681SAndroid Build Coastguard Worker  ret void
77*9880d681SAndroid Build Coastguard Worker
78*9880d681SAndroid Build Coastguard Workercond_next1283:                                    ; preds = %cond_next1219
79*9880d681SAndroid Build Coastguard Worker  ret void
80*9880d681SAndroid Build Coastguard Worker
81*9880d681SAndroid Build Coastguard Workercond_true1369.preheader:                          ; preds = %cond_true1254
82*9880d681SAndroid Build Coastguard Worker  ret void
83*9880d681SAndroid Build Coastguard Worker
84*9880d681SAndroid Build Coastguard Workerbb1567:                                           ; preds = %cond_true1254
85*9880d681SAndroid Build Coastguard Worker  %tmp1591 = load i64, i64* getelementptr inbounds (%struct.CHESS_POSITION, %struct.CHESS_POSITION* @search, i32 0, i32 4) ; <i64> [#uses=1]
86*9880d681SAndroid Build Coastguard Worker  %tmp1572 = tail call fastcc i32 @FirstOne()     ; <i32> [#uses=1]
87*9880d681SAndroid Build Coastguard Worker  %tmp1594 = load i32, i32* undef                      ; <i32> [#uses=1]
88*9880d681SAndroid Build Coastguard Worker  %tmp1594.upgrd.5 = trunc i32 %tmp1594 to i8     ; <i8> [#uses=1]
89*9880d681SAndroid Build Coastguard Worker  %shift.upgrd.6 = zext i8 %tmp1594.upgrd.5 to i64 ; <i64> [#uses=1]
90*9880d681SAndroid Build Coastguard Worker  %tmp1595 = lshr i64 %tmp1591, %shift.upgrd.6    ; <i64> [#uses=1]
91*9880d681SAndroid Build Coastguard Worker  %tmp1595.upgrd.7 = trunc i64 %tmp1595 to i32    ; <i32> [#uses=1]
92*9880d681SAndroid Build Coastguard Worker  %tmp1596 = and i32 %tmp1595.upgrd.7, 255        ; <i32> [#uses=1]
93*9880d681SAndroid Build Coastguard Worker  %gep.upgrd.8 = zext i32 %tmp1596 to i64         ; <i64> [#uses=1]
94*9880d681SAndroid Build Coastguard Worker  %tmp1598 = getelementptr [64 x [256 x i32]], [64 x [256 x i32]]* @bishop_mobility_rr45, i32 0, i32 %tmp1572, i64 %gep.upgrd.8 ; <i32*> [#uses=1]
95*9880d681SAndroid Build Coastguard Worker  %tmp1599 = load i32, i32* %tmp1598                   ; <i32> [#uses=1]
96*9880d681SAndroid Build Coastguard Worker  %tmp1602 = sub i32 0, %tmp1599                  ; <i32> [#uses=1]
97*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %cond_next1637, label %cond_true1607
98*9880d681SAndroid Build Coastguard Worker
99*9880d681SAndroid Build Coastguard Workercond_true1607:                                    ; preds = %bb1567
100*9880d681SAndroid Build Coastguard Worker  ret void
101*9880d681SAndroid Build Coastguard Worker
102*9880d681SAndroid Build Coastguard Workercond_next1637:                                    ; preds = %bb1567
103*9880d681SAndroid Build Coastguard Worker  %tmp1662 = sub i32 %tmp1602, 0                  ; <i32> [#uses=0]
104*9880d681SAndroid Build Coastguard Worker  ret void
105*9880d681SAndroid Build Coastguard Worker}
106