1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -disable-peephole -mtriple=i686-unknown -mattr=+mmx,+sse2 | FileCheck %s --check-prefix=X86
3 ; RUN: llc < %s -disable-peephole -mtriple=x86_64-unknown -mattr=+mmx,+sse2 | FileCheck %s --check-prefix=X64
5 define i64 @t0(<1 x i64>* %a, i32* %b) nounwind {
7 ; X86: # %bb.0: # %entry
9 ; X86-NEXT: movl %esp, %ebp
10 ; X86-NEXT: andl $-8, %esp
11 ; X86-NEXT: subl $8, %esp
12 ; X86-NEXT: movl 12(%ebp), %eax
13 ; X86-NEXT: movl 8(%ebp), %ecx
14 ; X86-NEXT: movq (%ecx), %mm0
15 ; X86-NEXT: movd (%eax), %mm1
16 ; X86-NEXT: psllq %mm1, %mm0
17 ; X86-NEXT: movq %mm0, (%esp)
18 ; X86-NEXT: movl (%esp), %eax
19 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
20 ; X86-NEXT: movl %ebp, %esp
25 ; X64: # %bb.0: # %entry
26 ; X64-NEXT: movq (%rdi), %mm0
27 ; X64-NEXT: movd (%rsi), %mm1
28 ; X64-NEXT: psllq %mm1, %mm0
29 ; X64-NEXT: movq %mm0, %rax
32 %0 = bitcast <1 x i64>* %a to x86_mmx*
33 %1 = load x86_mmx, x86_mmx* %0, align 8
34 %2 = load i32, i32* %b, align 4
35 %3 = tail call x86_mmx @llvm.x86.mmx.pslli.q(x86_mmx %1, i32 %2)
36 %4 = bitcast x86_mmx %3 to i64
39 declare x86_mmx @llvm.x86.mmx.pslli.q(x86_mmx, i32)
41 define i64 @t1(<1 x i64>* %a, i32* %b) nounwind {
43 ; X86: # %bb.0: # %entry
44 ; X86-NEXT: pushl %ebp
45 ; X86-NEXT: movl %esp, %ebp
46 ; X86-NEXT: andl $-8, %esp
47 ; X86-NEXT: subl $8, %esp
48 ; X86-NEXT: movl 12(%ebp), %eax
49 ; X86-NEXT: movl 8(%ebp), %ecx
50 ; X86-NEXT: movq (%ecx), %mm0
51 ; X86-NEXT: movd (%eax), %mm1
52 ; X86-NEXT: psrlq %mm1, %mm0
53 ; X86-NEXT: movq %mm0, (%esp)
54 ; X86-NEXT: movl (%esp), %eax
55 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
56 ; X86-NEXT: movl %ebp, %esp
61 ; X64: # %bb.0: # %entry
62 ; X64-NEXT: movq (%rdi), %mm0
63 ; X64-NEXT: movd (%rsi), %mm1
64 ; X64-NEXT: psrlq %mm1, %mm0
65 ; X64-NEXT: movq %mm0, %rax
68 %0 = bitcast <1 x i64>* %a to x86_mmx*
69 %1 = load x86_mmx, x86_mmx* %0, align 8
70 %2 = load i32, i32* %b, align 4
71 %3 = tail call x86_mmx @llvm.x86.mmx.psrli.q(x86_mmx %1, i32 %2)
72 %4 = bitcast x86_mmx %3 to i64
75 declare x86_mmx @llvm.x86.mmx.psrli.q(x86_mmx, i32)
77 define i64 @t2(<1 x i64>* %a, i32* %b) nounwind {
79 ; X86: # %bb.0: # %entry
80 ; X86-NEXT: pushl %ebp
81 ; X86-NEXT: movl %esp, %ebp
82 ; X86-NEXT: andl $-8, %esp
83 ; X86-NEXT: subl $8, %esp
84 ; X86-NEXT: movl 12(%ebp), %eax
85 ; X86-NEXT: movl 8(%ebp), %ecx
86 ; X86-NEXT: movq (%ecx), %mm0
87 ; X86-NEXT: movd (%eax), %mm1
88 ; X86-NEXT: psllw %mm1, %mm0
89 ; X86-NEXT: movq %mm0, (%esp)
90 ; X86-NEXT: movl (%esp), %eax
91 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
92 ; X86-NEXT: movl %ebp, %esp
97 ; X64: # %bb.0: # %entry
98 ; X64-NEXT: movq (%rdi), %mm0
99 ; X64-NEXT: movd (%rsi), %mm1
100 ; X64-NEXT: psllw %mm1, %mm0
101 ; X64-NEXT: movq %mm0, %rax
104 %0 = bitcast <1 x i64>* %a to x86_mmx*
105 %1 = load x86_mmx, x86_mmx* %0, align 8
106 %2 = load i32, i32* %b, align 4
107 %3 = tail call x86_mmx @llvm.x86.mmx.pslli.w(x86_mmx %1, i32 %2)
108 %4 = bitcast x86_mmx %3 to i64
111 declare x86_mmx @llvm.x86.mmx.pslli.w(x86_mmx, i32)
113 define i64 @t3(<1 x i64>* %a, i32* %b) nounwind {
115 ; X86: # %bb.0: # %entry
116 ; X86-NEXT: pushl %ebp
117 ; X86-NEXT: movl %esp, %ebp
118 ; X86-NEXT: andl $-8, %esp
119 ; X86-NEXT: subl $8, %esp
120 ; X86-NEXT: movl 12(%ebp), %eax
121 ; X86-NEXT: movl 8(%ebp), %ecx
122 ; X86-NEXT: movq (%ecx), %mm0
123 ; X86-NEXT: movd (%eax), %mm1
124 ; X86-NEXT: psrlw %mm1, %mm0
125 ; X86-NEXT: movq %mm0, (%esp)
126 ; X86-NEXT: movl (%esp), %eax
127 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
128 ; X86-NEXT: movl %ebp, %esp
129 ; X86-NEXT: popl %ebp
133 ; X64: # %bb.0: # %entry
134 ; X64-NEXT: movq (%rdi), %mm0
135 ; X64-NEXT: movd (%rsi), %mm1
136 ; X64-NEXT: psrlw %mm1, %mm0
137 ; X64-NEXT: movq %mm0, %rax
140 %0 = bitcast <1 x i64>* %a to x86_mmx*
141 %1 = load x86_mmx, x86_mmx* %0, align 8
142 %2 = load i32, i32* %b, align 4
143 %3 = tail call x86_mmx @llvm.x86.mmx.psrli.w(x86_mmx %1, i32 %2)
144 %4 = bitcast x86_mmx %3 to i64
147 declare x86_mmx @llvm.x86.mmx.psrli.w(x86_mmx, i32)
149 define i64 @t4(<1 x i64>* %a, i32* %b) nounwind {
151 ; X86: # %bb.0: # %entry
152 ; X86-NEXT: pushl %ebp
153 ; X86-NEXT: movl %esp, %ebp
154 ; X86-NEXT: andl $-8, %esp
155 ; X86-NEXT: subl $8, %esp
156 ; X86-NEXT: movl 12(%ebp), %eax
157 ; X86-NEXT: movl 8(%ebp), %ecx
158 ; X86-NEXT: movq (%ecx), %mm0
159 ; X86-NEXT: movd (%eax), %mm1
160 ; X86-NEXT: pslld %mm1, %mm0
161 ; X86-NEXT: movq %mm0, (%esp)
162 ; X86-NEXT: movl (%esp), %eax
163 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
164 ; X86-NEXT: movl %ebp, %esp
165 ; X86-NEXT: popl %ebp
169 ; X64: # %bb.0: # %entry
170 ; X64-NEXT: movq (%rdi), %mm0
171 ; X64-NEXT: movd (%rsi), %mm1
172 ; X64-NEXT: pslld %mm1, %mm0
173 ; X64-NEXT: movq %mm0, %rax
176 %0 = bitcast <1 x i64>* %a to x86_mmx*
177 %1 = load x86_mmx, x86_mmx* %0, align 8
178 %2 = load i32, i32* %b, align 4
179 %3 = tail call x86_mmx @llvm.x86.mmx.pslli.d(x86_mmx %1, i32 %2)
180 %4 = bitcast x86_mmx %3 to i64
183 declare x86_mmx @llvm.x86.mmx.pslli.d(x86_mmx, i32)
185 define i64 @t5(<1 x i64>* %a, i32* %b) nounwind {
187 ; X86: # %bb.0: # %entry
188 ; X86-NEXT: pushl %ebp
189 ; X86-NEXT: movl %esp, %ebp
190 ; X86-NEXT: andl $-8, %esp
191 ; X86-NEXT: subl $8, %esp
192 ; X86-NEXT: movl 12(%ebp), %eax
193 ; X86-NEXT: movl 8(%ebp), %ecx
194 ; X86-NEXT: movq (%ecx), %mm0
195 ; X86-NEXT: movd (%eax), %mm1
196 ; X86-NEXT: psrld %mm1, %mm0
197 ; X86-NEXT: movq %mm0, (%esp)
198 ; X86-NEXT: movl (%esp), %eax
199 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
200 ; X86-NEXT: movl %ebp, %esp
201 ; X86-NEXT: popl %ebp
205 ; X64: # %bb.0: # %entry
206 ; X64-NEXT: movq (%rdi), %mm0
207 ; X64-NEXT: movd (%rsi), %mm1
208 ; X64-NEXT: psrld %mm1, %mm0
209 ; X64-NEXT: movq %mm0, %rax
212 %0 = bitcast <1 x i64>* %a to x86_mmx*
213 %1 = load x86_mmx, x86_mmx* %0, align 8
214 %2 = load i32, i32* %b, align 4
215 %3 = tail call x86_mmx @llvm.x86.mmx.psrli.d(x86_mmx %1, i32 %2)
216 %4 = bitcast x86_mmx %3 to i64
219 declare x86_mmx @llvm.x86.mmx.psrli.d(x86_mmx, i32)
221 define i64 @t6(<1 x i64>* %a, i32* %b) nounwind {
223 ; X86: # %bb.0: # %entry
224 ; X86-NEXT: pushl %ebp
225 ; X86-NEXT: movl %esp, %ebp
226 ; X86-NEXT: andl $-8, %esp
227 ; X86-NEXT: subl $8, %esp
228 ; X86-NEXT: movl 12(%ebp), %eax
229 ; X86-NEXT: movl 8(%ebp), %ecx
230 ; X86-NEXT: movq (%ecx), %mm0
231 ; X86-NEXT: movd (%eax), %mm1
232 ; X86-NEXT: psraw %mm1, %mm0
233 ; X86-NEXT: movq %mm0, (%esp)
234 ; X86-NEXT: movl (%esp), %eax
235 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
236 ; X86-NEXT: movl %ebp, %esp
237 ; X86-NEXT: popl %ebp
241 ; X64: # %bb.0: # %entry
242 ; X64-NEXT: movq (%rdi), %mm0
243 ; X64-NEXT: movd (%rsi), %mm1
244 ; X64-NEXT: psraw %mm1, %mm0
245 ; X64-NEXT: movq %mm0, %rax
248 %0 = bitcast <1 x i64>* %a to x86_mmx*
249 %1 = load x86_mmx, x86_mmx* %0, align 8
250 %2 = load i32, i32* %b, align 4
251 %3 = tail call x86_mmx @llvm.x86.mmx.psrai.w(x86_mmx %1, i32 %2)
252 %4 = bitcast x86_mmx %3 to i64
255 declare x86_mmx @llvm.x86.mmx.psrai.w(x86_mmx, i32)
257 define i64 @t7(<1 x i64>* %a, i32* %b) nounwind {
259 ; X86: # %bb.0: # %entry
260 ; X86-NEXT: pushl %ebp
261 ; X86-NEXT: movl %esp, %ebp
262 ; X86-NEXT: andl $-8, %esp
263 ; X86-NEXT: subl $8, %esp
264 ; X86-NEXT: movl 12(%ebp), %eax
265 ; X86-NEXT: movl 8(%ebp), %ecx
266 ; X86-NEXT: movq (%ecx), %mm0
267 ; X86-NEXT: movd (%eax), %mm1
268 ; X86-NEXT: psrad %mm1, %mm0
269 ; X86-NEXT: movq %mm0, (%esp)
270 ; X86-NEXT: movl (%esp), %eax
271 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
272 ; X86-NEXT: movl %ebp, %esp
273 ; X86-NEXT: popl %ebp
277 ; X64: # %bb.0: # %entry
278 ; X64-NEXT: movq (%rdi), %mm0
279 ; X64-NEXT: movd (%rsi), %mm1
280 ; X64-NEXT: psrad %mm1, %mm0
281 ; X64-NEXT: movq %mm0, %rax
284 %0 = bitcast <1 x i64>* %a to x86_mmx*
285 %1 = load x86_mmx, x86_mmx* %0, align 8
286 %2 = load i32, i32* %b, align 4
287 %3 = tail call x86_mmx @llvm.x86.mmx.psrai.d(x86_mmx %1, i32 %2)
288 %4 = bitcast x86_mmx %3 to i64
291 declare x86_mmx @llvm.x86.mmx.psrai.d(x86_mmx, i32)
293 define i64 @tt0(x86_mmx %t, x86_mmx* %q) nounwind {
295 ; X86: # %bb.0: # %entry
296 ; X86-NEXT: pushl %ebp
297 ; X86-NEXT: movl %esp, %ebp
298 ; X86-NEXT: andl $-8, %esp
299 ; X86-NEXT: subl $8, %esp
300 ; X86-NEXT: movl 8(%ebp), %eax
301 ; X86-NEXT: paddb (%eax), %mm0
302 ; X86-NEXT: movq %mm0, (%esp)
303 ; X86-NEXT: movl (%esp), %eax
304 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
306 ; X86-NEXT: movl %ebp, %esp
307 ; X86-NEXT: popl %ebp
311 ; X64: # %bb.0: # %entry
312 ; X64-NEXT: paddb (%rdi), %mm0
313 ; X64-NEXT: movq %mm0, %rax
317 %v = load x86_mmx, x86_mmx* %q
318 %u = tail call x86_mmx @llvm.x86.mmx.padd.b(x86_mmx %t, x86_mmx %v)
319 %s = bitcast x86_mmx %u to i64
320 call void @llvm.x86.mmx.emms()
323 declare x86_mmx @llvm.x86.mmx.padd.b(x86_mmx, x86_mmx)
324 declare void @llvm.x86.mmx.emms()
326 define i64 @tt1(x86_mmx %t, x86_mmx* %q) nounwind {
328 ; X86: # %bb.0: # %entry
329 ; X86-NEXT: pushl %ebp
330 ; X86-NEXT: movl %esp, %ebp
331 ; X86-NEXT: andl $-8, %esp
332 ; X86-NEXT: subl $8, %esp
333 ; X86-NEXT: movl 8(%ebp), %eax
334 ; X86-NEXT: paddw (%eax), %mm0
335 ; X86-NEXT: movq %mm0, (%esp)
336 ; X86-NEXT: movl (%esp), %eax
337 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
339 ; X86-NEXT: movl %ebp, %esp
340 ; X86-NEXT: popl %ebp
344 ; X64: # %bb.0: # %entry
345 ; X64-NEXT: paddw (%rdi), %mm0
346 ; X64-NEXT: movq %mm0, %rax
350 %v = load x86_mmx, x86_mmx* %q
351 %u = tail call x86_mmx @llvm.x86.mmx.padd.w(x86_mmx %t, x86_mmx %v)
352 %s = bitcast x86_mmx %u to i64
353 call void @llvm.x86.mmx.emms()
356 declare x86_mmx @llvm.x86.mmx.padd.w(x86_mmx, x86_mmx)
358 define i64 @tt2(x86_mmx %t, x86_mmx* %q) nounwind {
360 ; X86: # %bb.0: # %entry
361 ; X86-NEXT: pushl %ebp
362 ; X86-NEXT: movl %esp, %ebp
363 ; X86-NEXT: andl $-8, %esp
364 ; X86-NEXT: subl $8, %esp
365 ; X86-NEXT: movl 8(%ebp), %eax
366 ; X86-NEXT: paddd (%eax), %mm0
367 ; X86-NEXT: movq %mm0, (%esp)
368 ; X86-NEXT: movl (%esp), %eax
369 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
371 ; X86-NEXT: movl %ebp, %esp
372 ; X86-NEXT: popl %ebp
376 ; X64: # %bb.0: # %entry
377 ; X64-NEXT: paddd (%rdi), %mm0
378 ; X64-NEXT: movq %mm0, %rax
382 %v = load x86_mmx, x86_mmx* %q
383 %u = tail call x86_mmx @llvm.x86.mmx.padd.d(x86_mmx %t, x86_mmx %v)
384 %s = bitcast x86_mmx %u to i64
385 call void @llvm.x86.mmx.emms()
388 declare x86_mmx @llvm.x86.mmx.padd.d(x86_mmx, x86_mmx)
390 define i64 @tt3(x86_mmx %t, x86_mmx* %q) nounwind {
392 ; X86: # %bb.0: # %entry
393 ; X86-NEXT: pushl %ebp
394 ; X86-NEXT: movl %esp, %ebp
395 ; X86-NEXT: andl $-8, %esp
396 ; X86-NEXT: subl $8, %esp
397 ; X86-NEXT: movl 8(%ebp), %eax
398 ; X86-NEXT: paddq (%eax), %mm0
399 ; X86-NEXT: movq %mm0, (%esp)
400 ; X86-NEXT: movl (%esp), %eax
401 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
403 ; X86-NEXT: movl %ebp, %esp
404 ; X86-NEXT: popl %ebp
408 ; X64: # %bb.0: # %entry
409 ; X64-NEXT: paddq (%rdi), %mm0
410 ; X64-NEXT: movq %mm0, %rax
414 %v = load x86_mmx, x86_mmx* %q
415 %u = tail call x86_mmx @llvm.x86.mmx.padd.q(x86_mmx %t, x86_mmx %v)
416 %s = bitcast x86_mmx %u to i64
417 call void @llvm.x86.mmx.emms()
420 declare x86_mmx @llvm.x86.mmx.padd.q(x86_mmx, x86_mmx)
422 define i64 @tt4(x86_mmx %t, x86_mmx* %q) nounwind {
424 ; X86: # %bb.0: # %entry
425 ; X86-NEXT: pushl %ebp
426 ; X86-NEXT: movl %esp, %ebp
427 ; X86-NEXT: andl $-8, %esp
428 ; X86-NEXT: subl $8, %esp
429 ; X86-NEXT: movl 8(%ebp), %eax
430 ; X86-NEXT: paddusb (%eax), %mm0
431 ; X86-NEXT: movq %mm0, (%esp)
432 ; X86-NEXT: movl (%esp), %eax
433 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
435 ; X86-NEXT: movl %ebp, %esp
436 ; X86-NEXT: popl %ebp
440 ; X64: # %bb.0: # %entry
441 ; X64-NEXT: paddusb (%rdi), %mm0
442 ; X64-NEXT: movq %mm0, %rax
446 %v = load x86_mmx, x86_mmx* %q
447 %u = tail call x86_mmx @llvm.x86.mmx.paddus.b(x86_mmx %t, x86_mmx %v)
448 %s = bitcast x86_mmx %u to i64
449 call void @llvm.x86.mmx.emms()
452 declare x86_mmx @llvm.x86.mmx.paddus.b(x86_mmx, x86_mmx)
454 define i64 @tt5(x86_mmx %t, x86_mmx* %q) nounwind {
456 ; X86: # %bb.0: # %entry
457 ; X86-NEXT: pushl %ebp
458 ; X86-NEXT: movl %esp, %ebp
459 ; X86-NEXT: andl $-8, %esp
460 ; X86-NEXT: subl $8, %esp
461 ; X86-NEXT: movl 8(%ebp), %eax
462 ; X86-NEXT: paddusw (%eax), %mm0
463 ; X86-NEXT: movq %mm0, (%esp)
464 ; X86-NEXT: movl (%esp), %eax
465 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
467 ; X86-NEXT: movl %ebp, %esp
468 ; X86-NEXT: popl %ebp
472 ; X64: # %bb.0: # %entry
473 ; X64-NEXT: paddusw (%rdi), %mm0
474 ; X64-NEXT: movq %mm0, %rax
478 %v = load x86_mmx, x86_mmx* %q
479 %u = tail call x86_mmx @llvm.x86.mmx.paddus.w(x86_mmx %t, x86_mmx %v)
480 %s = bitcast x86_mmx %u to i64
481 call void @llvm.x86.mmx.emms()
484 declare x86_mmx @llvm.x86.mmx.paddus.w(x86_mmx, x86_mmx)
486 define i64 @tt6(x86_mmx %t, x86_mmx* %q) nounwind {
488 ; X86: # %bb.0: # %entry
489 ; X86-NEXT: pushl %ebp
490 ; X86-NEXT: movl %esp, %ebp
491 ; X86-NEXT: andl $-8, %esp
492 ; X86-NEXT: subl $8, %esp
493 ; X86-NEXT: movl 8(%ebp), %eax
494 ; X86-NEXT: psrlw (%eax), %mm0
495 ; X86-NEXT: movq %mm0, (%esp)
496 ; X86-NEXT: movl (%esp), %eax
497 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
499 ; X86-NEXT: movl %ebp, %esp
500 ; X86-NEXT: popl %ebp
504 ; X64: # %bb.0: # %entry
505 ; X64-NEXT: psrlw (%rdi), %mm0
506 ; X64-NEXT: movq %mm0, %rax
510 %v = load x86_mmx, x86_mmx* %q
511 %u = tail call x86_mmx @llvm.x86.mmx.psrl.w(x86_mmx %t, x86_mmx %v)
512 %s = bitcast x86_mmx %u to i64
513 call void @llvm.x86.mmx.emms()
516 declare x86_mmx @llvm.x86.mmx.psrl.w(x86_mmx, x86_mmx)
518 define i64 @tt7(x86_mmx %t, x86_mmx* %q) nounwind {
520 ; X86: # %bb.0: # %entry
521 ; X86-NEXT: pushl %ebp
522 ; X86-NEXT: movl %esp, %ebp
523 ; X86-NEXT: andl $-8, %esp
524 ; X86-NEXT: subl $8, %esp
525 ; X86-NEXT: movl 8(%ebp), %eax
526 ; X86-NEXT: psrld (%eax), %mm0
527 ; X86-NEXT: movq %mm0, (%esp)
528 ; X86-NEXT: movl (%esp), %eax
529 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
531 ; X86-NEXT: movl %ebp, %esp
532 ; X86-NEXT: popl %ebp
536 ; X64: # %bb.0: # %entry
537 ; X64-NEXT: psrld (%rdi), %mm0
538 ; X64-NEXT: movq %mm0, %rax
542 %v = load x86_mmx, x86_mmx* %q
543 %u = tail call x86_mmx @llvm.x86.mmx.psrl.d(x86_mmx %t, x86_mmx %v)
544 %s = bitcast x86_mmx %u to i64
545 call void @llvm.x86.mmx.emms()
548 declare x86_mmx @llvm.x86.mmx.psrl.d(x86_mmx, x86_mmx)
550 define i64 @tt8(x86_mmx %t, x86_mmx* %q) nounwind {
552 ; X86: # %bb.0: # %entry
553 ; X86-NEXT: pushl %ebp
554 ; X86-NEXT: movl %esp, %ebp
555 ; X86-NEXT: andl $-8, %esp
556 ; X86-NEXT: subl $8, %esp
557 ; X86-NEXT: movl 8(%ebp), %eax
558 ; X86-NEXT: psrlq (%eax), %mm0
559 ; X86-NEXT: movq %mm0, (%esp)
560 ; X86-NEXT: movl (%esp), %eax
561 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
563 ; X86-NEXT: movl %ebp, %esp
564 ; X86-NEXT: popl %ebp
568 ; X64: # %bb.0: # %entry
569 ; X64-NEXT: psrlq (%rdi), %mm0
570 ; X64-NEXT: movq %mm0, %rax
574 %v = load x86_mmx, x86_mmx* %q
575 %u = tail call x86_mmx @llvm.x86.mmx.psrl.q(x86_mmx %t, x86_mmx %v)
576 %s = bitcast x86_mmx %u to i64
577 call void @llvm.x86.mmx.emms()
580 declare x86_mmx @llvm.x86.mmx.psrl.q(x86_mmx, x86_mmx)
582 define void @test_psrlq_by_volatile_shift_amount(x86_mmx* %t) nounwind {
583 ; X86-LABEL: test_psrlq_by_volatile_shift_amount:
584 ; X86: # %bb.0: # %entry
585 ; X86-NEXT: pushl %eax
586 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
587 ; X86-NEXT: movl $1, (%esp)
588 ; X86-NEXT: movl $255, %ecx
589 ; X86-NEXT: movd %ecx, %mm0
590 ; X86-NEXT: movd (%esp), %mm1
591 ; X86-NEXT: psrlq %mm1, %mm0
592 ; X86-NEXT: movq %mm0, (%eax)
593 ; X86-NEXT: popl %eax
596 ; X64-LABEL: test_psrlq_by_volatile_shift_amount:
597 ; X64: # %bb.0: # %entry
598 ; X64-NEXT: movl $1, -{{[0-9]+}}(%rsp)
599 ; X64-NEXT: movl $255, %eax
600 ; X64-NEXT: movd %eax, %mm0
601 ; X64-NEXT: movd -{{[0-9]+}}(%rsp), %mm1
602 ; X64-NEXT: psrlq %mm1, %mm0
603 ; X64-NEXT: movq %mm0, (%rdi)
606 %0 = alloca i32, align 4
607 %1 = bitcast i32* %0 to i8*
608 call void @llvm.lifetime.start(i64 4, i8* nonnull %1)
609 store volatile i32 1, i32* %0, align 4
610 %2 = load volatile i32, i32* %0, align 4
611 %3 = tail call x86_mmx @llvm.x86.mmx.psrli.q(x86_mmx bitcast (<1 x i64> <i64 255> to x86_mmx), i32 %2)
612 store x86_mmx %3, x86_mmx* %t, align 8
613 call void @llvm.lifetime.end(i64 4, i8* nonnull %1)
617 declare void @llvm.lifetime.start(i64, i8* nocapture)
618 declare void @llvm.lifetime.end(i64, i8* nocapture)
620 ; Make sure we shrink this vector load and fold it.
621 define x86_mmx @vec_load(<4 x float>* %x) {
622 ; X86-LABEL: vec_load:
624 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
625 ; X86-NEXT: pshufw $68, (%eax), %mm0 # mm0 = mem[0,1,0,1]
626 ; X86-NEXT: paddsb %mm0, %mm0
629 ; X64-LABEL: vec_load:
631 ; X64-NEXT: pshufw $68, (%rdi), %mm0 # mm0 = mem[0,1,0,1]
632 ; X64-NEXT: paddsb %mm0, %mm0
633 ; X64-NEXT: movq2dq %mm0, %xmm0
635 %z = load <4 x float>, <4 x float>* %x
636 %y = extractelement <4 x float> %z, i32 0
637 %a = insertelement <2 x float> undef, float %y, i32 0
638 %b = insertelement <2 x float> %a, float %y, i32 1
639 %c = bitcast <2 x float> %b to x86_mmx
640 %d = tail call x86_mmx @llvm.x86.mmx.padds.b(x86_mmx %c, x86_mmx %c)
644 declare x86_mmx @llvm.x86.mmx.padds.b(x86_mmx, x86_mmx)