[HLSL] Implement RWBuffer::operator[] via __builtin_hlsl_resource_getpointer (#117017)
[llvm-project.git] / llvm / test / CodeGen / Hexagon / registerscav-missing-spill-slot.ll
blob1a8e06259abb77e69564c9e75bdf82e9f6d3f9f9
1 ; RUN: llc -march=hexagon -machine-sink-split=0 < %s
2 ; REQUIRES: asserts
3 ; Used to fail with: Assertion `ScavengingFrameIndex >= 0 && "Cannot scavenge register without an emergency spill slot!"' failed.
5 target triple = "hexagon-unknown-linux-gnu"
7 %s.0 = type { double, double, double, double, double, double, i32, double, double, double, double, ptr, i8, [9 x i8], double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, double, [200 x ptr], [32 x ptr], [32 x i8], i32 }
9 ; Function Attrs: nounwind
10 define void @f0() #0 {
11 b0:
12   %v0 = call ptr @f2()
13   br i1 undef, label %b1, label %b2
15 b1:                                               ; preds = %b0
16   ret void
18 b2:                                               ; preds = %b0
19   br i1 undef, label %b3, label %b4
21 b3:                                               ; preds = %b2
22   unreachable
24 b4:                                               ; preds = %b2
25   br i1 undef, label %b5, label %b6
27 b5:                                               ; preds = %b4
28   unreachable
30 b6:                                               ; preds = %b4
31   %v1 = call i32 @f1() #0
32   br i1 undef, label %b7, label %b20
34 b7:                                               ; preds = %b6
35   switch i32 undef, label %b8 [
36     i32 6, label %b9
37     i32 1, label %b14
38     i32 2, label %b13
39     i32 3, label %b12
40     i32 4, label %b11
41     i32 5, label %b10
42   ]
44 b8:                                               ; preds = %b7
45   br label %b9
47 b9:                                               ; preds = %b8, %b7
48   unreachable
50 b10:                                              ; preds = %b7
51   unreachable
53 b11:                                              ; preds = %b7
54   unreachable
56 b12:                                              ; preds = %b7
57   unreachable
59 b13:                                              ; preds = %b7
60   unreachable
62 b14:                                              ; preds = %b7
63   %v2 = call ptr @f3(i32 0) #0
64   br label %b15
66 b15:                                              ; preds = %b15, %b14
67   %v4 = fadd double undef, undef
68   br i1 undef, label %b16, label %b15
70 b16:                                              ; preds = %b15
71   switch i32 undef, label %b18 [
72     i32 0, label %b19
73     i32 2, label %b17
74   ]
76 b17:                                              ; preds = %b16
77   %v7 = or i32 0, 16
78   %v8 = getelementptr i8, ptr %v0, i32 %v7
79   %v10 = load double, ptr undef, align 8, !tbaa !0
80   %v11 = fcmp olt double -1.000000e+11, %v10
81   %v12 = select i1 %v11, double %v10, double -1.000000e+11
82   %v13 = load double, ptr %v0, align 8, !tbaa !0
83   %v14 = fcmp olt double -1.000000e+11, %v13
84   %v15 = select i1 %v14, double %v13, double -1.000000e+11
85   %v16 = load double, ptr %v8, align 8, !tbaa !0
86   %v17 = fcmp olt double -1.000000e+11, %v16
87   %v18 = select i1 %v17, double %v16, double -1.000000e+11
88   %v19 = fcmp ogt double 1.000000e+11, %v13
89   %v20 = select i1 %v19, double %v13, double 1.000000e+11
90   %v21 = fcmp ogt double 1.000000e+11, %v16
91   %v22 = select i1 %v21, double %v16, double 1.000000e+11
92   br label %b18
94 b18:                                              ; preds = %b17, %b16
95   %v23 = phi double [ %v12, %b17 ], [ -1.000000e+11, %b16 ]
96   %v24 = phi double [ %v15, %b17 ], [ -1.000000e+11, %b16 ]
97   %v25 = phi double [ %v20, %b17 ], [ 1.000000e+11, %b16 ]
98   %v26 = phi double [ %v18, %b17 ], [ -1.000000e+11, %b16 ]
99   %v27 = phi double [ %v22, %b17 ], [ 1.000000e+11, %b16 ]
100   %v28 = load double, ptr undef, align 8, !tbaa !0
101   %v29 = select i1 undef, double %v28, double %v23
102   %v30 = load double, ptr null, align 8, !tbaa !0
103   %v31 = select i1 undef, double %v30, double %v24
104   %v32 = load double, ptr undef, align 8, !tbaa !0
105   %v33 = select i1 undef, double %v32, double %v26
106   %v34 = select i1 undef, double %v30, double %v25
107   %v35 = select i1 undef, double %v32, double %v27
108   br i1 false, label %b20, label %b19
110 b19:                                              ; preds = %b19, %b18, %b16
111   %v36 = phi double [ %v75, %b19 ], [ -1.000000e+11, %b16 ], [ %v29, %b18 ]
112   %v37 = phi double [ %v81, %b19 ], [ 1.000000e+11, %b16 ], [ undef, %b18 ]
113   %v38 = phi double [ %v78, %b19 ], [ -1.000000e+11, %b16 ], [ %v31, %b18 ]
114   %v39 = phi double [ %v82, %b19 ], [ 1.000000e+11, %b16 ], [ %v34, %b18 ]
115   %v40 = phi double [ %v80, %b19 ], [ -1.000000e+11, %b16 ], [ %v33, %b18 ]
116   %v41 = phi double [ %v84, %b19 ], [ 1.000000e+11, %b16 ], [ %v35, %b18 ]
117   %v44 = load double, ptr null, align 8, !tbaa !0
118   %v45 = select i1 undef, double %v44, double %v36
119   %v46 = load double, ptr %v0, align 8, !tbaa !0
120   %v47 = select i1 undef, double %v46, double %v38
121   %v48 = load double, ptr undef, align 8, !tbaa !0
122   %v49 = select i1 undef, double %v48, double %v40
123   %v50 = select i1 undef, double %v44, double %v37
124   %v51 = fcmp ogt double %v39, %v46
125   %v52 = select i1 %v51, double %v46, double %v39
126   %v53 = select i1 undef, double %v48, double %v41
127   %v54 = load double, ptr null, align 8, !tbaa !0
128   %v55 = select i1 undef, double %v54, double %v45
129   %v56 = load double, ptr undef, align 8, !tbaa !0
130   %v57 = select i1 undef, double %v56, double %v47
131   %v58 = load double, ptr undef, align 8, !tbaa !0
132   %v59 = select i1 undef, double %v58, double %v49
133   %v60 = select i1 undef, double %v54, double %v50
134   %v61 = select i1 undef, double %v56, double %v52
135   %v62 = select i1 false, double %v58, double %v53
136   %v63 = load double, ptr undef, align 8, !tbaa !0
137   %v64 = select i1 undef, double %v63, double %v55
138   %v65 = load double, ptr undef, align 8, !tbaa !0
139   %v66 = select i1 undef, double %v65, double %v57
140   %v67 = load double, ptr null, align 8, !tbaa !0
141   %v68 = select i1 undef, double %v67, double %v59
142   %v69 = fcmp ogt double %v60, %v63
143   %v70 = select i1 %v69, double %v63, double %v60
144   %v71 = select i1 false, double %v65, double %v61
145   %v72 = select i1 false, double %v67, double %v62
146   %v73 = load double, ptr null, align 8, !tbaa !0
147   %v74 = fcmp olt double %v64, %v73
148   %v75 = select i1 %v74, double %v73, double %v64
149   %v76 = load double, ptr null, align 8, !tbaa !0
150   %v77 = fcmp olt double %v66, %v76
151   %v78 = select i1 %v77, double %v76, double %v66
152   %v79 = fcmp olt double %v68, 0.000000e+00
153   %v80 = select i1 %v79, double 0.000000e+00, double %v68
154   %v81 = select i1 undef, double %v73, double %v70
155   %v82 = select i1 undef, double %v76, double %v71
156   %v83 = fcmp ogt double %v72, 0.000000e+00
157   %v84 = select i1 %v83, double 0.000000e+00, double %v72
158   br i1 false, label %b20, label %b19
160 b20:                                              ; preds = %b19, %b18, %b6
161   unreachable
164 declare i32 @f1(...)
166 ; Function Attrs: nounwind
167 declare noalias ptr @f2() #0
169 declare ptr @f3(...)
171 attributes #0 = { nounwind }
173 !0 = !{!1, !1, i64 0}
174 !1 = !{!"double", !2}
175 !2 = !{!"omnipotent char", !3}
176 !3 = !{!"Simple C/C++ TBAA"}