Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / X86 / non-value-mem-operand.mir
blobf188e821c2dad3eb6493af4dfb1be384e6f0d3d2
1 # RUN: llc  -run-pass implicit-null-checks -mtriple=x86_64-apple-macosx -o - %s | FileCheck %s\r
2 \r
3 # CHECK-NOT: FAULTING_OP\r
4 \r
5 --- |\r
6   target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"\r
7   target triple = "x86_64-unknown-linux-gnu"\r
8   \r
9   @global = external global i8*\r
10   @global.1 = external global i8*\r
11   \r
12   declare i8* @ham(i8*, i8**)\r
13   \r
14   define void @eggs(i8* %arg) gc "statepoint-example" {\r
15   bb:\r
16     %tmp = call i8* undef(i8* undef, i8** undef)\r
17     %tmp1 = icmp eq i8* %tmp, null\r
18     br i1 %tmp1, label %bb2, label %bb3, !make.implicit !0\r
19   \r
20   bb2:                                              ; preds = %bb\r
21     br i1 undef, label %bb51, label %bb59\r
22   \r
23   bb3:                                              ; preds = %bb\r
24     %tmp4 = getelementptr inbounds i8, i8* %tmp, i64 16\r
25     %tmp5 = bitcast i8* %tmp4 to i64*\r
26     br label %bb7\r
27   \r
28   bb7:                                              ; preds = %bb37, %bb3\r
29     %tmp8 = phi i64* [ %tmp5, %bb3 ], [ %tmp18, %bb37 ]\r
30     %tmp10 = phi i32 [ undef, %bb3 ], [ %tmp48, %bb37 ]\r
31     %tmp12 = phi i32 [ 0, %bb3 ], [ 6, %bb37 ]\r
32     %tmp13 = phi double [ 0.000000e+00, %bb3 ], [ 2.000000e+00, %bb37 ]\r
33     %tmp14 = zext i32 %tmp10 to i64\r
34     br i1 undef, label %bb26, label %bb15\r
35   \r
36   bb15:                                             ; preds = %bb7\r
37     %tmp16 = call token (i64, i32, void ()*, i32, i32, ...) @llvm.experimental.gc.statepoint.p0f_isVoidf(i64 2882400000, i32 0, void ()* nonnull elementtype(void ()) @wibble, i32 0, i32 0, i32 0, i32 0) ["deopt" (i32 1, i32 0, i32 99, i32 0, i32 12, i32 0, i32 10, i32 %tmp10, i32 10, i32 0, i32 10, i32 %tmp12, i32 10, i32 undef, i32 6, float undef, i32 7, double %tmp13, i32 99, i8* null, i32 7, double undef, i32 99, i8* null, i32 13, i8* %tmp, i32 7, double undef, i32 99, i8* null, i8* undef)]\r
38     br label %bb26\r
39   \r
40   bb26:                                             ; preds = %bb15, %bb7\r
41     %tmp18 = phi i64* [ %tmp8, %bb7 ], [ undef, %bb15 ]\r
42     %tmp20 = sub i32 0, 0\r
43     %tmp21 = select i1 undef, i32 0, i32 %tmp20\r
44     %tmp22 = sext i32 %tmp21 to i64\r
45     %tmp23 = load i8*, i8** @global.1, align 8\r
46     %tmp24 = icmp eq i8* %tmp23, null\r
47     %tmp25 = select i1 %tmp24, i8* null, i8* undef\r
48     %tmp27 = load i32, i32* undef, align 4\r
49     %sunkaddr = mul i64 %tmp14, 8\r
50     %tmp2 = bitcast i64* %tmp18 to i8*\r
51     %sunkaddr1 = getelementptr i8, i8* %tmp2, i64 %sunkaddr\r
52     %tmp3 = bitcast i8* %sunkaddr1 to i64*\r
53     %tmp28 = load i64, i64* %tmp3, align 8\r
54     %tmp29 = add i64 %tmp28, 1\r
55     store i64 %tmp29, i64* %tmp3, align 8\r
56     %tmp30 = trunc i64 %tmp28 to i32\r
57     %tmp31 = sub i32 %tmp27, %tmp30\r
58     store i32 %tmp31, i32* undef, align 4\r
59     %tmp32 = getelementptr inbounds i8, i8* %tmp25, i64 768\r
60     %tmp33 = bitcast i8* %tmp32 to i64*\r
61     %tmp34 = load i64, i64* %tmp33, align 8\r
62     br i1 undef, label %bb37, label %bb35\r
63   \r
64   bb35:                                             ; preds = %bb26\r
65     %tmp36 = call i8* @ham(i8* undef, i8** nonnull @global)\r
66     br label %bb37\r
67   \r
68   bb37:                                             ; preds = %bb35, %bb26\r
69     %tmp38 = phi i8* [ %tmp36, %bb35 ], [ undef, %bb26 ]\r
70     %tmp39 = getelementptr inbounds i8, i8* %tmp38, i64 760\r
71     %tmp40 = bitcast i8* %tmp39 to i64*\r
72     %tmp41 = load i64, i64* %tmp40, align 8\r
73     %tmp42 = icmp slt i64 %tmp34, %tmp41\r
74     %tmp43 = select i1 %tmp42, i64 %tmp41, i64 %tmp34\r
75     %tmp44 = and i64 %tmp43, 63\r
76     %tmp45 = ashr i64 %tmp29, %tmp44\r
77     %sunkaddr2 = mul i64 %tmp14, 8\r
78     %tmp6 = bitcast i64* %tmp18 to i8*\r
79     %sunkaddr3 = getelementptr i8, i8* %tmp6, i64 %sunkaddr2\r
80     %tmp7 = bitcast i8* %sunkaddr3 to i64*\r
81     store i64 %tmp45, i64* %tmp7, align 8\r
82     %tmp46 = sub i64 0, %tmp22\r
83     store i64 %tmp46, i64* undef, align 8\r
84     %tmp47 = add nsw i32 %tmp12, 1\r
85     %tmp48 = add i32 %tmp10, 1\r
86     %tmp49 = icmp sgt i32 %tmp48, 15140\r
87     br i1 %tmp49, label %bb51.loopexit, label %bb7\r
88   \r
89   bb51.loopexit:                                    ; preds = %bb37\r
90     %tmp9 = add i32 %tmp10, 1\r
91     br label %bb51\r
92   \r
93   bb51:                                             ; preds = %bb51.loopexit, %bb2\r
94     %tmp52 = phi i32 [ %tmp47, %bb51.loopexit ], [ 0, %bb2 ]\r
95     %tmp53 = phi double [ 2.000000e+00, %bb51.loopexit ], [ 0.000000e+00, %bb2 ]\r
96     %tmp54 = phi i32 [ %tmp9, %bb51.loopexit ], [ undef, %bb2 ]\r
97     %tmp56 = add i32 %tmp54, 0\r
98     %tmp57 = call token (i64, i32, void (i32)*, i32, i32, ...) @llvm.experimental.gc.statepoint.p0f_isVoidi32f(i64 2882400000, i32 0, void (i32)* nonnull elementtype(void (i32)) @wobble, i32 1, i32 0, i32 -121, i32 0, i32 0) ["deopt" (i32 1, i32 0, i32 270, i32 4, i32 12, i32 0, i32 11, i64 undef, i32 99, i8* null, i32 10, i32 %tmp56, i32 6, float undef, i32 99, i8* null, i32 99, i8* null, i32 10, i32 %tmp52, i32 10, i32 undef, i32 99, i8* null, i32 7, double %tmp53, i32 99, i8* null, i32 7, double undef, i32 99, i8* null, i32 13, i8* undef, i32 99, i8* null, i32 99, i8* null, i8* undef)]\r
99     unreachable\r
100   \r
101   bb59:                                             ; preds = %bb2\r
102     %tmp61 = call token (i64, i32, void (i32)*, i32, i32, ...) @llvm.experimental.gc.statepoint.p0f_isVoidi32f(i64 2882400000, i32 0, void (i32)* nonnull elementtype(void (i32)) @wobble, i32 1, i32 0, i32 8, i32 0, i32 0) ["deopt" (i32 1, i32 0, i32 123, i32 4, i32 12, i32 0, i32 13, i8* null, i32 99, i32 undef, i32 13, i8* null, i32 10, i32 undef, i32 99, i32 undef, i32 99, i32 undef, i32 99, i32 undef, i32 99, i8* null, i32 99, float undef, i32 99, double undef, i32 99, i8* null, i32 99, double undef, i32 99, i8* null, i32 13, i8* null, i32 99, double undef, i32 99, i8* null)]\r
103     unreachable\r
104   }\r
105   \r
106   declare void @wibble()\r
107   \r
108   declare void @wobble(i32)\r
109   \r
110   declare token @llvm.experimental.gc.statepoint.p0f_isVoidi32f(i64, i32, void (i32)*, i32, i32, ...)\r
111   \r
112   declare token @llvm.experimental.gc.statepoint.p0f_isVoidf(i64, i32, void ()*, i32, i32, ...)\r
113   \r
114   ; Function Attrs: nounwind\r
115   declare void @llvm.stackprotector(i8*, i8**) #0\r
116   \r
117   attributes #0 = { nounwind }\r
118   \r
119   !0 = !{}\r
120 ...\r
121 ---\r
122 name:            eggs\r
123 alignment:       16\r
124 tracksRegLiveness: true\r
125 fixedStack:      \r
126   - { id: 0, type: spill-slot, offset: -56, size: 8, alignment: 8, callee-saved-register: '$rbx' }\r
127   - { id: 1, type: spill-slot, offset: -48, size: 8, alignment: 16, callee-saved-register: '$r12' }\r
128   - { id: 2, type: spill-slot, offset: -40, size: 8, alignment: 8, callee-saved-register: '$r13' }\r
129   - { id: 3, type: spill-slot, offset: -32, size: 8, alignment: 16, callee-saved-register: '$r14' }\r
130   - { id: 4, type: spill-slot, offset: -24, size: 8, alignment: 8, callee-saved-register: '$r15' }\r
131   - { id: 5, type: spill-slot, offset: -16, size: 8, alignment: 16, callee-saved-register: '$rbp' }\r
132 stack:           \r
133   - { id: 0, offset: -88, size: 8, alignment: 8 }\r
134   - { id: 1, offset: -96, size: 8, alignment: 8 }\r
135   - { id: 2, offset: -104, size: 8, alignment: 8 }\r
136   - { id: 3, offset: -64, size: 8, alignment: 8 }\r
137   - { id: 4, type: spill-slot, offset: -72, size: 8, alignment: 8 }\r
138   - { id: 5, type: spill-slot, offset: -80, size: 8, alignment: 8 }\r
139 constants:       \r
140   - id:              0\r
141     value:           'double 2.000000e+00'\r
142     alignment:       8\r
143 body:             |\r
144   bb.0.bb:\r
145     successors: %bb.1.bb2(0x00000800), %bb.3.bb3(0x7ffff800)\r
146     liveins: $rbp, $r15, $r14, $r13, $r12, $rbx\r
147   \r
148     frame-setup PUSH64r killed $rbp, implicit-def $rsp, implicit $rsp\r
149     frame-setup PUSH64r killed $r15, implicit-def $rsp, implicit $rsp\r
150     frame-setup PUSH64r killed $r14, implicit-def $rsp, implicit $rsp\r
151     frame-setup PUSH64r killed $r13, implicit-def $rsp, implicit $rsp\r
152     frame-setup PUSH64r killed $r12, implicit-def $rsp, implicit $rsp\r
153     frame-setup PUSH64r killed $rbx, implicit-def $rsp, implicit $rsp\r
154     $rsp = frame-setup SUB64ri8 $rsp, 56, implicit-def dead $eflags\r
155     CALL64r undef $rax, csr_64, implicit $rsp, implicit undef $rdi, implicit undef $rsi, implicit-def $rsp, implicit-def $rax\r
156     TEST64rr $rax, $rax, implicit-def $eflags\r
157     JCC_1 %bb.3.bb3, 5, implicit killed $eflags\r
158   \r
159   bb.1.bb2:\r
160     successors: %bb.2(0x40000000), %bb.13.bb59(0x40000000)\r
161   \r
162     $ebp = XOR32rr undef $ebp, undef $ebp, implicit-def dead $eflags\r
163     TEST8rr $bpl, $bpl, implicit-def $eflags\r
164     JCC_1 %bb.13.bb59, 4, implicit killed $eflags\r
165   \r
166   bb.2:\r
167     successors: %bb.12.bb51(0x80000000)\r
168     liveins: $ebp\r
169   \r
170     $xmm0 = XORPSrr undef $xmm0, undef $xmm0\r
171     $ebx = IMPLICIT_DEF implicit-def $rbx\r
172     JMP_1 %bb.12.bb51\r
173   \r
174   bb.3.bb3:\r
175     successors: %bb.4.bb7(0x80000000)\r
176     liveins: $rax\r
177   \r
178     MOV64mr $rsp, 1, $noreg, 32, $noreg, $rax :: (store (s64) into %stack.5)\r
179     $r12 = MOV64rr killed $rax\r
180     $r12 = ADD64ri8 killed $r12, 16, implicit-def dead $eflags\r
181     $xmm0 = XORPSrr undef $xmm0, undef $xmm0\r
182     $esi = XOR32rr undef $esi, undef $esi, implicit-def dead $eflags\r
183     $rax = MOV64ri %const.0\r
184     $xmm1 = MOVSDrm_alt killed $rax, 1, $noreg, 0, $noreg :: (load (s64) from constant-pool)\r
185     MOVSDmr $rsp, 1, $noreg, 40, $noreg, killed $xmm1 :: (store (s64) into %stack.4)\r
186     $eax = IMPLICIT_DEF\r
187     $ecx = XOR32rr undef $ecx, undef $ecx, implicit-def dead $eflags\r
188   \r
189   bb.4.bb7:\r
190     successors: %bb.6.bb26(0x40000000), %bb.5.bb15(0x40000000)\r
191     liveins: $eax, $ecx, $esi, $r12, $xmm0\r
192   \r
193     $ebp = MOV32rr killed $ecx\r
194     $ebx = MOV32rr killed $eax, implicit-def $rbx\r
195     $r14d = MOV32rr $ebx, implicit-def $r14\r
196     TEST8rr $sil, $sil, implicit-def $eflags\r
197     JCC_1 %bb.6.bb26, 5, implicit $eflags\r
198   \r
199   bb.5.bb15:\r
200     successors: %bb.6.bb26(0x80000000)\r
201     liveins: $ebp, $rbx, $r14, $xmm0\r
202   \r
203     MOV32mr $rsp, 1, $noreg, 24, $noreg, $ebx :: (store (s32) into %stack.0, align 8)\r
204     MOV32mr $rsp, 1, $noreg, 16, $noreg, $ebp :: (store (s32) into %stack.1, align 8)\r
205     MOVSDmr $rsp, 1, $noreg, 8, $noreg, killed $xmm0 :: (store (s64) into %stack.2)\r
206     $rax = MOV64rm $rsp, 1, $noreg, 32, $noreg :: (load (s64) from %stack.5)\r
207     MOV64mr $rsp, 1, $noreg, 48, $noreg, killed $rax :: (store (s64) into %stack.3)\r
208     $rax = MOV64ri @wibble\r
209     STATEPOINT 2882400000, 0, 0, killed $rax, 2, 0, 2, 0, 2, 30, 2, 1, 2, 0, 2, 99, 2, 0, 2, 12, 2, 0, 2, 10, 1, 8, $rsp, 24, 2, 10, 2, 0, 2, 10, 1, 8, $rsp, 16, 2, 10, 2, 4278124286, 2, 6, 2, 4278124286, 2, 7, 1, 8, $rsp, 8, 2, 99, 2, 0, 2, 7, 2, 4278124286, 2, 99, 2, 0, 2, 13, 1, 8, $rsp, 48, 2, 7, 2, 4278124286, 2, 99, 2, 0, 2, 0, 2, 0, 2, 0, csr_64, implicit-def $rsp :: (volatile load (s64) from %stack.0), (volatile load (s64) from %stack.1), (volatile load (s64) from %stack.2), (volatile load (s64) from %stack.3)\r
210     $esi = XOR32rr undef $esi, undef $esi, implicit-def dead $eflags\r
211     $r12 = IMPLICIT_DEF\r
212   \r
213   bb.6.bb26:\r
214     successors: %bb.8.bb37(0x40000000), %bb.7.bb35(0x40000000)\r
215     liveins: $ebp, $esi, $rbx, $r12, $r14\r
216   \r
217     $rax = MOV64ri @global.1\r
218     $rax = MOV64rm killed $rax, 1, $noreg, 0, $noreg :: (dereferenceable load (s64) from @global.1)\r
219     TEST64rr $rax, $rax, implicit-def $eflags\r
220     $rax = CMOV64rr undef $rax, killed $rax, 4, implicit killed $eflags\r
221     $ecx = MOV32rm undef $rax, 1, $noreg, 0, $noreg :: (load (s32) from `i32* undef`)\r
222     $rdx = MOV64rm $r12, 8, $r14, 0, $noreg :: (load (s64) from %ir.tmp3)\r
223     $r15 = LEA64r $rdx, 1, $noreg, 1, _\r
224     MOV64mr $r12, 8, $r14, 0, $noreg, $r15 :: (store (s64) into %ir.tmp3)\r
225     $ecx = SUB32rr killed $ecx, $edx, implicit-def dead $eflags, implicit killed $rdx\r
226     MOV32mr undef $rax, 1, $noreg, 0, $noreg, killed $ecx :: (store (s32) into `i32* undef`)\r
227     $r13 = MOV64rm killed $rax, 1, $noreg, 768, $noreg :: (load (s64) from %ir.tmp33)\r
228     TEST8rr $sil, $sil, implicit-def $eflags\r
229     $rax = IMPLICIT_DEF\r
230     JCC_1 %bb.8.bb37, 5, implicit $eflags\r
231   \r
232   bb.7.bb35:\r
233     successors: %bb.8.bb37(0x80000000)\r
234     liveins: $ebp, $rbx, $r12, $r13, $r14, $r15\r
235   \r
236     $rsi = MOV64ri @global\r
237     $rax = MOV64ri @ham\r
238     CALL64r killed $rax, csr_64, implicit $rsp, implicit undef $rdi, implicit $rsi, implicit-def $rsp, implicit-def $rax\r
239     $esi = XOR32rr undef $esi, undef $esi, implicit-def dead $eflags\r
240   \r
241   bb.8.bb37:\r
242     successors: %bb.9.bb37(0x40000000), %bb.10.bb37(0x40000000)\r
243     liveins: $ebp, $esi, $rax, $rbx, $r12, $r13, $r14, $r15\r
244   \r
245     $rcx = MOV64rm killed $rax, 1, $noreg, 760, $noreg :: (load (s64) from %ir.tmp40)\r
246     CMP64rr $r13, $rcx, implicit-def $eflags\r
247     JCC_1 %bb.10.bb37, 12, implicit $eflags\r
248   \r
249   bb.9.bb37:\r
250     successors: %bb.10.bb37(0x80000000)\r
251     liveins: $ebp, $esi, $rbx, $r12, $r13, $r14, $r15\r
252   \r
253     $cl = MOV8rr $r13b, implicit killed $r13, implicit-def $rcx\r
254   \r
255   bb.10.bb37:\r
256     successors: %bb.11.bb51.loopexit(0x00000800), %bb.4.bb7(0x7ffff800)\r
257     liveins: $ebp, $esi, $rbx, $rcx, $r12, $r14, $r15\r
258   \r
259     $cl = KILL $cl, implicit killed $rcx\r
260     $r15 = SAR64rCL killed $r15, implicit-def dead $eflags, implicit $cl\r
261     MOV64mr $r12, 8, killed $r14, 0, $noreg, killed $r15 :: (store (s64) into %ir.tmp7)\r
262     MOV64mi32 undef $rax, 1, $noreg, 0, $noreg, 0 :: (store (s64) into `i64* undef`)\r
263     $eax = LEA64_32r $rbx, 1, $noreg, 1, _\r
264     $ecx = MOV32ri 6\r
265     CMP32ri $eax, 15141, implicit-def $eflags\r
266     $xmm0 = MOVSDrm_alt $rsp, 1, $noreg, 40, $noreg :: (load (s64) from %stack.4)\r
267     JCC_1 %bb.4.bb7, 12, implicit $eflags\r
268   \r
269   bb.11.bb51.loopexit:\r
270     successors: %bb.12.bb51(0x80000000)\r
271     liveins: $ebp, $rbx\r
272   \r
273     $ebp = INC32r killed $ebp, implicit-def dead $eflags\r
274     $ebx = INC32r $ebx, implicit-def dead $eflags, implicit killed $rbx, implicit-def $rbx\r
275     $rax = MOV64ri %const.0\r
276     $xmm0 = MOVSDrm_alt killed $rax, 1, $noreg, 0, $noreg :: (load (s64) from constant-pool)\r
277   \r
278   bb.12.bb51:\r
279     liveins: $ebp, $rbx, $xmm0\r
280   \r
281     MOV32mr $rsp, 1, $noreg, 24, $noreg, $ebx, implicit killed $rbx :: (store (s32) into %stack.0, align 8)\r
282     MOV32mr $rsp, 1, $noreg, 16, $noreg, killed $ebp :: (store (s32) into %stack.1, align 8)\r
283     MOVSDmr $rsp, 1, $noreg, 8, $noreg, killed $xmm0 :: (store (s64) into %stack.2)\r
284     $rax = MOV64ri @wobble\r
285     $edi = MOV32ri -121\r
286     STATEPOINT 2882400000, 0, 1, killed $rax, $edi, 2, 0, 2, 0, 2, 38, 2, 1, 2, 0, 2, 270, 2, 4, 2, 12, 2, 0, 2, 11, 2, 4278124286, 2, 99, 2, 0, 2, 10, 1, 8, $rsp, 24, 2, 6, 2, 4278124286, 2, 99, 2, 0, 2, 99, 2, 0, 2, 10, 1, 8, $rsp, 16, 2, 10, 2, 4278124286, 2, 99, 2, 0, 2, 7, 1, 8, $rsp, 8, 2, 99, 2, 0, 2, 7, 2, 4278124286, 2, 99, 2, 0, 2, 13, 2, 4278124286, 2, 99, 2, 0, 2, 99, 2, 0, 2, 0, 2, 0, 2, 0, csr_64, implicit-def $rsp :: (volatile load (s64) from %stack.0), (volatile load (s64) from %stack.1), (volatile load (s64) from %stack.2)\r
287   \r
288   bb.13.bb59:\r
289     $rax = MOV64ri @wobble\r
290     $edi = MOV32ri 8\r
291     STATEPOINT 2882400000, 0, 1, killed $rax, $edi, 2, 0, 2, 0, 2, 38, 2, 1, 2, 0, 2, 123, 2, 4, 2, 12, 2, 0, 2, 13, 2, 0, 2, 99, 2, 4278124286, 2, 13, 2, 0, 2, 10, 2, 4278124286, 2, 99, 2, 4278124286, 2, 99, 2, 4278124286, 2, 99, 2, 4278124286, 2, 99, 2, 0, 2, 99, 2, 4278124286, 2, 99, 2, 4278124286, 2, 99, 2, 0, 2, 99, 2, 4278124286, 2, 99, 2, 0, 2, 13, 2, 0, 2, 99, 2, 4278124286, 2, 99, 2, 0, 2, 0, 2, 0, 2, 0, csr_64, implicit-def $rsp\r
293 ...\r