Lines Matching refs:SSE2
2 … -mtriple=x86_64-unknown-unknown -mattr=+sse2 | FileCheck %s --check-prefix=SSE --check-prefix=SSE2
10 ; SSE2-LABEL: test1:
11 ; SSE2: # BB#0: # %entry
12 ; SSE2-NEXT: movdqa %xmm1, %xmm2
13 ; SSE2-NEXT: pcmpgtb %xmm0, %xmm2
14 ; SSE2-NEXT: pand %xmm2, %xmm0
15 ; SSE2-NEXT: pandn %xmm1, %xmm2
16 ; SSE2-NEXT: por %xmm2, %xmm0
17 ; SSE2-NEXT: retq
35 ; SSE2-LABEL: test2:
36 ; SSE2: # BB#0: # %entry
37 ; SSE2-NEXT: movdqa %xmm0, %xmm2
38 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm2
39 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm3
40 ; SSE2-NEXT: pxor %xmm2, %xmm3
41 ; SSE2-NEXT: pandn %xmm0, %xmm2
42 ; SSE2-NEXT: pandn %xmm1, %xmm3
43 ; SSE2-NEXT: por %xmm3, %xmm2
44 ; SSE2-NEXT: movdqa %xmm2, %xmm0
45 ; SSE2-NEXT: retq
63 ; SSE2-LABEL: test3:
64 ; SSE2: # BB#0: # %entry
65 ; SSE2-NEXT: movdqa %xmm0, %xmm2
66 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm2
67 ; SSE2-NEXT: pand %xmm2, %xmm0
68 ; SSE2-NEXT: pandn %xmm1, %xmm2
69 ; SSE2-NEXT: por %xmm0, %xmm2
70 ; SSE2-NEXT: movdqa %xmm2, %xmm0
71 ; SSE2-NEXT: retq
89 ; SSE2-LABEL: test4:
90 ; SSE2: # BB#0: # %entry
91 ; SSE2-NEXT: movdqa %xmm1, %xmm3
92 ; SSE2-NEXT: pcmpgtb %xmm0, %xmm3
93 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
94 ; SSE2-NEXT: pxor %xmm3, %xmm2
95 ; SSE2-NEXT: pandn %xmm0, %xmm3
96 ; SSE2-NEXT: pandn %xmm1, %xmm2
97 ; SSE2-NEXT: por %xmm3, %xmm2
98 ; SSE2-NEXT: movdqa %xmm2, %xmm0
99 ; SSE2-NEXT: retq
245 ; SSE2-LABEL: test13:
246 ; SSE2: # BB#0: # %entry
247 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [32768,32768,32768,32768,32768,32768,32768,32768]
248 ; SSE2-NEXT: movdqa %xmm0, %xmm3
249 ; SSE2-NEXT: pxor %xmm2, %xmm3
250 ; SSE2-NEXT: pxor %xmm1, %xmm2
251 ; SSE2-NEXT: pcmpgtw %xmm3, %xmm2
252 ; SSE2-NEXT: pand %xmm2, %xmm0
253 ; SSE2-NEXT: pandn %xmm1, %xmm2
254 ; SSE2-NEXT: por %xmm2, %xmm0
255 ; SSE2-NEXT: retq
273 ; SSE2-LABEL: test14:
274 ; SSE2: # BB#0: # %entry
275 ; SSE2-NEXT: movdqa %xmm0, %xmm2
276 ; SSE2-NEXT: psubusw %xmm1, %xmm2
277 ; SSE2-NEXT: pxor %xmm3, %xmm3
278 ; SSE2-NEXT: pcmpeqw %xmm2, %xmm3
279 ; SSE2-NEXT: pand %xmm3, %xmm0
280 ; SSE2-NEXT: pandn %xmm1, %xmm3
281 ; SSE2-NEXT: por %xmm3, %xmm0
282 ; SSE2-NEXT: retq
300 ; SSE2-LABEL: test15:
301 ; SSE2: # BB#0: # %entry
302 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [32768,32768,32768,32768,32768,32768,32768,32768]
303 ; SSE2-NEXT: movdqa %xmm1, %xmm3
304 ; SSE2-NEXT: pxor %xmm2, %xmm3
305 ; SSE2-NEXT: pxor %xmm0, %xmm2
306 ; SSE2-NEXT: pcmpgtw %xmm3, %xmm2
307 ; SSE2-NEXT: pand %xmm2, %xmm0
308 ; SSE2-NEXT: pandn %xmm1, %xmm2
309 ; SSE2-NEXT: por %xmm2, %xmm0
310 ; SSE2-NEXT: retq
328 ; SSE2-LABEL: test16:
329 ; SSE2: # BB#0: # %entry
330 ; SSE2-NEXT: movdqa %xmm1, %xmm2
331 ; SSE2-NEXT: psubusw %xmm0, %xmm2
332 ; SSE2-NEXT: pxor %xmm3, %xmm3
333 ; SSE2-NEXT: pcmpeqw %xmm2, %xmm3
334 ; SSE2-NEXT: pand %xmm3, %xmm0
335 ; SSE2-NEXT: pandn %xmm1, %xmm3
336 ; SSE2-NEXT: por %xmm3, %xmm0
337 ; SSE2-NEXT: retq
355 ; SSE2-LABEL: test17:
356 ; SSE2: # BB#0: # %entry
357 ; SSE2-NEXT: movdqa %xmm1, %xmm2
358 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm2
359 ; SSE2-NEXT: pand %xmm2, %xmm0
360 ; SSE2-NEXT: pandn %xmm1, %xmm2
361 ; SSE2-NEXT: por %xmm2, %xmm0
362 ; SSE2-NEXT: retq
380 ; SSE2-LABEL: test18:
381 ; SSE2: # BB#0: # %entry
382 ; SSE2-NEXT: movdqa %xmm0, %xmm2
383 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm2
384 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm3
385 ; SSE2-NEXT: pxor %xmm2, %xmm3
386 ; SSE2-NEXT: pandn %xmm0, %xmm2
387 ; SSE2-NEXT: pandn %xmm1, %xmm3
388 ; SSE2-NEXT: por %xmm3, %xmm2
389 ; SSE2-NEXT: movdqa %xmm2, %xmm0
390 ; SSE2-NEXT: retq
408 ; SSE2-LABEL: test19:
409 ; SSE2: # BB#0: # %entry
410 ; SSE2-NEXT: movdqa %xmm0, %xmm2
411 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm2
412 ; SSE2-NEXT: pand %xmm2, %xmm0
413 ; SSE2-NEXT: pandn %xmm1, %xmm2
414 ; SSE2-NEXT: por %xmm0, %xmm2
415 ; SSE2-NEXT: movdqa %xmm2, %xmm0
416 ; SSE2-NEXT: retq
434 ; SSE2-LABEL: test20:
435 ; SSE2: # BB#0: # %entry
436 ; SSE2-NEXT: movdqa %xmm1, %xmm3
437 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm3
438 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
439 ; SSE2-NEXT: pxor %xmm3, %xmm2
440 ; SSE2-NEXT: pandn %xmm0, %xmm3
441 ; SSE2-NEXT: pandn %xmm1, %xmm2
442 ; SSE2-NEXT: por %xmm3, %xmm2
443 ; SSE2-NEXT: movdqa %xmm2, %xmm0
444 ; SSE2-NEXT: retq
462 ; SSE2-LABEL: test21:
463 ; SSE2: # BB#0: # %entry
464 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
465 ; SSE2-NEXT: movdqa %xmm0, %xmm3
466 ; SSE2-NEXT: pxor %xmm2, %xmm3
467 ; SSE2-NEXT: pxor %xmm1, %xmm2
468 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm2
469 ; SSE2-NEXT: pand %xmm2, %xmm0
470 ; SSE2-NEXT: pandn %xmm1, %xmm2
471 ; SSE2-NEXT: por %xmm2, %xmm0
472 ; SSE2-NEXT: retq
490 ; SSE2-LABEL: test22:
491 ; SSE2: # BB#0: # %entry
492 ; SSE2-NEXT: movdqa {{.*#+}} xmm3 = [2147483648,2147483648,2147483648,2147483648]
493 ; SSE2-NEXT: movdqa %xmm1, %xmm2
494 ; SSE2-NEXT: pxor %xmm3, %xmm2
495 ; SSE2-NEXT: pxor %xmm0, %xmm3
496 ; SSE2-NEXT: pcmpgtd %xmm2, %xmm3
497 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
498 ; SSE2-NEXT: pxor %xmm3, %xmm2
499 ; SSE2-NEXT: pandn %xmm0, %xmm3
500 ; SSE2-NEXT: pandn %xmm1, %xmm2
501 ; SSE2-NEXT: por %xmm3, %xmm2
502 ; SSE2-NEXT: movdqa %xmm2, %xmm0
503 ; SSE2-NEXT: retq
521 ; SSE2-LABEL: test23:
522 ; SSE2: # BB#0: # %entry
523 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
524 ; SSE2-NEXT: movdqa %xmm1, %xmm3
525 ; SSE2-NEXT: pxor %xmm2, %xmm3
526 ; SSE2-NEXT: pxor %xmm0, %xmm2
527 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm2
528 ; SSE2-NEXT: pand %xmm2, %xmm0
529 ; SSE2-NEXT: pandn %xmm1, %xmm2
530 ; SSE2-NEXT: por %xmm2, %xmm0
531 ; SSE2-NEXT: retq
549 ; SSE2-LABEL: test24:
550 ; SSE2: # BB#0: # %entry
551 ; SSE2-NEXT: movdqa {{.*#+}} xmm3 = [2147483648,2147483648,2147483648,2147483648]
552 ; SSE2-NEXT: movdqa %xmm0, %xmm2
553 ; SSE2-NEXT: pxor %xmm3, %xmm2
554 ; SSE2-NEXT: pxor %xmm1, %xmm3
555 ; SSE2-NEXT: pcmpgtd %xmm2, %xmm3
556 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
557 ; SSE2-NEXT: pxor %xmm3, %xmm2
558 ; SSE2-NEXT: pandn %xmm0, %xmm3
559 ; SSE2-NEXT: pandn %xmm1, %xmm2
560 ; SSE2-NEXT: por %xmm3, %xmm2
561 ; SSE2-NEXT: movdqa %xmm2, %xmm0
562 ; SSE2-NEXT: retq
580 ; SSE2-LABEL: test25:
581 ; SSE2: # BB#0: # %entry
582 ; SSE2-NEXT: movdqa %xmm3, %xmm4
583 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm4
584 ; SSE2-NEXT: movdqa %xmm2, %xmm5
585 ; SSE2-NEXT: pcmpgtb %xmm0, %xmm5
586 ; SSE2-NEXT: pand %xmm5, %xmm0
587 ; SSE2-NEXT: pandn %xmm2, %xmm5
588 ; SSE2-NEXT: por %xmm5, %xmm0
589 ; SSE2-NEXT: pand %xmm4, %xmm1
590 ; SSE2-NEXT: pandn %xmm3, %xmm4
591 ; SSE2-NEXT: por %xmm4, %xmm1
592 ; SSE2-NEXT: retq
625 ; SSE2-LABEL: test26:
626 ; SSE2: # BB#0: # %entry
627 ; SSE2-NEXT: movdqa %xmm1, %xmm6
628 ; SSE2-NEXT: pcmpgtb %xmm3, %xmm6
629 ; SSE2-NEXT: pcmpeqd %xmm7, %xmm7
630 ; SSE2-NEXT: movdqa %xmm6, %xmm4
631 ; SSE2-NEXT: pxor %xmm7, %xmm4
632 ; SSE2-NEXT: movdqa %xmm0, %xmm5
633 ; SSE2-NEXT: pcmpgtb %xmm2, %xmm5
634 ; SSE2-NEXT: pxor %xmm5, %xmm7
635 ; SSE2-NEXT: pandn %xmm0, %xmm5
636 ; SSE2-NEXT: pandn %xmm2, %xmm7
637 ; SSE2-NEXT: por %xmm7, %xmm5
638 ; SSE2-NEXT: pandn %xmm1, %xmm6
639 ; SSE2-NEXT: pandn %xmm3, %xmm4
640 ; SSE2-NEXT: por %xmm6, %xmm4
641 ; SSE2-NEXT: movdqa %xmm5, %xmm0
642 ; SSE2-NEXT: movdqa %xmm4, %xmm1
643 ; SSE2-NEXT: retq
676 ; SSE2-LABEL: test27:
677 ; SSE2: # BB#0: # %entry
678 ; SSE2-NEXT: movdqa %xmm1, %xmm4
679 ; SSE2-NEXT: pcmpgtb %xmm3, %xmm4
680 ; SSE2-NEXT: movdqa %xmm0, %xmm5
681 ; SSE2-NEXT: pcmpgtb %xmm2, %xmm5
682 ; SSE2-NEXT: pand %xmm5, %xmm0
683 ; SSE2-NEXT: pandn %xmm2, %xmm5
684 ; SSE2-NEXT: por %xmm0, %xmm5
685 ; SSE2-NEXT: pand %xmm4, %xmm1
686 ; SSE2-NEXT: pandn %xmm3, %xmm4
687 ; SSE2-NEXT: por %xmm1, %xmm4
688 ; SSE2-NEXT: movdqa %xmm5, %xmm0
689 ; SSE2-NEXT: movdqa %xmm4, %xmm1
690 ; SSE2-NEXT: retq
723 ; SSE2-LABEL: test28:
724 ; SSE2: # BB#0: # %entry
725 ; SSE2-NEXT: movdqa %xmm3, %xmm6
726 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm6
727 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
728 ; SSE2-NEXT: movdqa %xmm6, %xmm5
729 ; SSE2-NEXT: pxor %xmm4, %xmm5
730 ; SSE2-NEXT: movdqa %xmm2, %xmm7
731 ; SSE2-NEXT: pcmpgtb %xmm0, %xmm7
732 ; SSE2-NEXT: pxor %xmm7, %xmm4
733 ; SSE2-NEXT: pandn %xmm0, %xmm7
734 ; SSE2-NEXT: pandn %xmm2, %xmm4
735 ; SSE2-NEXT: por %xmm7, %xmm4
736 ; SSE2-NEXT: pandn %xmm1, %xmm6
737 ; SSE2-NEXT: pandn %xmm3, %xmm5
738 ; SSE2-NEXT: por %xmm6, %xmm5
739 ; SSE2-NEXT: movdqa %xmm4, %xmm0
740 ; SSE2-NEXT: movdqa %xmm5, %xmm1
741 ; SSE2-NEXT: retq
1022 ; SSE2-LABEL: test37:
1023 ; SSE2: # BB#0: # %entry
1024 ; SSE2-NEXT: movdqa {{.*#+}} xmm4 = [32768,32768,32768,32768,32768,32768,32768,32768]
1025 ; SSE2-NEXT: movdqa %xmm1, %xmm5
1026 ; SSE2-NEXT: pxor %xmm4, %xmm5
1027 ; SSE2-NEXT: movdqa %xmm3, %xmm6
1028 ; SSE2-NEXT: pxor %xmm4, %xmm6
1029 ; SSE2-NEXT: pcmpgtw %xmm5, %xmm6
1030 ; SSE2-NEXT: movdqa %xmm0, %xmm5
1031 ; SSE2-NEXT: pxor %xmm4, %xmm5
1032 ; SSE2-NEXT: pxor %xmm2, %xmm4
1033 ; SSE2-NEXT: pcmpgtw %xmm5, %xmm4
1034 ; SSE2-NEXT: pand %xmm4, %xmm0
1035 ; SSE2-NEXT: pandn %xmm2, %xmm4
1036 ; SSE2-NEXT: por %xmm4, %xmm0
1037 ; SSE2-NEXT: pand %xmm6, %xmm1
1038 ; SSE2-NEXT: pandn %xmm3, %xmm6
1039 ; SSE2-NEXT: por %xmm6, %xmm1
1040 ; SSE2-NEXT: retq
1073 ; SSE2-LABEL: test38:
1074 ; SSE2: # BB#0: # %entry
1075 ; SSE2-NEXT: movdqa %xmm1, %xmm4
1076 ; SSE2-NEXT: psubusw %xmm3, %xmm4
1077 ; SSE2-NEXT: pxor %xmm6, %xmm6
1078 ; SSE2-NEXT: pcmpeqw %xmm6, %xmm4
1079 ; SSE2-NEXT: movdqa %xmm0, %xmm5
1080 ; SSE2-NEXT: psubusw %xmm2, %xmm5
1081 ; SSE2-NEXT: pcmpeqw %xmm6, %xmm5
1082 ; SSE2-NEXT: pand %xmm5, %xmm0
1083 ; SSE2-NEXT: pandn %xmm2, %xmm5
1084 ; SSE2-NEXT: por %xmm0, %xmm5
1085 ; SSE2-NEXT: pand %xmm4, %xmm1
1086 ; SSE2-NEXT: pandn %xmm3, %xmm4
1087 ; SSE2-NEXT: por %xmm1, %xmm4
1088 ; SSE2-NEXT: movdqa %xmm5, %xmm0
1089 ; SSE2-NEXT: movdqa %xmm4, %xmm1
1090 ; SSE2-NEXT: retq
1123 ; SSE2-LABEL: test39:
1124 ; SSE2: # BB#0: # %entry
1125 ; SSE2-NEXT: movdqa {{.*#+}} xmm5 = [32768,32768,32768,32768,32768,32768,32768,32768]
1126 ; SSE2-NEXT: movdqa %xmm3, %xmm6
1127 ; SSE2-NEXT: pxor %xmm5, %xmm6
1128 ; SSE2-NEXT: movdqa %xmm1, %xmm4
1129 ; SSE2-NEXT: pxor %xmm5, %xmm4
1130 ; SSE2-NEXT: pcmpgtw %xmm6, %xmm4
1131 ; SSE2-NEXT: movdqa %xmm2, %xmm6
1132 ; SSE2-NEXT: pxor %xmm5, %xmm6
1133 ; SSE2-NEXT: pxor %xmm0, %xmm5
1134 ; SSE2-NEXT: pcmpgtw %xmm6, %xmm5
1135 ; SSE2-NEXT: pand %xmm5, %xmm0
1136 ; SSE2-NEXT: pandn %xmm2, %xmm5
1137 ; SSE2-NEXT: por %xmm5, %xmm0
1138 ; SSE2-NEXT: pand %xmm4, %xmm1
1139 ; SSE2-NEXT: pandn %xmm3, %xmm4
1140 ; SSE2-NEXT: por %xmm1, %xmm4
1141 ; SSE2-NEXT: movdqa %xmm4, %xmm1
1142 ; SSE2-NEXT: retq
1175 ; SSE2-LABEL: test40:
1176 ; SSE2: # BB#0: # %entry
1177 ; SSE2-NEXT: movdqa %xmm3, %xmm4
1178 ; SSE2-NEXT: psubusw %xmm1, %xmm4
1179 ; SSE2-NEXT: pxor %xmm5, %xmm5
1180 ; SSE2-NEXT: pcmpeqw %xmm5, %xmm4
1181 ; SSE2-NEXT: movdqa %xmm2, %xmm6
1182 ; SSE2-NEXT: psubusw %xmm0, %xmm6
1183 ; SSE2-NEXT: pcmpeqw %xmm5, %xmm6
1184 ; SSE2-NEXT: pand %xmm6, %xmm0
1185 ; SSE2-NEXT: pandn %xmm2, %xmm6
1186 ; SSE2-NEXT: por %xmm6, %xmm0
1187 ; SSE2-NEXT: pand %xmm4, %xmm1
1188 ; SSE2-NEXT: pandn %xmm3, %xmm4
1189 ; SSE2-NEXT: por %xmm4, %xmm1
1190 ; SSE2-NEXT: retq
1223 ; SSE2-LABEL: test41:
1224 ; SSE2: # BB#0: # %entry
1225 ; SSE2-NEXT: movdqa %xmm3, %xmm4
1226 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm4
1227 ; SSE2-NEXT: movdqa %xmm2, %xmm5
1228 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm5
1229 ; SSE2-NEXT: pand %xmm5, %xmm0
1230 ; SSE2-NEXT: pandn %xmm2, %xmm5
1231 ; SSE2-NEXT: por %xmm5, %xmm0
1232 ; SSE2-NEXT: pand %xmm4, %xmm1
1233 ; SSE2-NEXT: pandn %xmm3, %xmm4
1234 ; SSE2-NEXT: por %xmm4, %xmm1
1235 ; SSE2-NEXT: retq
1268 ; SSE2-LABEL: test42:
1269 ; SSE2: # BB#0: # %entry
1270 ; SSE2-NEXT: movdqa %xmm1, %xmm6
1271 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm6
1272 ; SSE2-NEXT: pcmpeqd %xmm7, %xmm7
1273 ; SSE2-NEXT: movdqa %xmm6, %xmm4
1274 ; SSE2-NEXT: pxor %xmm7, %xmm4
1275 ; SSE2-NEXT: movdqa %xmm0, %xmm5
1276 ; SSE2-NEXT: pcmpgtd %xmm2, %xmm5
1277 ; SSE2-NEXT: pxor %xmm5, %xmm7
1278 ; SSE2-NEXT: pandn %xmm0, %xmm5
1279 ; SSE2-NEXT: pandn %xmm2, %xmm7
1280 ; SSE2-NEXT: por %xmm7, %xmm5
1281 ; SSE2-NEXT: pandn %xmm1, %xmm6
1282 ; SSE2-NEXT: pandn %xmm3, %xmm4
1283 ; SSE2-NEXT: por %xmm6, %xmm4
1284 ; SSE2-NEXT: movdqa %xmm5, %xmm0
1285 ; SSE2-NEXT: movdqa %xmm4, %xmm1
1286 ; SSE2-NEXT: retq
1319 ; SSE2-LABEL: test43:
1320 ; SSE2: # BB#0: # %entry
1321 ; SSE2-NEXT: movdqa %xmm1, %xmm4
1322 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
1323 ; SSE2-NEXT: movdqa %xmm0, %xmm5
1324 ; SSE2-NEXT: pcmpgtd %xmm2, %xmm5
1325 ; SSE2-NEXT: pand %xmm5, %xmm0
1326 ; SSE2-NEXT: pandn %xmm2, %xmm5
1327 ; SSE2-NEXT: por %xmm0, %xmm5
1328 ; SSE2-NEXT: pand %xmm4, %xmm1
1329 ; SSE2-NEXT: pandn %xmm3, %xmm4
1330 ; SSE2-NEXT: por %xmm1, %xmm4
1331 ; SSE2-NEXT: movdqa %xmm5, %xmm0
1332 ; SSE2-NEXT: movdqa %xmm4, %xmm1
1333 ; SSE2-NEXT: retq
1366 ; SSE2-LABEL: test44:
1367 ; SSE2: # BB#0: # %entry
1368 ; SSE2-NEXT: movdqa %xmm3, %xmm6
1369 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm6
1370 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
1371 ; SSE2-NEXT: movdqa %xmm6, %xmm5
1372 ; SSE2-NEXT: pxor %xmm4, %xmm5
1373 ; SSE2-NEXT: movdqa %xmm2, %xmm7
1374 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm7
1375 ; SSE2-NEXT: pxor %xmm7, %xmm4
1376 ; SSE2-NEXT: pandn %xmm0, %xmm7
1377 ; SSE2-NEXT: pandn %xmm2, %xmm4
1378 ; SSE2-NEXT: por %xmm7, %xmm4
1379 ; SSE2-NEXT: pandn %xmm1, %xmm6
1380 ; SSE2-NEXT: pandn %xmm3, %xmm5
1381 ; SSE2-NEXT: por %xmm6, %xmm5
1382 ; SSE2-NEXT: movdqa %xmm4, %xmm0
1383 ; SSE2-NEXT: movdqa %xmm5, %xmm1
1384 ; SSE2-NEXT: retq
1417 ; SSE2-LABEL: test45:
1418 ; SSE2: # BB#0: # %entry
1419 ; SSE2-NEXT: movdqa {{.*#+}} xmm4 = [2147483648,2147483648,2147483648,2147483648]
1420 ; SSE2-NEXT: movdqa %xmm1, %xmm5
1421 ; SSE2-NEXT: pxor %xmm4, %xmm5
1422 ; SSE2-NEXT: movdqa %xmm3, %xmm6
1423 ; SSE2-NEXT: pxor %xmm4, %xmm6
1424 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm6
1425 ; SSE2-NEXT: movdqa %xmm0, %xmm5
1426 ; SSE2-NEXT: pxor %xmm4, %xmm5
1427 ; SSE2-NEXT: pxor %xmm2, %xmm4
1428 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm4
1429 ; SSE2-NEXT: pand %xmm4, %xmm0
1430 ; SSE2-NEXT: pandn %xmm2, %xmm4
1431 ; SSE2-NEXT: por %xmm4, %xmm0
1432 ; SSE2-NEXT: pand %xmm6, %xmm1
1433 ; SSE2-NEXT: pandn %xmm3, %xmm6
1434 ; SSE2-NEXT: por %xmm6, %xmm1
1435 ; SSE2-NEXT: retq
1468 ; SSE2-LABEL: test46:
1469 ; SSE2: # BB#0: # %entry
1470 ; SSE2-NEXT: movdqa {{.*#+}} xmm6 = [2147483648,2147483648,2147483648,2147483648]
1471 ; SSE2-NEXT: movdqa %xmm3, %xmm4
1472 ; SSE2-NEXT: pxor %xmm6, %xmm4
1473 ; SSE2-NEXT: movdqa %xmm1, %xmm7
1474 ; SSE2-NEXT: pxor %xmm6, %xmm7
1475 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm7
1476 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
1477 ; SSE2-NEXT: movdqa %xmm7, %xmm5
1478 ; SSE2-NEXT: pxor %xmm4, %xmm5
1479 ; SSE2-NEXT: movdqa %xmm2, %xmm8
1480 ; SSE2-NEXT: pxor %xmm6, %xmm8
1481 ; SSE2-NEXT: pxor %xmm0, %xmm6
1482 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm6
1483 ; SSE2-NEXT: pxor %xmm6, %xmm4
1484 ; SSE2-NEXT: pandn %xmm0, %xmm6
1485 ; SSE2-NEXT: pandn %xmm2, %xmm4
1486 ; SSE2-NEXT: por %xmm6, %xmm4
1487 ; SSE2-NEXT: pandn %xmm1, %xmm7
1488 ; SSE2-NEXT: pandn %xmm3, %xmm5
1489 ; SSE2-NEXT: por %xmm7, %xmm5
1490 ; SSE2-NEXT: movdqa %xmm4, %xmm0
1491 ; SSE2-NEXT: movdqa %xmm5, %xmm1
1492 ; SSE2-NEXT: retq
1525 ; SSE2-LABEL: test47:
1526 ; SSE2: # BB#0: # %entry
1527 ; SSE2-NEXT: movdqa {{.*#+}} xmm5 = [2147483648,2147483648,2147483648,2147483648]
1528 ; SSE2-NEXT: movdqa %xmm3, %xmm6
1529 ; SSE2-NEXT: pxor %xmm5, %xmm6
1530 ; SSE2-NEXT: movdqa %xmm1, %xmm4
1531 ; SSE2-NEXT: pxor %xmm5, %xmm4
1532 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm4
1533 ; SSE2-NEXT: movdqa %xmm2, %xmm6
1534 ; SSE2-NEXT: pxor %xmm5, %xmm6
1535 ; SSE2-NEXT: pxor %xmm0, %xmm5
1536 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
1537 ; SSE2-NEXT: pand %xmm5, %xmm0
1538 ; SSE2-NEXT: pandn %xmm2, %xmm5
1539 ; SSE2-NEXT: por %xmm5, %xmm0
1540 ; SSE2-NEXT: pand %xmm4, %xmm1
1541 ; SSE2-NEXT: pandn %xmm3, %xmm4
1542 ; SSE2-NEXT: por %xmm1, %xmm4
1543 ; SSE2-NEXT: movdqa %xmm4, %xmm1
1544 ; SSE2-NEXT: retq
1577 ; SSE2-LABEL: test48:
1578 ; SSE2: # BB#0: # %entry
1579 ; SSE2-NEXT: movdqa {{.*#+}} xmm6 = [2147483648,2147483648,2147483648,2147483648]
1580 ; SSE2-NEXT: movdqa %xmm1, %xmm4
1581 ; SSE2-NEXT: pxor %xmm6, %xmm4
1582 ; SSE2-NEXT: movdqa %xmm3, %xmm7
1583 ; SSE2-NEXT: pxor %xmm6, %xmm7
1584 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm7
1585 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
1586 ; SSE2-NEXT: movdqa %xmm7, %xmm5
1587 ; SSE2-NEXT: pxor %xmm4, %xmm5
1588 ; SSE2-NEXT: movdqa %xmm0, %xmm8
1589 ; SSE2-NEXT: pxor %xmm6, %xmm8
1590 ; SSE2-NEXT: pxor %xmm2, %xmm6
1591 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm6
1592 ; SSE2-NEXT: pxor %xmm6, %xmm4
1593 ; SSE2-NEXT: pandn %xmm0, %xmm6
1594 ; SSE2-NEXT: pandn %xmm2, %xmm4
1595 ; SSE2-NEXT: por %xmm6, %xmm4
1596 ; SSE2-NEXT: pandn %xmm1, %xmm7
1597 ; SSE2-NEXT: pandn %xmm3, %xmm5
1598 ; SSE2-NEXT: por %xmm7, %xmm5
1599 ; SSE2-NEXT: movdqa %xmm4, %xmm0
1600 ; SSE2-NEXT: movdqa %xmm5, %xmm1
1601 ; SSE2-NEXT: retq
1634 ; SSE2-LABEL: test49:
1635 ; SSE2: # BB#0: # %entry
1636 ; SSE2-NEXT: movdqa %xmm1, %xmm2
1637 ; SSE2-NEXT: pcmpgtb %xmm0, %xmm2
1638 ; SSE2-NEXT: pand %xmm2, %xmm1
1639 ; SSE2-NEXT: pandn %xmm0, %xmm2
1640 ; SSE2-NEXT: por %xmm1, %xmm2
1641 ; SSE2-NEXT: movdqa %xmm2, %xmm0
1642 ; SSE2-NEXT: retq
1660 ; SSE2-LABEL: test50:
1661 ; SSE2: # BB#0: # %entry
1662 ; SSE2-NEXT: movdqa %xmm0, %xmm2
1663 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm2
1664 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm3
1665 ; SSE2-NEXT: pxor %xmm2, %xmm3
1666 ; SSE2-NEXT: pandn %xmm1, %xmm2
1667 ; SSE2-NEXT: pandn %xmm0, %xmm3
1668 ; SSE2-NEXT: por %xmm3, %xmm2
1669 ; SSE2-NEXT: movdqa %xmm2, %xmm0
1670 ; SSE2-NEXT: retq
1688 ; SSE2-LABEL: test51:
1689 ; SSE2: # BB#0: # %entry
1690 ; SSE2-NEXT: movdqa %xmm0, %xmm2
1691 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm2
1692 ; SSE2-NEXT: pand %xmm2, %xmm1
1693 ; SSE2-NEXT: pandn %xmm0, %xmm2
1694 ; SSE2-NEXT: por %xmm1, %xmm2
1695 ; SSE2-NEXT: movdqa %xmm2, %xmm0
1696 ; SSE2-NEXT: retq
1714 ; SSE2-LABEL: test52:
1715 ; SSE2: # BB#0: # %entry
1716 ; SSE2-NEXT: movdqa %xmm1, %xmm3
1717 ; SSE2-NEXT: pcmpgtb %xmm0, %xmm3
1718 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
1719 ; SSE2-NEXT: pxor %xmm3, %xmm2
1720 ; SSE2-NEXT: pandn %xmm1, %xmm3
1721 ; SSE2-NEXT: pandn %xmm0, %xmm2
1722 ; SSE2-NEXT: por %xmm3, %xmm2
1723 ; SSE2-NEXT: movdqa %xmm2, %xmm0
1724 ; SSE2-NEXT: retq
1870 ; SSE2-LABEL: test61:
1871 ; SSE2: # BB#0: # %entry
1872 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [32768,32768,32768,32768,32768,32768,32768,32768]
1873 ; SSE2-NEXT: movdqa %xmm0, %xmm3
1874 ; SSE2-NEXT: pxor %xmm2, %xmm3
1875 ; SSE2-NEXT: pxor %xmm1, %xmm2
1876 ; SSE2-NEXT: pcmpgtw %xmm3, %xmm2
1877 ; SSE2-NEXT: pand %xmm2, %xmm1
1878 ; SSE2-NEXT: pandn %xmm0, %xmm2
1879 ; SSE2-NEXT: por %xmm1, %xmm2
1880 ; SSE2-NEXT: movdqa %xmm2, %xmm0
1881 ; SSE2-NEXT: retq
1899 ; SSE2-LABEL: test62:
1900 ; SSE2: # BB#0: # %entry
1901 ; SSE2-NEXT: movdqa %xmm0, %xmm3
1902 ; SSE2-NEXT: psubusw %xmm1, %xmm3
1903 ; SSE2-NEXT: pxor %xmm2, %xmm2
1904 ; SSE2-NEXT: pcmpeqw %xmm3, %xmm2
1905 ; SSE2-NEXT: pand %xmm2, %xmm1
1906 ; SSE2-NEXT: pandn %xmm0, %xmm2
1907 ; SSE2-NEXT: por %xmm1, %xmm2
1908 ; SSE2-NEXT: movdqa %xmm2, %xmm0
1909 ; SSE2-NEXT: retq
1927 ; SSE2-LABEL: test63:
1928 ; SSE2: # BB#0: # %entry
1929 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [32768,32768,32768,32768,32768,32768,32768,32768]
1930 ; SSE2-NEXT: movdqa %xmm1, %xmm3
1931 ; SSE2-NEXT: pxor %xmm2, %xmm3
1932 ; SSE2-NEXT: pxor %xmm0, %xmm2
1933 ; SSE2-NEXT: pcmpgtw %xmm3, %xmm2
1934 ; SSE2-NEXT: pand %xmm2, %xmm1
1935 ; SSE2-NEXT: pandn %xmm0, %xmm2
1936 ; SSE2-NEXT: por %xmm1, %xmm2
1937 ; SSE2-NEXT: movdqa %xmm2, %xmm0
1938 ; SSE2-NEXT: retq
1956 ; SSE2-LABEL: test64:
1957 ; SSE2: # BB#0: # %entry
1958 ; SSE2-NEXT: movdqa %xmm1, %xmm3
1959 ; SSE2-NEXT: psubusw %xmm0, %xmm3
1960 ; SSE2-NEXT: pxor %xmm2, %xmm2
1961 ; SSE2-NEXT: pcmpeqw %xmm3, %xmm2
1962 ; SSE2-NEXT: pand %xmm2, %xmm1
1963 ; SSE2-NEXT: pandn %xmm0, %xmm2
1964 ; SSE2-NEXT: por %xmm1, %xmm2
1965 ; SSE2-NEXT: movdqa %xmm2, %xmm0
1966 ; SSE2-NEXT: retq
1984 ; SSE2-LABEL: test65:
1985 ; SSE2: # BB#0: # %entry
1986 ; SSE2-NEXT: movdqa %xmm1, %xmm2
1987 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm2
1988 ; SSE2-NEXT: pand %xmm2, %xmm1
1989 ; SSE2-NEXT: pandn %xmm0, %xmm2
1990 ; SSE2-NEXT: por %xmm1, %xmm2
1991 ; SSE2-NEXT: movdqa %xmm2, %xmm0
1992 ; SSE2-NEXT: retq
2010 ; SSE2-LABEL: test66:
2011 ; SSE2: # BB#0: # %entry
2012 ; SSE2-NEXT: movdqa %xmm0, %xmm2
2013 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm2
2014 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm3
2015 ; SSE2-NEXT: pxor %xmm2, %xmm3
2016 ; SSE2-NEXT: pandn %xmm1, %xmm2
2017 ; SSE2-NEXT: pandn %xmm0, %xmm3
2018 ; SSE2-NEXT: por %xmm3, %xmm2
2019 ; SSE2-NEXT: movdqa %xmm2, %xmm0
2020 ; SSE2-NEXT: retq
2038 ; SSE2-LABEL: test67:
2039 ; SSE2: # BB#0: # %entry
2040 ; SSE2-NEXT: movdqa %xmm0, %xmm2
2041 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm2
2042 ; SSE2-NEXT: pand %xmm2, %xmm1
2043 ; SSE2-NEXT: pandn %xmm0, %xmm2
2044 ; SSE2-NEXT: por %xmm1, %xmm2
2045 ; SSE2-NEXT: movdqa %xmm2, %xmm0
2046 ; SSE2-NEXT: retq
2064 ; SSE2-LABEL: test68:
2065 ; SSE2: # BB#0: # %entry
2066 ; SSE2-NEXT: movdqa %xmm1, %xmm3
2067 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm3
2068 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
2069 ; SSE2-NEXT: pxor %xmm3, %xmm2
2070 ; SSE2-NEXT: pandn %xmm1, %xmm3
2071 ; SSE2-NEXT: pandn %xmm0, %xmm2
2072 ; SSE2-NEXT: por %xmm3, %xmm2
2073 ; SSE2-NEXT: movdqa %xmm2, %xmm0
2074 ; SSE2-NEXT: retq
2092 ; SSE2-LABEL: test69:
2093 ; SSE2: # BB#0: # %entry
2094 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
2095 ; SSE2-NEXT: movdqa %xmm0, %xmm3
2096 ; SSE2-NEXT: pxor %xmm2, %xmm3
2097 ; SSE2-NEXT: pxor %xmm1, %xmm2
2098 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm2
2099 ; SSE2-NEXT: pand %xmm2, %xmm1
2100 ; SSE2-NEXT: pandn %xmm0, %xmm2
2101 ; SSE2-NEXT: por %xmm1, %xmm2
2102 ; SSE2-NEXT: movdqa %xmm2, %xmm0
2103 ; SSE2-NEXT: retq
2121 ; SSE2-LABEL: test70:
2122 ; SSE2: # BB#0: # %entry
2123 ; SSE2-NEXT: movdqa {{.*#+}} xmm3 = [2147483648,2147483648,2147483648,2147483648]
2124 ; SSE2-NEXT: movdqa %xmm1, %xmm2
2125 ; SSE2-NEXT: pxor %xmm3, %xmm2
2126 ; SSE2-NEXT: pxor %xmm0, %xmm3
2127 ; SSE2-NEXT: pcmpgtd %xmm2, %xmm3
2128 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
2129 ; SSE2-NEXT: pxor %xmm3, %xmm2
2130 ; SSE2-NEXT: pandn %xmm1, %xmm3
2131 ; SSE2-NEXT: pandn %xmm0, %xmm2
2132 ; SSE2-NEXT: por %xmm3, %xmm2
2133 ; SSE2-NEXT: movdqa %xmm2, %xmm0
2134 ; SSE2-NEXT: retq
2152 ; SSE2-LABEL: test71:
2153 ; SSE2: # BB#0: # %entry
2154 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
2155 ; SSE2-NEXT: movdqa %xmm1, %xmm3
2156 ; SSE2-NEXT: pxor %xmm2, %xmm3
2157 ; SSE2-NEXT: pxor %xmm0, %xmm2
2158 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm2
2159 ; SSE2-NEXT: pand %xmm2, %xmm1
2160 ; SSE2-NEXT: pandn %xmm0, %xmm2
2161 ; SSE2-NEXT: por %xmm1, %xmm2
2162 ; SSE2-NEXT: movdqa %xmm2, %xmm0
2163 ; SSE2-NEXT: retq
2181 ; SSE2-LABEL: test72:
2182 ; SSE2: # BB#0: # %entry
2183 ; SSE2-NEXT: movdqa {{.*#+}} xmm3 = [2147483648,2147483648,2147483648,2147483648]
2184 ; SSE2-NEXT: movdqa %xmm0, %xmm2
2185 ; SSE2-NEXT: pxor %xmm3, %xmm2
2186 ; SSE2-NEXT: pxor %xmm1, %xmm3
2187 ; SSE2-NEXT: pcmpgtd %xmm2, %xmm3
2188 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
2189 ; SSE2-NEXT: pxor %xmm3, %xmm2
2190 ; SSE2-NEXT: pandn %xmm1, %xmm3
2191 ; SSE2-NEXT: pandn %xmm0, %xmm2
2192 ; SSE2-NEXT: por %xmm3, %xmm2
2193 ; SSE2-NEXT: movdqa %xmm2, %xmm0
2194 ; SSE2-NEXT: retq
2212 ; SSE2-LABEL: test73:
2213 ; SSE2: # BB#0: # %entry
2214 ; SSE2-NEXT: movdqa %xmm3, %xmm4
2215 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm4
2216 ; SSE2-NEXT: movdqa %xmm2, %xmm5
2217 ; SSE2-NEXT: pcmpgtb %xmm0, %xmm5
2218 ; SSE2-NEXT: pand %xmm5, %xmm2
2219 ; SSE2-NEXT: pandn %xmm0, %xmm5
2220 ; SSE2-NEXT: por %xmm2, %xmm5
2221 ; SSE2-NEXT: pand %xmm4, %xmm3
2222 ; SSE2-NEXT: pandn %xmm1, %xmm4
2223 ; SSE2-NEXT: por %xmm3, %xmm4
2224 ; SSE2-NEXT: movdqa %xmm5, %xmm0
2225 ; SSE2-NEXT: movdqa %xmm4, %xmm1
2226 ; SSE2-NEXT: retq
2259 ; SSE2-LABEL: test74:
2260 ; SSE2: # BB#0: # %entry
2261 ; SSE2-NEXT: movdqa %xmm1, %xmm6
2262 ; SSE2-NEXT: pcmpgtb %xmm3, %xmm6
2263 ; SSE2-NEXT: pcmpeqd %xmm7, %xmm7
2264 ; SSE2-NEXT: movdqa %xmm6, %xmm4
2265 ; SSE2-NEXT: pxor %xmm7, %xmm4
2266 ; SSE2-NEXT: movdqa %xmm0, %xmm5
2267 ; SSE2-NEXT: pcmpgtb %xmm2, %xmm5
2268 ; SSE2-NEXT: pxor %xmm5, %xmm7
2269 ; SSE2-NEXT: pandn %xmm2, %xmm5
2270 ; SSE2-NEXT: pandn %xmm0, %xmm7
2271 ; SSE2-NEXT: por %xmm7, %xmm5
2272 ; SSE2-NEXT: pandn %xmm3, %xmm6
2273 ; SSE2-NEXT: pandn %xmm1, %xmm4
2274 ; SSE2-NEXT: por %xmm6, %xmm4
2275 ; SSE2-NEXT: movdqa %xmm5, %xmm0
2276 ; SSE2-NEXT: movdqa %xmm4, %xmm1
2277 ; SSE2-NEXT: retq
2310 ; SSE2-LABEL: test75:
2311 ; SSE2: # BB#0: # %entry
2312 ; SSE2-NEXT: movdqa %xmm1, %xmm4
2313 ; SSE2-NEXT: pcmpgtb %xmm3, %xmm4
2314 ; SSE2-NEXT: movdqa %xmm0, %xmm5
2315 ; SSE2-NEXT: pcmpgtb %xmm2, %xmm5
2316 ; SSE2-NEXT: pand %xmm5, %xmm2
2317 ; SSE2-NEXT: pandn %xmm0, %xmm5
2318 ; SSE2-NEXT: por %xmm2, %xmm5
2319 ; SSE2-NEXT: pand %xmm4, %xmm3
2320 ; SSE2-NEXT: pandn %xmm1, %xmm4
2321 ; SSE2-NEXT: por %xmm3, %xmm4
2322 ; SSE2-NEXT: movdqa %xmm5, %xmm0
2323 ; SSE2-NEXT: movdqa %xmm4, %xmm1
2324 ; SSE2-NEXT: retq
2357 ; SSE2-LABEL: test76:
2358 ; SSE2: # BB#0: # %entry
2359 ; SSE2-NEXT: movdqa %xmm3, %xmm6
2360 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm6
2361 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
2362 ; SSE2-NEXT: movdqa %xmm6, %xmm5
2363 ; SSE2-NEXT: pxor %xmm4, %xmm5
2364 ; SSE2-NEXT: movdqa %xmm2, %xmm7
2365 ; SSE2-NEXT: pcmpgtb %xmm0, %xmm7
2366 ; SSE2-NEXT: pxor %xmm7, %xmm4
2367 ; SSE2-NEXT: pandn %xmm2, %xmm7
2368 ; SSE2-NEXT: pandn %xmm0, %xmm4
2369 ; SSE2-NEXT: por %xmm7, %xmm4
2370 ; SSE2-NEXT: pandn %xmm3, %xmm6
2371 ; SSE2-NEXT: pandn %xmm1, %xmm5
2372 ; SSE2-NEXT: por %xmm6, %xmm5
2373 ; SSE2-NEXT: movdqa %xmm4, %xmm0
2374 ; SSE2-NEXT: movdqa %xmm5, %xmm1
2375 ; SSE2-NEXT: retq
2656 ; SSE2-LABEL: test85:
2657 ; SSE2: # BB#0: # %entry
2658 ; SSE2-NEXT: movdqa {{.*#+}} xmm4 = [32768,32768,32768,32768,32768,32768,32768,32768]
2659 ; SSE2-NEXT: movdqa %xmm1, %xmm6
2660 ; SSE2-NEXT: pxor %xmm4, %xmm6
2661 ; SSE2-NEXT: movdqa %xmm3, %xmm5
2662 ; SSE2-NEXT: pxor %xmm4, %xmm5
2663 ; SSE2-NEXT: pcmpgtw %xmm6, %xmm5
2664 ; SSE2-NEXT: movdqa %xmm0, %xmm6
2665 ; SSE2-NEXT: pxor %xmm4, %xmm6
2666 ; SSE2-NEXT: pxor %xmm2, %xmm4
2667 ; SSE2-NEXT: pcmpgtw %xmm6, %xmm4
2668 ; SSE2-NEXT: pand %xmm4, %xmm2
2669 ; SSE2-NEXT: pandn %xmm0, %xmm4
2670 ; SSE2-NEXT: por %xmm2, %xmm4
2671 ; SSE2-NEXT: pand %xmm5, %xmm3
2672 ; SSE2-NEXT: pandn %xmm1, %xmm5
2673 ; SSE2-NEXT: por %xmm3, %xmm5
2674 ; SSE2-NEXT: movdqa %xmm4, %xmm0
2675 ; SSE2-NEXT: movdqa %xmm5, %xmm1
2676 ; SSE2-NEXT: retq
2709 ; SSE2-LABEL: test86:
2710 ; SSE2: # BB#0: # %entry
2711 ; SSE2-NEXT: movdqa %xmm1, %xmm4
2712 ; SSE2-NEXT: psubusw %xmm3, %xmm4
2713 ; SSE2-NEXT: pxor %xmm6, %xmm6
2714 ; SSE2-NEXT: pcmpeqw %xmm6, %xmm4
2715 ; SSE2-NEXT: movdqa %xmm0, %xmm5
2716 ; SSE2-NEXT: psubusw %xmm2, %xmm5
2717 ; SSE2-NEXT: pcmpeqw %xmm6, %xmm5
2718 ; SSE2-NEXT: pand %xmm5, %xmm2
2719 ; SSE2-NEXT: pandn %xmm0, %xmm5
2720 ; SSE2-NEXT: por %xmm2, %xmm5
2721 ; SSE2-NEXT: pand %xmm4, %xmm3
2722 ; SSE2-NEXT: pandn %xmm1, %xmm4
2723 ; SSE2-NEXT: por %xmm3, %xmm4
2724 ; SSE2-NEXT: movdqa %xmm5, %xmm0
2725 ; SSE2-NEXT: movdqa %xmm4, %xmm1
2726 ; SSE2-NEXT: retq
2759 ; SSE2-LABEL: test87:
2760 ; SSE2: # BB#0: # %entry
2761 ; SSE2-NEXT: movdqa {{.*#+}} xmm4 = [32768,32768,32768,32768,32768,32768,32768,32768]
2762 ; SSE2-NEXT: movdqa %xmm3, %xmm6
2763 ; SSE2-NEXT: pxor %xmm4, %xmm6
2764 ; SSE2-NEXT: movdqa %xmm1, %xmm5
2765 ; SSE2-NEXT: pxor %xmm4, %xmm5
2766 ; SSE2-NEXT: pcmpgtw %xmm6, %xmm5
2767 ; SSE2-NEXT: movdqa %xmm2, %xmm6
2768 ; SSE2-NEXT: pxor %xmm4, %xmm6
2769 ; SSE2-NEXT: pxor %xmm0, %xmm4
2770 ; SSE2-NEXT: pcmpgtw %xmm6, %xmm4
2771 ; SSE2-NEXT: pand %xmm4, %xmm2
2772 ; SSE2-NEXT: pandn %xmm0, %xmm4
2773 ; SSE2-NEXT: por %xmm2, %xmm4
2774 ; SSE2-NEXT: pand %xmm5, %xmm3
2775 ; SSE2-NEXT: pandn %xmm1, %xmm5
2776 ; SSE2-NEXT: por %xmm3, %xmm5
2777 ; SSE2-NEXT: movdqa %xmm4, %xmm0
2778 ; SSE2-NEXT: movdqa %xmm5, %xmm1
2779 ; SSE2-NEXT: retq
2812 ; SSE2-LABEL: test88:
2813 ; SSE2: # BB#0: # %entry
2814 ; SSE2-NEXT: movdqa %xmm3, %xmm4
2815 ; SSE2-NEXT: psubusw %xmm1, %xmm4
2816 ; SSE2-NEXT: pxor %xmm6, %xmm6
2817 ; SSE2-NEXT: pcmpeqw %xmm6, %xmm4
2818 ; SSE2-NEXT: movdqa %xmm2, %xmm5
2819 ; SSE2-NEXT: psubusw %xmm0, %xmm5
2820 ; SSE2-NEXT: pcmpeqw %xmm6, %xmm5
2821 ; SSE2-NEXT: pand %xmm5, %xmm2
2822 ; SSE2-NEXT: pandn %xmm0, %xmm5
2823 ; SSE2-NEXT: por %xmm2, %xmm5
2824 ; SSE2-NEXT: pand %xmm4, %xmm3
2825 ; SSE2-NEXT: pandn %xmm1, %xmm4
2826 ; SSE2-NEXT: por %xmm3, %xmm4
2827 ; SSE2-NEXT: movdqa %xmm5, %xmm0
2828 ; SSE2-NEXT: movdqa %xmm4, %xmm1
2829 ; SSE2-NEXT: retq
2862 ; SSE2-LABEL: test89:
2863 ; SSE2: # BB#0: # %entry
2864 ; SSE2-NEXT: movdqa %xmm3, %xmm4
2865 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm4
2866 ; SSE2-NEXT: movdqa %xmm2, %xmm5
2867 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm5
2868 ; SSE2-NEXT: pand %xmm5, %xmm2
2869 ; SSE2-NEXT: pandn %xmm0, %xmm5
2870 ; SSE2-NEXT: por %xmm2, %xmm5
2871 ; SSE2-NEXT: pand %xmm4, %xmm3
2872 ; SSE2-NEXT: pandn %xmm1, %xmm4
2873 ; SSE2-NEXT: por %xmm3, %xmm4
2874 ; SSE2-NEXT: movdqa %xmm5, %xmm0
2875 ; SSE2-NEXT: movdqa %xmm4, %xmm1
2876 ; SSE2-NEXT: retq
2909 ; SSE2-LABEL: test90:
2910 ; SSE2: # BB#0: # %entry
2911 ; SSE2-NEXT: movdqa %xmm1, %xmm6
2912 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm6
2913 ; SSE2-NEXT: pcmpeqd %xmm7, %xmm7
2914 ; SSE2-NEXT: movdqa %xmm6, %xmm4
2915 ; SSE2-NEXT: pxor %xmm7, %xmm4
2916 ; SSE2-NEXT: movdqa %xmm0, %xmm5
2917 ; SSE2-NEXT: pcmpgtd %xmm2, %xmm5
2918 ; SSE2-NEXT: pxor %xmm5, %xmm7
2919 ; SSE2-NEXT: pandn %xmm2, %xmm5
2920 ; SSE2-NEXT: pandn %xmm0, %xmm7
2921 ; SSE2-NEXT: por %xmm7, %xmm5
2922 ; SSE2-NEXT: pandn %xmm3, %xmm6
2923 ; SSE2-NEXT: pandn %xmm1, %xmm4
2924 ; SSE2-NEXT: por %xmm6, %xmm4
2925 ; SSE2-NEXT: movdqa %xmm5, %xmm0
2926 ; SSE2-NEXT: movdqa %xmm4, %xmm1
2927 ; SSE2-NEXT: retq
2960 ; SSE2-LABEL: test91:
2961 ; SSE2: # BB#0: # %entry
2962 ; SSE2-NEXT: movdqa %xmm1, %xmm4
2963 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
2964 ; SSE2-NEXT: movdqa %xmm0, %xmm5
2965 ; SSE2-NEXT: pcmpgtd %xmm2, %xmm5
2966 ; SSE2-NEXT: pand %xmm5, %xmm2
2967 ; SSE2-NEXT: pandn %xmm0, %xmm5
2968 ; SSE2-NEXT: por %xmm2, %xmm5
2969 ; SSE2-NEXT: pand %xmm4, %xmm3
2970 ; SSE2-NEXT: pandn %xmm1, %xmm4
2971 ; SSE2-NEXT: por %xmm3, %xmm4
2972 ; SSE2-NEXT: movdqa %xmm5, %xmm0
2973 ; SSE2-NEXT: movdqa %xmm4, %xmm1
2974 ; SSE2-NEXT: retq
3007 ; SSE2-LABEL: test92:
3008 ; SSE2: # BB#0: # %entry
3009 ; SSE2-NEXT: movdqa %xmm3, %xmm6
3010 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm6
3011 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
3012 ; SSE2-NEXT: movdqa %xmm6, %xmm5
3013 ; SSE2-NEXT: pxor %xmm4, %xmm5
3014 ; SSE2-NEXT: movdqa %xmm2, %xmm7
3015 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm7
3016 ; SSE2-NEXT: pxor %xmm7, %xmm4
3017 ; SSE2-NEXT: pandn %xmm2, %xmm7
3018 ; SSE2-NEXT: pandn %xmm0, %xmm4
3019 ; SSE2-NEXT: por %xmm7, %xmm4
3020 ; SSE2-NEXT: pandn %xmm3, %xmm6
3021 ; SSE2-NEXT: pandn %xmm1, %xmm5
3022 ; SSE2-NEXT: por %xmm6, %xmm5
3023 ; SSE2-NEXT: movdqa %xmm4, %xmm0
3024 ; SSE2-NEXT: movdqa %xmm5, %xmm1
3025 ; SSE2-NEXT: retq
3058 ; SSE2-LABEL: test93:
3059 ; SSE2: # BB#0: # %entry
3060 ; SSE2-NEXT: movdqa {{.*#+}} xmm4 = [2147483648,2147483648,2147483648,2147483648]
3061 ; SSE2-NEXT: movdqa %xmm1, %xmm6
3062 ; SSE2-NEXT: pxor %xmm4, %xmm6
3063 ; SSE2-NEXT: movdqa %xmm3, %xmm5
3064 ; SSE2-NEXT: pxor %xmm4, %xmm5
3065 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
3066 ; SSE2-NEXT: movdqa %xmm0, %xmm6
3067 ; SSE2-NEXT: pxor %xmm4, %xmm6
3068 ; SSE2-NEXT: pxor %xmm2, %xmm4
3069 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm4
3070 ; SSE2-NEXT: pand %xmm4, %xmm2
3071 ; SSE2-NEXT: pandn %xmm0, %xmm4
3072 ; SSE2-NEXT: por %xmm2, %xmm4
3073 ; SSE2-NEXT: pand %xmm5, %xmm3
3074 ; SSE2-NEXT: pandn %xmm1, %xmm5
3075 ; SSE2-NEXT: por %xmm3, %xmm5
3076 ; SSE2-NEXT: movdqa %xmm4, %xmm0
3077 ; SSE2-NEXT: movdqa %xmm5, %xmm1
3078 ; SSE2-NEXT: retq
3111 ; SSE2-LABEL: test94:
3112 ; SSE2: # BB#0: # %entry
3113 ; SSE2-NEXT: movdqa {{.*#+}} xmm6 = [2147483648,2147483648,2147483648,2147483648]
3114 ; SSE2-NEXT: movdqa %xmm3, %xmm4
3115 ; SSE2-NEXT: pxor %xmm6, %xmm4
3116 ; SSE2-NEXT: movdqa %xmm1, %xmm7
3117 ; SSE2-NEXT: pxor %xmm6, %xmm7
3118 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm7
3119 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
3120 ; SSE2-NEXT: movdqa %xmm7, %xmm5
3121 ; SSE2-NEXT: pxor %xmm4, %xmm5
3122 ; SSE2-NEXT: movdqa %xmm2, %xmm8
3123 ; SSE2-NEXT: pxor %xmm6, %xmm8
3124 ; SSE2-NEXT: pxor %xmm0, %xmm6
3125 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm6
3126 ; SSE2-NEXT: pxor %xmm6, %xmm4
3127 ; SSE2-NEXT: pandn %xmm2, %xmm6
3128 ; SSE2-NEXT: pandn %xmm0, %xmm4
3129 ; SSE2-NEXT: por %xmm6, %xmm4
3130 ; SSE2-NEXT: pandn %xmm3, %xmm7
3131 ; SSE2-NEXT: pandn %xmm1, %xmm5
3132 ; SSE2-NEXT: por %xmm7, %xmm5
3133 ; SSE2-NEXT: movdqa %xmm4, %xmm0
3134 ; SSE2-NEXT: movdqa %xmm5, %xmm1
3135 ; SSE2-NEXT: retq
3168 ; SSE2-LABEL: test95:
3169 ; SSE2: # BB#0: # %entry
3170 ; SSE2-NEXT: movdqa {{.*#+}} xmm4 = [2147483648,2147483648,2147483648,2147483648]
3171 ; SSE2-NEXT: movdqa %xmm3, %xmm6
3172 ; SSE2-NEXT: pxor %xmm4, %xmm6
3173 ; SSE2-NEXT: movdqa %xmm1, %xmm5
3174 ; SSE2-NEXT: pxor %xmm4, %xmm5
3175 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
3176 ; SSE2-NEXT: movdqa %xmm2, %xmm6
3177 ; SSE2-NEXT: pxor %xmm4, %xmm6
3178 ; SSE2-NEXT: pxor %xmm0, %xmm4
3179 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm4
3180 ; SSE2-NEXT: pand %xmm4, %xmm2
3181 ; SSE2-NEXT: pandn %xmm0, %xmm4
3182 ; SSE2-NEXT: por %xmm2, %xmm4
3183 ; SSE2-NEXT: pand %xmm5, %xmm3
3184 ; SSE2-NEXT: pandn %xmm1, %xmm5
3185 ; SSE2-NEXT: por %xmm3, %xmm5
3186 ; SSE2-NEXT: movdqa %xmm4, %xmm0
3187 ; SSE2-NEXT: movdqa %xmm5, %xmm1
3188 ; SSE2-NEXT: retq
3221 ; SSE2-LABEL: test96:
3222 ; SSE2: # BB#0: # %entry
3223 ; SSE2-NEXT: movdqa {{.*#+}} xmm6 = [2147483648,2147483648,2147483648,2147483648]
3224 ; SSE2-NEXT: movdqa %xmm1, %xmm4
3225 ; SSE2-NEXT: pxor %xmm6, %xmm4
3226 ; SSE2-NEXT: movdqa %xmm3, %xmm7
3227 ; SSE2-NEXT: pxor %xmm6, %xmm7
3228 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm7
3229 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
3230 ; SSE2-NEXT: movdqa %xmm7, %xmm5
3231 ; SSE2-NEXT: pxor %xmm4, %xmm5
3232 ; SSE2-NEXT: movdqa %xmm0, %xmm8
3233 ; SSE2-NEXT: pxor %xmm6, %xmm8
3234 ; SSE2-NEXT: pxor %xmm2, %xmm6
3235 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm6
3236 ; SSE2-NEXT: pxor %xmm6, %xmm4
3237 ; SSE2-NEXT: pandn %xmm2, %xmm6
3238 ; SSE2-NEXT: pandn %xmm0, %xmm4
3239 ; SSE2-NEXT: por %xmm6, %xmm4
3240 ; SSE2-NEXT: pandn %xmm3, %xmm7
3241 ; SSE2-NEXT: pandn %xmm1, %xmm5
3242 ; SSE2-NEXT: por %xmm7, %xmm5
3243 ; SSE2-NEXT: movdqa %xmm4, %xmm0
3244 ; SSE2-NEXT: movdqa %xmm5, %xmm1
3245 ; SSE2-NEXT: retq
3280 ; SSE2-LABEL: test97:
3281 ; SSE2: # BB#0: # %entry
3282 ; SSE2-NEXT: movdqa %xmm7, %xmm8
3283 ; SSE2-NEXT: pcmpgtb %xmm3, %xmm8
3284 ; SSE2-NEXT: movdqa %xmm6, %xmm9
3285 ; SSE2-NEXT: pcmpgtb %xmm2, %xmm9
3286 ; SSE2-NEXT: movdqa %xmm5, %xmm10
3287 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm10
3288 ; SSE2-NEXT: movdqa %xmm4, %xmm11
3289 ; SSE2-NEXT: pcmpgtb %xmm0, %xmm11
3290 ; SSE2-NEXT: pand %xmm11, %xmm0
3291 ; SSE2-NEXT: pandn %xmm4, %xmm11
3292 ; SSE2-NEXT: por %xmm11, %xmm0
3293 ; SSE2-NEXT: pand %xmm10, %xmm1
3294 ; SSE2-NEXT: pandn %xmm5, %xmm10
3295 ; SSE2-NEXT: por %xmm10, %xmm1
3296 ; SSE2-NEXT: pand %xmm9, %xmm2
3297 ; SSE2-NEXT: pandn %xmm6, %xmm9
3298 ; SSE2-NEXT: por %xmm9, %xmm2
3299 ; SSE2-NEXT: pand %xmm8, %xmm3
3300 ; SSE2-NEXT: pandn %xmm7, %xmm8
3301 ; SSE2-NEXT: por %xmm8, %xmm3
3302 ; SSE2-NEXT: retq
3343 ; SSE2-LABEL: test98:
3344 ; SSE2: # BB#0: # %entry
3345 ; SSE2-NEXT: movdqa %xmm3, %xmm8
3346 ; SSE2-NEXT: movdqa %xmm2, %xmm9
3347 ; SSE2-NEXT: movdqa %xmm8, %xmm12
3348 ; SSE2-NEXT: pcmpgtb %xmm7, %xmm12
3349 ; SSE2-NEXT: pcmpeqd %xmm13, %xmm13
3350 ; SSE2-NEXT: movdqa %xmm12, %xmm3
3351 ; SSE2-NEXT: pxor %xmm13, %xmm3
3352 ; SSE2-NEXT: movdqa %xmm9, %xmm14
3353 ; SSE2-NEXT: pcmpgtb %xmm6, %xmm14
3354 ; SSE2-NEXT: movdqa %xmm14, %xmm2
3355 ; SSE2-NEXT: pxor %xmm13, %xmm2
3356 ; SSE2-NEXT: movdqa %xmm1, %xmm15
3357 ; SSE2-NEXT: pcmpgtb %xmm5, %xmm15
3358 ; SSE2-NEXT: movdqa %xmm15, %xmm10
3359 ; SSE2-NEXT: pxor %xmm13, %xmm10
3360 ; SSE2-NEXT: movdqa %xmm0, %xmm11
3361 ; SSE2-NEXT: pcmpgtb %xmm4, %xmm11
3362 ; SSE2-NEXT: pxor %xmm11, %xmm13
3363 ; SSE2-NEXT: pandn %xmm0, %xmm11
3364 ; SSE2-NEXT: pandn %xmm4, %xmm13
3365 ; SSE2-NEXT: por %xmm13, %xmm11
3366 ; SSE2-NEXT: pandn %xmm1, %xmm15
3367 ; SSE2-NEXT: pandn %xmm5, %xmm10
3368 ; SSE2-NEXT: por %xmm15, %xmm10
3369 ; SSE2-NEXT: pandn %xmm9, %xmm14
3370 ; SSE2-NEXT: pandn %xmm6, %xmm2
3371 ; SSE2-NEXT: por %xmm14, %xmm2
3372 ; SSE2-NEXT: pandn %xmm8, %xmm12
3373 ; SSE2-NEXT: pandn %xmm7, %xmm3
3374 ; SSE2-NEXT: por %xmm12, %xmm3
3375 ; SSE2-NEXT: movdqa %xmm11, %xmm0
3376 ; SSE2-NEXT: movdqa %xmm10, %xmm1
3377 ; SSE2-NEXT: retq
3418 ; SSE2-LABEL: test99:
3419 ; SSE2: # BB#0: # %entry
3420 ; SSE2-NEXT: movdqa %xmm3, %xmm8
3421 ; SSE2-NEXT: pcmpgtb %xmm7, %xmm3
3422 ; SSE2-NEXT: movdqa %xmm2, %xmm9
3423 ; SSE2-NEXT: pcmpgtb %xmm6, %xmm9
3424 ; SSE2-NEXT: movdqa %xmm1, %xmm10
3425 ; SSE2-NEXT: pcmpgtb %xmm5, %xmm10
3426 ; SSE2-NEXT: movdqa %xmm0, %xmm11
3427 ; SSE2-NEXT: pcmpgtb %xmm4, %xmm11
3428 ; SSE2-NEXT: pand %xmm11, %xmm0
3429 ; SSE2-NEXT: pandn %xmm4, %xmm11
3430 ; SSE2-NEXT: por %xmm0, %xmm11
3431 ; SSE2-NEXT: pand %xmm10, %xmm1
3432 ; SSE2-NEXT: pandn %xmm5, %xmm10
3433 ; SSE2-NEXT: por %xmm1, %xmm10
3434 ; SSE2-NEXT: pand %xmm9, %xmm2
3435 ; SSE2-NEXT: pandn %xmm6, %xmm9
3436 ; SSE2-NEXT: por %xmm2, %xmm9
3437 ; SSE2-NEXT: pand %xmm3, %xmm8
3438 ; SSE2-NEXT: pandn %xmm7, %xmm3
3439 ; SSE2-NEXT: por %xmm8, %xmm3
3440 ; SSE2-NEXT: movdqa %xmm11, %xmm0
3441 ; SSE2-NEXT: movdqa %xmm10, %xmm1
3442 ; SSE2-NEXT: movdqa %xmm9, %xmm2
3443 ; SSE2-NEXT: retq
3484 ; SSE2-LABEL: test100:
3485 ; SSE2: # BB#0: # %entry
3486 ; SSE2-NEXT: movdqa %xmm3, %xmm8
3487 ; SSE2-NEXT: movdqa %xmm2, %xmm9
3488 ; SSE2-NEXT: movdqa %xmm0, %xmm10
3489 ; SSE2-NEXT: movdqa %xmm7, %xmm12
3490 ; SSE2-NEXT: pcmpgtb %xmm8, %xmm12
3491 ; SSE2-NEXT: pcmpeqd %xmm0, %xmm0
3492 ; SSE2-NEXT: movdqa %xmm12, %xmm3
3493 ; SSE2-NEXT: pxor %xmm0, %xmm3
3494 ; SSE2-NEXT: movdqa %xmm6, %xmm13
3495 ; SSE2-NEXT: pcmpgtb %xmm9, %xmm13
3496 ; SSE2-NEXT: movdqa %xmm13, %xmm2
3497 ; SSE2-NEXT: pxor %xmm0, %xmm2
3498 ; SSE2-NEXT: movdqa %xmm5, %xmm14
3499 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm14
3500 ; SSE2-NEXT: movdqa %xmm14, %xmm11
3501 ; SSE2-NEXT: pxor %xmm0, %xmm11
3502 ; SSE2-NEXT: movdqa %xmm4, %xmm15
3503 ; SSE2-NEXT: pcmpgtb %xmm10, %xmm15
3504 ; SSE2-NEXT: pxor %xmm15, %xmm0
3505 ; SSE2-NEXT: pandn %xmm10, %xmm15
3506 ; SSE2-NEXT: pandn %xmm4, %xmm0
3507 ; SSE2-NEXT: por %xmm15, %xmm0
3508 ; SSE2-NEXT: pandn %xmm1, %xmm14
3509 ; SSE2-NEXT: pandn %xmm5, %xmm11
3510 ; SSE2-NEXT: por %xmm14, %xmm11
3511 ; SSE2-NEXT: pandn %xmm9, %xmm13
3512 ; SSE2-NEXT: pandn %xmm6, %xmm2
3513 ; SSE2-NEXT: por %xmm13, %xmm2
3514 ; SSE2-NEXT: pandn %xmm8, %xmm12
3515 ; SSE2-NEXT: pandn %xmm7, %xmm3
3516 ; SSE2-NEXT: por %xmm12, %xmm3
3517 ; SSE2-NEXT: movdqa %xmm11, %xmm1
3518 ; SSE2-NEXT: retq
3871 ; SSE2-LABEL: test109:
3872 ; SSE2: # BB#0: # %entry
3873 ; SSE2-NEXT: movdqa {{.*#+}} xmm10 = [32768,32768,32768,32768,32768,32768,32768,32768]
3874 ; SSE2-NEXT: movdqa %xmm3, %xmm9
3875 ; SSE2-NEXT: pxor %xmm10, %xmm9
3876 ; SSE2-NEXT: movdqa %xmm7, %xmm8
3877 ; SSE2-NEXT: pxor %xmm10, %xmm8
3878 ; SSE2-NEXT: pcmpgtw %xmm9, %xmm8
3879 ; SSE2-NEXT: movdqa %xmm2, %xmm11
3880 ; SSE2-NEXT: pxor %xmm10, %xmm11
3881 ; SSE2-NEXT: movdqa %xmm6, %xmm9
3882 ; SSE2-NEXT: pxor %xmm10, %xmm9
3883 ; SSE2-NEXT: pcmpgtw %xmm11, %xmm9
3884 ; SSE2-NEXT: movdqa %xmm1, %xmm11
3885 ; SSE2-NEXT: pxor %xmm10, %xmm11
3886 ; SSE2-NEXT: movdqa %xmm5, %xmm12
3887 ; SSE2-NEXT: pxor %xmm10, %xmm12
3888 ; SSE2-NEXT: pcmpgtw %xmm11, %xmm12
3889 ; SSE2-NEXT: movdqa %xmm0, %xmm11
3890 ; SSE2-NEXT: pxor %xmm10, %xmm11
3891 ; SSE2-NEXT: pxor %xmm4, %xmm10
3892 ; SSE2-NEXT: pcmpgtw %xmm11, %xmm10
3893 ; SSE2-NEXT: pand %xmm10, %xmm0
3894 ; SSE2-NEXT: pandn %xmm4, %xmm10
3895 ; SSE2-NEXT: por %xmm10, %xmm0
3896 ; SSE2-NEXT: pand %xmm12, %xmm1
3897 ; SSE2-NEXT: pandn %xmm5, %xmm12
3898 ; SSE2-NEXT: por %xmm12, %xmm1
3899 ; SSE2-NEXT: pand %xmm9, %xmm2
3900 ; SSE2-NEXT: pandn %xmm6, %xmm9
3901 ; SSE2-NEXT: por %xmm9, %xmm2
3902 ; SSE2-NEXT: pand %xmm8, %xmm3
3903 ; SSE2-NEXT: pandn %xmm7, %xmm8
3904 ; SSE2-NEXT: por %xmm8, %xmm3
3905 ; SSE2-NEXT: retq
3946 ; SSE2-LABEL: test110:
3947 ; SSE2: # BB#0: # %entry
3948 ; SSE2-NEXT: movdqa %xmm3, %xmm8
3949 ; SSE2-NEXT: movdqa %xmm2, %xmm9
3950 ; SSE2-NEXT: movdqa %xmm1, %xmm10
3951 ; SSE2-NEXT: psubusw %xmm7, %xmm3
3952 ; SSE2-NEXT: pxor %xmm12, %xmm12
3953 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm3
3954 ; SSE2-NEXT: psubusw %xmm6, %xmm2
3955 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm2
3956 ; SSE2-NEXT: psubusw %xmm5, %xmm1
3957 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm1
3958 ; SSE2-NEXT: movdqa %xmm0, %xmm11
3959 ; SSE2-NEXT: psubusw %xmm4, %xmm11
3960 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm11
3961 ; SSE2-NEXT: pand %xmm11, %xmm0
3962 ; SSE2-NEXT: pandn %xmm4, %xmm11
3963 ; SSE2-NEXT: por %xmm0, %xmm11
3964 ; SSE2-NEXT: pand %xmm1, %xmm10
3965 ; SSE2-NEXT: pandn %xmm5, %xmm1
3966 ; SSE2-NEXT: por %xmm10, %xmm1
3967 ; SSE2-NEXT: pand %xmm2, %xmm9
3968 ; SSE2-NEXT: pandn %xmm6, %xmm2
3969 ; SSE2-NEXT: por %xmm9, %xmm2
3970 ; SSE2-NEXT: pand %xmm3, %xmm8
3971 ; SSE2-NEXT: pandn %xmm7, %xmm3
3972 ; SSE2-NEXT: por %xmm8, %xmm3
3973 ; SSE2-NEXT: movdqa %xmm11, %xmm0
3974 ; SSE2-NEXT: retq
4015 ; SSE2-LABEL: test111:
4016 ; SSE2: # BB#0: # %entry
4017 ; SSE2-NEXT: movdqa {{.*#+}} xmm11 = [32768,32768,32768,32768,32768,32768,32768,32768]
4018 ; SSE2-NEXT: movdqa %xmm7, %xmm9
4019 ; SSE2-NEXT: pxor %xmm11, %xmm9
4020 ; SSE2-NEXT: movdqa %xmm3, %xmm8
4021 ; SSE2-NEXT: pxor %xmm11, %xmm8
4022 ; SSE2-NEXT: pcmpgtw %xmm9, %xmm8
4023 ; SSE2-NEXT: movdqa %xmm6, %xmm10
4024 ; SSE2-NEXT: pxor %xmm11, %xmm10
4025 ; SSE2-NEXT: movdqa %xmm2, %xmm9
4026 ; SSE2-NEXT: pxor %xmm11, %xmm9
4027 ; SSE2-NEXT: pcmpgtw %xmm10, %xmm9
4028 ; SSE2-NEXT: movdqa %xmm5, %xmm12
4029 ; SSE2-NEXT: pxor %xmm11, %xmm12
4030 ; SSE2-NEXT: movdqa %xmm1, %xmm10
4031 ; SSE2-NEXT: pxor %xmm11, %xmm10
4032 ; SSE2-NEXT: pcmpgtw %xmm12, %xmm10
4033 ; SSE2-NEXT: movdqa %xmm4, %xmm12
4034 ; SSE2-NEXT: pxor %xmm11, %xmm12
4035 ; SSE2-NEXT: pxor %xmm0, %xmm11
4036 ; SSE2-NEXT: pcmpgtw %xmm12, %xmm11
4037 ; SSE2-NEXT: pand %xmm11, %xmm0
4038 ; SSE2-NEXT: pandn %xmm4, %xmm11
4039 ; SSE2-NEXT: por %xmm11, %xmm0
4040 ; SSE2-NEXT: pand %xmm10, %xmm1
4041 ; SSE2-NEXT: pandn %xmm5, %xmm10
4042 ; SSE2-NEXT: por %xmm1, %xmm10
4043 ; SSE2-NEXT: pand %xmm9, %xmm2
4044 ; SSE2-NEXT: pandn %xmm6, %xmm9
4045 ; SSE2-NEXT: por %xmm2, %xmm9
4046 ; SSE2-NEXT: pand %xmm8, %xmm3
4047 ; SSE2-NEXT: pandn %xmm7, %xmm8
4048 ; SSE2-NEXT: por %xmm3, %xmm8
4049 ; SSE2-NEXT: movdqa %xmm10, %xmm1
4050 ; SSE2-NEXT: movdqa %xmm9, %xmm2
4051 ; SSE2-NEXT: movdqa %xmm8, %xmm3
4052 ; SSE2-NEXT: retq
4093 ; SSE2-LABEL: test112:
4094 ; SSE2: # BB#0: # %entry
4095 ; SSE2-NEXT: movdqa %xmm7, %xmm8
4096 ; SSE2-NEXT: psubusw %xmm3, %xmm8
4097 ; SSE2-NEXT: pxor %xmm9, %xmm9
4098 ; SSE2-NEXT: pcmpeqw %xmm9, %xmm8
4099 ; SSE2-NEXT: movdqa %xmm6, %xmm10
4100 ; SSE2-NEXT: psubusw %xmm2, %xmm10
4101 ; SSE2-NEXT: pcmpeqw %xmm9, %xmm10
4102 ; SSE2-NEXT: movdqa %xmm5, %xmm11
4103 ; SSE2-NEXT: psubusw %xmm1, %xmm11
4104 ; SSE2-NEXT: pcmpeqw %xmm9, %xmm11
4105 ; SSE2-NEXT: movdqa %xmm4, %xmm12
4106 ; SSE2-NEXT: psubusw %xmm0, %xmm12
4107 ; SSE2-NEXT: pcmpeqw %xmm9, %xmm12
4108 ; SSE2-NEXT: pand %xmm12, %xmm0
4109 ; SSE2-NEXT: pandn %xmm4, %xmm12
4110 ; SSE2-NEXT: por %xmm12, %xmm0
4111 ; SSE2-NEXT: pand %xmm11, %xmm1
4112 ; SSE2-NEXT: pandn %xmm5, %xmm11
4113 ; SSE2-NEXT: por %xmm11, %xmm1
4114 ; SSE2-NEXT: pand %xmm10, %xmm2
4115 ; SSE2-NEXT: pandn %xmm6, %xmm10
4116 ; SSE2-NEXT: por %xmm10, %xmm2
4117 ; SSE2-NEXT: pand %xmm8, %xmm3
4118 ; SSE2-NEXT: pandn %xmm7, %xmm8
4119 ; SSE2-NEXT: por %xmm8, %xmm3
4120 ; SSE2-NEXT: retq
4161 ; SSE2-LABEL: test113:
4162 ; SSE2: # BB#0: # %entry
4163 ; SSE2-NEXT: movdqa %xmm7, %xmm8
4164 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm8
4165 ; SSE2-NEXT: movdqa %xmm6, %xmm9
4166 ; SSE2-NEXT: pcmpgtd %xmm2, %xmm9
4167 ; SSE2-NEXT: movdqa %xmm5, %xmm10
4168 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm10
4169 ; SSE2-NEXT: movdqa %xmm4, %xmm11
4170 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm11
4171 ; SSE2-NEXT: pand %xmm11, %xmm0
4172 ; SSE2-NEXT: pandn %xmm4, %xmm11
4173 ; SSE2-NEXT: por %xmm11, %xmm0
4174 ; SSE2-NEXT: pand %xmm10, %xmm1
4175 ; SSE2-NEXT: pandn %xmm5, %xmm10
4176 ; SSE2-NEXT: por %xmm10, %xmm1
4177 ; SSE2-NEXT: pand %xmm9, %xmm2
4178 ; SSE2-NEXT: pandn %xmm6, %xmm9
4179 ; SSE2-NEXT: por %xmm9, %xmm2
4180 ; SSE2-NEXT: pand %xmm8, %xmm3
4181 ; SSE2-NEXT: pandn %xmm7, %xmm8
4182 ; SSE2-NEXT: por %xmm8, %xmm3
4183 ; SSE2-NEXT: retq
4224 ; SSE2-LABEL: test114:
4225 ; SSE2: # BB#0: # %entry
4226 ; SSE2-NEXT: movdqa %xmm3, %xmm8
4227 ; SSE2-NEXT: movdqa %xmm2, %xmm9
4228 ; SSE2-NEXT: movdqa %xmm8, %xmm12
4229 ; SSE2-NEXT: pcmpgtd %xmm7, %xmm12
4230 ; SSE2-NEXT: pcmpeqd %xmm13, %xmm13
4231 ; SSE2-NEXT: movdqa %xmm12, %xmm3
4232 ; SSE2-NEXT: pxor %xmm13, %xmm3
4233 ; SSE2-NEXT: movdqa %xmm9, %xmm14
4234 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm14
4235 ; SSE2-NEXT: movdqa %xmm14, %xmm2
4236 ; SSE2-NEXT: pxor %xmm13, %xmm2
4237 ; SSE2-NEXT: movdqa %xmm1, %xmm15
4238 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm15
4239 ; SSE2-NEXT: movdqa %xmm15, %xmm10
4240 ; SSE2-NEXT: pxor %xmm13, %xmm10
4241 ; SSE2-NEXT: movdqa %xmm0, %xmm11
4242 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm11
4243 ; SSE2-NEXT: pxor %xmm11, %xmm13
4244 ; SSE2-NEXT: pandn %xmm0, %xmm11
4245 ; SSE2-NEXT: pandn %xmm4, %xmm13
4246 ; SSE2-NEXT: por %xmm13, %xmm11
4247 ; SSE2-NEXT: pandn %xmm1, %xmm15
4248 ; SSE2-NEXT: pandn %xmm5, %xmm10
4249 ; SSE2-NEXT: por %xmm15, %xmm10
4250 ; SSE2-NEXT: pandn %xmm9, %xmm14
4251 ; SSE2-NEXT: pandn %xmm6, %xmm2
4252 ; SSE2-NEXT: por %xmm14, %xmm2
4253 ; SSE2-NEXT: pandn %xmm8, %xmm12
4254 ; SSE2-NEXT: pandn %xmm7, %xmm3
4255 ; SSE2-NEXT: por %xmm12, %xmm3
4256 ; SSE2-NEXT: movdqa %xmm11, %xmm0
4257 ; SSE2-NEXT: movdqa %xmm10, %xmm1
4258 ; SSE2-NEXT: retq
4299 ; SSE2-LABEL: test115:
4300 ; SSE2: # BB#0: # %entry
4301 ; SSE2-NEXT: movdqa %xmm3, %xmm8
4302 ; SSE2-NEXT: pcmpgtd %xmm7, %xmm3
4303 ; SSE2-NEXT: movdqa %xmm2, %xmm9
4304 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm9
4305 ; SSE2-NEXT: movdqa %xmm1, %xmm10
4306 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm10
4307 ; SSE2-NEXT: movdqa %xmm0, %xmm11
4308 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm11
4309 ; SSE2-NEXT: pand %xmm11, %xmm0
4310 ; SSE2-NEXT: pandn %xmm4, %xmm11
4311 ; SSE2-NEXT: por %xmm0, %xmm11
4312 ; SSE2-NEXT: pand %xmm10, %xmm1
4313 ; SSE2-NEXT: pandn %xmm5, %xmm10
4314 ; SSE2-NEXT: por %xmm1, %xmm10
4315 ; SSE2-NEXT: pand %xmm9, %xmm2
4316 ; SSE2-NEXT: pandn %xmm6, %xmm9
4317 ; SSE2-NEXT: por %xmm2, %xmm9
4318 ; SSE2-NEXT: pand %xmm3, %xmm8
4319 ; SSE2-NEXT: pandn %xmm7, %xmm3
4320 ; SSE2-NEXT: por %xmm8, %xmm3
4321 ; SSE2-NEXT: movdqa %xmm11, %xmm0
4322 ; SSE2-NEXT: movdqa %xmm10, %xmm1
4323 ; SSE2-NEXT: movdqa %xmm9, %xmm2
4324 ; SSE2-NEXT: retq
4365 ; SSE2-LABEL: test116:
4366 ; SSE2: # BB#0: # %entry
4367 ; SSE2-NEXT: movdqa %xmm3, %xmm8
4368 ; SSE2-NEXT: movdqa %xmm2, %xmm9
4369 ; SSE2-NEXT: movdqa %xmm0, %xmm10
4370 ; SSE2-NEXT: movdqa %xmm7, %xmm12
4371 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm12
4372 ; SSE2-NEXT: pcmpeqd %xmm0, %xmm0
4373 ; SSE2-NEXT: movdqa %xmm12, %xmm3
4374 ; SSE2-NEXT: pxor %xmm0, %xmm3
4375 ; SSE2-NEXT: movdqa %xmm6, %xmm13
4376 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm13
4377 ; SSE2-NEXT: movdqa %xmm13, %xmm2
4378 ; SSE2-NEXT: pxor %xmm0, %xmm2
4379 ; SSE2-NEXT: movdqa %xmm5, %xmm14
4380 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm14
4381 ; SSE2-NEXT: movdqa %xmm14, %xmm11
4382 ; SSE2-NEXT: pxor %xmm0, %xmm11
4383 ; SSE2-NEXT: movdqa %xmm4, %xmm15
4384 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm15
4385 ; SSE2-NEXT: pxor %xmm15, %xmm0
4386 ; SSE2-NEXT: pandn %xmm10, %xmm15
4387 ; SSE2-NEXT: pandn %xmm4, %xmm0
4388 ; SSE2-NEXT: por %xmm15, %xmm0
4389 ; SSE2-NEXT: pandn %xmm1, %xmm14
4390 ; SSE2-NEXT: pandn %xmm5, %xmm11
4391 ; SSE2-NEXT: por %xmm14, %xmm11
4392 ; SSE2-NEXT: pandn %xmm9, %xmm13
4393 ; SSE2-NEXT: pandn %xmm6, %xmm2
4394 ; SSE2-NEXT: por %xmm13, %xmm2
4395 ; SSE2-NEXT: pandn %xmm8, %xmm12
4396 ; SSE2-NEXT: pandn %xmm7, %xmm3
4397 ; SSE2-NEXT: por %xmm12, %xmm3
4398 ; SSE2-NEXT: movdqa %xmm11, %xmm1
4399 ; SSE2-NEXT: retq
4440 ; SSE2-LABEL: test117:
4441 ; SSE2: # BB#0: # %entry
4442 ; SSE2-NEXT: movdqa {{.*#+}} xmm10 = [2147483648,2147483648,2147483648,2147483648]
4443 ; SSE2-NEXT: movdqa %xmm3, %xmm9
4444 ; SSE2-NEXT: pxor %xmm10, %xmm9
4445 ; SSE2-NEXT: movdqa %xmm7, %xmm8
4446 ; SSE2-NEXT: pxor %xmm10, %xmm8
4447 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm8
4448 ; SSE2-NEXT: movdqa %xmm2, %xmm11
4449 ; SSE2-NEXT: pxor %xmm10, %xmm11
4450 ; SSE2-NEXT: movdqa %xmm6, %xmm9
4451 ; SSE2-NEXT: pxor %xmm10, %xmm9
4452 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm9
4453 ; SSE2-NEXT: movdqa %xmm1, %xmm11
4454 ; SSE2-NEXT: pxor %xmm10, %xmm11
4455 ; SSE2-NEXT: movdqa %xmm5, %xmm12
4456 ; SSE2-NEXT: pxor %xmm10, %xmm12
4457 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm12
4458 ; SSE2-NEXT: movdqa %xmm0, %xmm11
4459 ; SSE2-NEXT: pxor %xmm10, %xmm11
4460 ; SSE2-NEXT: pxor %xmm4, %xmm10
4461 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm10
4462 ; SSE2-NEXT: pand %xmm10, %xmm0
4463 ; SSE2-NEXT: pandn %xmm4, %xmm10
4464 ; SSE2-NEXT: por %xmm10, %xmm0
4465 ; SSE2-NEXT: pand %xmm12, %xmm1
4466 ; SSE2-NEXT: pandn %xmm5, %xmm12
4467 ; SSE2-NEXT: por %xmm12, %xmm1
4468 ; SSE2-NEXT: pand %xmm9, %xmm2
4469 ; SSE2-NEXT: pandn %xmm6, %xmm9
4470 ; SSE2-NEXT: por %xmm9, %xmm2
4471 ; SSE2-NEXT: pand %xmm8, %xmm3
4472 ; SSE2-NEXT: pandn %xmm7, %xmm8
4473 ; SSE2-NEXT: por %xmm8, %xmm3
4474 ; SSE2-NEXT: retq
4515 ; SSE2-LABEL: test118:
4516 ; SSE2: # BB#0: # %entry
4517 ; SSE2-NEXT: movdqa %xmm0, %xmm10
4518 ; SSE2-NEXT: movdqa {{.*#+}} xmm14 = [2147483648,2147483648,2147483648,2147483648]
4519 ; SSE2-NEXT: movdqa %xmm7, %xmm0
4520 ; SSE2-NEXT: pxor %xmm14, %xmm0
4521 ; SSE2-NEXT: movdqa %xmm3, %xmm12
4522 ; SSE2-NEXT: pxor %xmm14, %xmm12
4523 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm12
4524 ; SSE2-NEXT: pcmpeqd %xmm0, %xmm0
4525 ; SSE2-NEXT: movdqa %xmm12, %xmm8
4526 ; SSE2-NEXT: pxor %xmm0, %xmm8
4527 ; SSE2-NEXT: movdqa %xmm6, %xmm9
4528 ; SSE2-NEXT: pxor %xmm14, %xmm9
4529 ; SSE2-NEXT: movdqa %xmm2, %xmm13
4530 ; SSE2-NEXT: pxor %xmm14, %xmm13
4531 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm13
4532 ; SSE2-NEXT: movdqa %xmm13, %xmm9
4533 ; SSE2-NEXT: pxor %xmm0, %xmm9
4534 ; SSE2-NEXT: movdqa %xmm5, %xmm11
4535 ; SSE2-NEXT: pxor %xmm14, %xmm11
4536 ; SSE2-NEXT: movdqa %xmm1, %xmm15
4537 ; SSE2-NEXT: pxor %xmm14, %xmm15
4538 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
4539 ; SSE2-NEXT: movdqa %xmm4, %xmm11
4540 ; SSE2-NEXT: pxor %xmm14, %xmm11
4541 ; SSE2-NEXT: pxor %xmm10, %xmm14
4542 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
4543 ; SSE2-NEXT: movdqa %xmm15, %xmm11
4544 ; SSE2-NEXT: pxor %xmm0, %xmm11
4545 ; SSE2-NEXT: pxor %xmm14, %xmm0
4546 ; SSE2-NEXT: pandn %xmm10, %xmm14
4547 ; SSE2-NEXT: pandn %xmm4, %xmm0
4548 ; SSE2-NEXT: por %xmm14, %xmm0
4549 ; SSE2-NEXT: pandn %xmm1, %xmm15
4550 ; SSE2-NEXT: pandn %xmm5, %xmm11
4551 ; SSE2-NEXT: por %xmm15, %xmm11
4552 ; SSE2-NEXT: pandn %xmm2, %xmm13
4553 ; SSE2-NEXT: pandn %xmm6, %xmm9
4554 ; SSE2-NEXT: por %xmm13, %xmm9
4555 ; SSE2-NEXT: pandn %xmm3, %xmm12
4556 ; SSE2-NEXT: pandn %xmm7, %xmm8
4557 ; SSE2-NEXT: por %xmm12, %xmm8
4558 ; SSE2-NEXT: movdqa %xmm11, %xmm1
4559 ; SSE2-NEXT: movdqa %xmm9, %xmm2
4560 ; SSE2-NEXT: movdqa %xmm8, %xmm3
4561 ; SSE2-NEXT: retq
4602 ; SSE2-LABEL: test119:
4603 ; SSE2: # BB#0: # %entry
4604 ; SSE2-NEXT: movdqa {{.*#+}} xmm11 = [2147483648,2147483648,2147483648,2147483648]
4605 ; SSE2-NEXT: movdqa %xmm7, %xmm9
4606 ; SSE2-NEXT: pxor %xmm11, %xmm9
4607 ; SSE2-NEXT: movdqa %xmm3, %xmm8
4608 ; SSE2-NEXT: pxor %xmm11, %xmm8
4609 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm8
4610 ; SSE2-NEXT: movdqa %xmm6, %xmm10
4611 ; SSE2-NEXT: pxor %xmm11, %xmm10
4612 ; SSE2-NEXT: movdqa %xmm2, %xmm9
4613 ; SSE2-NEXT: pxor %xmm11, %xmm9
4614 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm9
4615 ; SSE2-NEXT: movdqa %xmm5, %xmm12
4616 ; SSE2-NEXT: pxor %xmm11, %xmm12
4617 ; SSE2-NEXT: movdqa %xmm1, %xmm10
4618 ; SSE2-NEXT: pxor %xmm11, %xmm10
4619 ; SSE2-NEXT: pcmpgtd %xmm12, %xmm10
4620 ; SSE2-NEXT: movdqa %xmm4, %xmm12
4621 ; SSE2-NEXT: pxor %xmm11, %xmm12
4622 ; SSE2-NEXT: pxor %xmm0, %xmm11
4623 ; SSE2-NEXT: pcmpgtd %xmm12, %xmm11
4624 ; SSE2-NEXT: pand %xmm11, %xmm0
4625 ; SSE2-NEXT: pandn %xmm4, %xmm11
4626 ; SSE2-NEXT: por %xmm11, %xmm0
4627 ; SSE2-NEXT: pand %xmm10, %xmm1
4628 ; SSE2-NEXT: pandn %xmm5, %xmm10
4629 ; SSE2-NEXT: por %xmm1, %xmm10
4630 ; SSE2-NEXT: pand %xmm9, %xmm2
4631 ; SSE2-NEXT: pandn %xmm6, %xmm9
4632 ; SSE2-NEXT: por %xmm2, %xmm9
4633 ; SSE2-NEXT: pand %xmm8, %xmm3
4634 ; SSE2-NEXT: pandn %xmm7, %xmm8
4635 ; SSE2-NEXT: por %xmm3, %xmm8
4636 ; SSE2-NEXT: movdqa %xmm10, %xmm1
4637 ; SSE2-NEXT: movdqa %xmm9, %xmm2
4638 ; SSE2-NEXT: movdqa %xmm8, %xmm3
4639 ; SSE2-NEXT: retq
4680 ; SSE2-LABEL: test120:
4681 ; SSE2: # BB#0: # %entry
4682 ; SSE2-NEXT: movdqa %xmm0, %xmm10
4683 ; SSE2-NEXT: movdqa {{.*#+}} xmm14 = [2147483648,2147483648,2147483648,2147483648]
4684 ; SSE2-NEXT: movdqa %xmm3, %xmm0
4685 ; SSE2-NEXT: pxor %xmm14, %xmm0
4686 ; SSE2-NEXT: movdqa %xmm7, %xmm12
4687 ; SSE2-NEXT: pxor %xmm14, %xmm12
4688 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm12
4689 ; SSE2-NEXT: pcmpeqd %xmm0, %xmm0
4690 ; SSE2-NEXT: movdqa %xmm12, %xmm8
4691 ; SSE2-NEXT: pxor %xmm0, %xmm8
4692 ; SSE2-NEXT: movdqa %xmm2, %xmm9
4693 ; SSE2-NEXT: pxor %xmm14, %xmm9
4694 ; SSE2-NEXT: movdqa %xmm6, %xmm13
4695 ; SSE2-NEXT: pxor %xmm14, %xmm13
4696 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm13
4697 ; SSE2-NEXT: movdqa %xmm13, %xmm9
4698 ; SSE2-NEXT: pxor %xmm0, %xmm9
4699 ; SSE2-NEXT: movdqa %xmm1, %xmm11
4700 ; SSE2-NEXT: pxor %xmm14, %xmm11
4701 ; SSE2-NEXT: movdqa %xmm5, %xmm15
4702 ; SSE2-NEXT: pxor %xmm14, %xmm15
4703 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
4704 ; SSE2-NEXT: movdqa %xmm10, %xmm11
4705 ; SSE2-NEXT: pxor %xmm14, %xmm11
4706 ; SSE2-NEXT: pxor %xmm4, %xmm14
4707 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
4708 ; SSE2-NEXT: movdqa %xmm15, %xmm11
4709 ; SSE2-NEXT: pxor %xmm0, %xmm11
4710 ; SSE2-NEXT: pxor %xmm14, %xmm0
4711 ; SSE2-NEXT: pandn %xmm10, %xmm14
4712 ; SSE2-NEXT: pandn %xmm4, %xmm0
4713 ; SSE2-NEXT: por %xmm14, %xmm0
4714 ; SSE2-NEXT: pandn %xmm1, %xmm15
4715 ; SSE2-NEXT: pandn %xmm5, %xmm11
4716 ; SSE2-NEXT: por %xmm15, %xmm11
4717 ; SSE2-NEXT: pandn %xmm2, %xmm13
4718 ; SSE2-NEXT: pandn %xmm6, %xmm9
4719 ; SSE2-NEXT: por %xmm13, %xmm9
4720 ; SSE2-NEXT: pandn %xmm3, %xmm12
4721 ; SSE2-NEXT: pandn %xmm7, %xmm8
4722 ; SSE2-NEXT: por %xmm12, %xmm8
4723 ; SSE2-NEXT: movdqa %xmm11, %xmm1
4724 ; SSE2-NEXT: movdqa %xmm9, %xmm2
4725 ; SSE2-NEXT: movdqa %xmm8, %xmm3
4726 ; SSE2-NEXT: retq
4767 ; SSE2-LABEL: test121:
4768 ; SSE2: # BB#0: # %entry
4769 ; SSE2-NEXT: movdqa {{.*#+}} xmm9 = [2147483648,0,2147483648,0]
4770 ; SSE2-NEXT: movdqa %xmm3, %xmm8
4771 ; SSE2-NEXT: pxor %xmm9, %xmm8
4772 ; SSE2-NEXT: movdqa %xmm7, %xmm10
4773 ; SSE2-NEXT: pxor %xmm9, %xmm10
4774 ; SSE2-NEXT: movdqa %xmm10, %xmm11
4775 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
4776 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
4777 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm10
4778 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm10[1,1,3,3]
4779 ; SSE2-NEXT: pand %xmm12, %xmm10
4780 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm11[1,1,3,3]
4781 ; SSE2-NEXT: por %xmm10, %xmm8
4782 ; SSE2-NEXT: movdqa %xmm2, %xmm10
4783 ; SSE2-NEXT: pxor %xmm9, %xmm10
4784 ; SSE2-NEXT: movdqa %xmm6, %xmm11
4785 ; SSE2-NEXT: pxor %xmm9, %xmm11
4786 ; SSE2-NEXT: movdqa %xmm11, %xmm12
4787 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm12
4788 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm12[0,0,2,2]
4789 ; SSE2-NEXT: pcmpeqd %xmm10, %xmm11
4790 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm11[1,1,3,3]
4791 ; SSE2-NEXT: pand %xmm13, %xmm11
4792 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm12[1,1,3,3]
4793 ; SSE2-NEXT: por %xmm11, %xmm10
4794 ; SSE2-NEXT: movdqa %xmm1, %xmm11
4795 ; SSE2-NEXT: pxor %xmm9, %xmm11
4796 ; SSE2-NEXT: movdqa %xmm5, %xmm12
4797 ; SSE2-NEXT: pxor %xmm9, %xmm12
4798 ; SSE2-NEXT: movdqa %xmm12, %xmm13
4799 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm13
4800 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
4801 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm12
4802 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm12[1,1,3,3]
4803 ; SSE2-NEXT: pand %xmm14, %xmm11
4804 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm13[1,1,3,3]
4805 ; SSE2-NEXT: por %xmm11, %xmm12
4806 ; SSE2-NEXT: movdqa %xmm0, %xmm11
4807 ; SSE2-NEXT: pxor %xmm9, %xmm11
4808 ; SSE2-NEXT: pxor %xmm4, %xmm9
4809 ; SSE2-NEXT: movdqa %xmm9, %xmm13
4810 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm13
4811 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
4812 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm9
4813 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm9[1,1,3,3]
4814 ; SSE2-NEXT: pand %xmm14, %xmm9
4815 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
4816 ; SSE2-NEXT: por %xmm9, %xmm11
4817 ; SSE2-NEXT: pand %xmm11, %xmm0
4818 ; SSE2-NEXT: pandn %xmm4, %xmm11
4819 ; SSE2-NEXT: por %xmm11, %xmm0
4820 ; SSE2-NEXT: pand %xmm12, %xmm1
4821 ; SSE2-NEXT: pandn %xmm5, %xmm12
4822 ; SSE2-NEXT: por %xmm12, %xmm1
4823 ; SSE2-NEXT: pand %xmm10, %xmm2
4824 ; SSE2-NEXT: pandn %xmm6, %xmm10
4825 ; SSE2-NEXT: por %xmm10, %xmm2
4826 ; SSE2-NEXT: pand %xmm8, %xmm3
4827 ; SSE2-NEXT: pandn %xmm7, %xmm8
4828 ; SSE2-NEXT: por %xmm8, %xmm3
4829 ; SSE2-NEXT: retq
4890 ; SSE2-LABEL: test122:
4891 ; SSE2: # BB#0: # %entry
4892 ; SSE2-NEXT: movdqa %xmm7, %xmm8
4893 ; SSE2-NEXT: movdqa %xmm8, -{{[0-9]+}}(%rsp) # 16-byte Spill
4894 ; SSE2-NEXT: movdqa %xmm3, %xmm7
4895 ; SSE2-NEXT: movdqa %xmm2, %xmm3
4896 ; SSE2-NEXT: movdqa %xmm1, %xmm2
4897 ; SSE2-NEXT: movdqa %xmm0, %xmm9
4898 ; SSE2-NEXT: movdqa {{.*#+}} xmm10 = [2147483648,0,2147483648,0]
4899 ; SSE2-NEXT: pxor %xmm10, %xmm8
4900 ; SSE2-NEXT: movdqa %xmm7, %xmm0
4901 ; SSE2-NEXT: pxor %xmm10, %xmm0
4902 ; SSE2-NEXT: movdqa %xmm0, %xmm11
4903 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
4904 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
4905 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm0
4906 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm0[1,1,3,3]
4907 ; SSE2-NEXT: pand %xmm12, %xmm0
4908 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
4909 ; SSE2-NEXT: por %xmm0, %xmm12
4910 ; SSE2-NEXT: pcmpeqd %xmm1, %xmm1
4911 ; SSE2-NEXT: movdqa %xmm12, %xmm8
4912 ; SSE2-NEXT: pxor %xmm1, %xmm8
4913 ; SSE2-NEXT: movdqa %xmm6, %xmm11
4914 ; SSE2-NEXT: pxor %xmm10, %xmm11
4915 ; SSE2-NEXT: movdqa %xmm3, %xmm13
4916 ; SSE2-NEXT: pxor %xmm10, %xmm13
4917 ; SSE2-NEXT: movdqa %xmm13, %xmm14
4918 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
4919 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm14[0,0,2,2]
4920 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm13
4921 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
4922 ; SSE2-NEXT: pand %xmm15, %xmm11
4923 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm14[1,1,3,3]
4924 ; SSE2-NEXT: por %xmm11, %xmm13
4925 ; SSE2-NEXT: movdqa %xmm5, %xmm11
4926 ; SSE2-NEXT: pxor %xmm10, %xmm11
4927 ; SSE2-NEXT: movdqa %xmm2, %xmm14
4928 ; SSE2-NEXT: pxor %xmm10, %xmm14
4929 ; SSE2-NEXT: movdqa %xmm14, %xmm15
4930 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
4931 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm14
4932 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm15[0,0,2,2]
4933 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
4934 ; SSE2-NEXT: pand %xmm11, %xmm14
4935 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm15[1,1,3,3]
4936 ; SSE2-NEXT: por %xmm14, %xmm15
4937 ; SSE2-NEXT: movdqa %xmm4, %xmm11
4938 ; SSE2-NEXT: pxor %xmm10, %xmm11
4939 ; SSE2-NEXT: pxor %xmm9, %xmm10
4940 ; SSE2-NEXT: movdqa %xmm10, %xmm14
4941 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
4942 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm10
4943 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm14[0,0,2,2]
4944 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm10[1,1,3,3]
4945 ; SSE2-NEXT: pand %xmm11, %xmm0
4946 ; SSE2-NEXT: movdqa %xmm13, %xmm10
4947 ; SSE2-NEXT: pxor %xmm1, %xmm10
4948 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
4949 ; SSE2-NEXT: por %xmm0, %xmm14
4950 ; SSE2-NEXT: movdqa %xmm15, %xmm11
4951 ; SSE2-NEXT: pxor %xmm1, %xmm11
4952 ; SSE2-NEXT: pxor %xmm14, %xmm1
4953 ; SSE2-NEXT: pandn %xmm9, %xmm14
4954 ; SSE2-NEXT: pandn %xmm4, %xmm1
4955 ; SSE2-NEXT: por %xmm14, %xmm1
4956 ; SSE2-NEXT: pandn %xmm2, %xmm15
4957 ; SSE2-NEXT: pandn %xmm5, %xmm11
4958 ; SSE2-NEXT: por %xmm15, %xmm11
4959 ; SSE2-NEXT: pandn %xmm3, %xmm13
4960 ; SSE2-NEXT: pandn %xmm6, %xmm10
4961 ; SSE2-NEXT: por %xmm13, %xmm10
4962 ; SSE2-NEXT: pandn %xmm7, %xmm12
4963 ; SSE2-NEXT: pandn -{{[0-9]+}}(%rsp), %xmm8 # 16-byte Folded Reload
4964 ; SSE2-NEXT: por %xmm12, %xmm8
4965 ; SSE2-NEXT: movdqa %xmm1, %xmm0
4966 ; SSE2-NEXT: movdqa %xmm11, %xmm1
4967 ; SSE2-NEXT: movdqa %xmm10, %xmm2
4968 ; SSE2-NEXT: movdqa %xmm8, %xmm3
4969 ; SSE2-NEXT: retq
5042 ; SSE2-LABEL: test123:
5043 ; SSE2: # BB#0: # %entry
5044 ; SSE2-NEXT: movdqa {{.*#+}} xmm9 = [2147483648,0,2147483648,0]
5045 ; SSE2-NEXT: movdqa %xmm7, %xmm8
5046 ; SSE2-NEXT: pxor %xmm9, %xmm8
5047 ; SSE2-NEXT: movdqa %xmm3, %xmm10
5048 ; SSE2-NEXT: pxor %xmm9, %xmm10
5049 ; SSE2-NEXT: movdqa %xmm10, %xmm11
5050 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
5051 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
5052 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm10
5053 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm10[1,1,3,3]
5054 ; SSE2-NEXT: pand %xmm12, %xmm10
5055 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm11[1,1,3,3]
5056 ; SSE2-NEXT: por %xmm10, %xmm8
5057 ; SSE2-NEXT: movdqa %xmm6, %xmm10
5058 ; SSE2-NEXT: pxor %xmm9, %xmm10
5059 ; SSE2-NEXT: movdqa %xmm2, %xmm11
5060 ; SSE2-NEXT: pxor %xmm9, %xmm11
5061 ; SSE2-NEXT: movdqa %xmm11, %xmm12
5062 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm12
5063 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm12[0,0,2,2]
5064 ; SSE2-NEXT: pcmpeqd %xmm10, %xmm11
5065 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm11[1,1,3,3]
5066 ; SSE2-NEXT: pand %xmm13, %xmm11
5067 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm12[1,1,3,3]
5068 ; SSE2-NEXT: por %xmm11, %xmm10
5069 ; SSE2-NEXT: movdqa %xmm5, %xmm11
5070 ; SSE2-NEXT: pxor %xmm9, %xmm11
5071 ; SSE2-NEXT: movdqa %xmm1, %xmm12
5072 ; SSE2-NEXT: pxor %xmm9, %xmm12
5073 ; SSE2-NEXT: movdqa %xmm12, %xmm13
5074 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm13
5075 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
5076 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm12
5077 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm12[1,1,3,3]
5078 ; SSE2-NEXT: pand %xmm14, %xmm11
5079 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm13[1,1,3,3]
5080 ; SSE2-NEXT: por %xmm11, %xmm12
5081 ; SSE2-NEXT: movdqa %xmm4, %xmm11
5082 ; SSE2-NEXT: pxor %xmm9, %xmm11
5083 ; SSE2-NEXT: pxor %xmm0, %xmm9
5084 ; SSE2-NEXT: movdqa %xmm9, %xmm13
5085 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm13
5086 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
5087 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm9
5088 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm9[1,1,3,3]
5089 ; SSE2-NEXT: pand %xmm14, %xmm9
5090 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
5091 ; SSE2-NEXT: por %xmm9, %xmm11
5092 ; SSE2-NEXT: pand %xmm11, %xmm0
5093 ; SSE2-NEXT: pandn %xmm4, %xmm11
5094 ; SSE2-NEXT: por %xmm11, %xmm0
5095 ; SSE2-NEXT: pand %xmm12, %xmm1
5096 ; SSE2-NEXT: pandn %xmm5, %xmm12
5097 ; SSE2-NEXT: por %xmm12, %xmm1
5098 ; SSE2-NEXT: pand %xmm10, %xmm2
5099 ; SSE2-NEXT: pandn %xmm6, %xmm10
5100 ; SSE2-NEXT: por %xmm10, %xmm2
5101 ; SSE2-NEXT: pand %xmm8, %xmm3
5102 ; SSE2-NEXT: pandn %xmm7, %xmm8
5103 ; SSE2-NEXT: por %xmm8, %xmm3
5104 ; SSE2-NEXT: retq
5164 ; SSE2-LABEL: test124:
5165 ; SSE2: # BB#0: # %entry
5166 ; SSE2-NEXT: movdqa %xmm7, %xmm11
5167 ; SSE2-NEXT: movdqa %xmm11, -{{[0-9]+}}(%rsp) # 16-byte Spill
5168 ; SSE2-NEXT: movdqa %xmm3, %xmm7
5169 ; SSE2-NEXT: movdqa %xmm2, %xmm3
5170 ; SSE2-NEXT: movdqa %xmm1, %xmm2
5171 ; SSE2-NEXT: movdqa %xmm0, %xmm9
5172 ; SSE2-NEXT: movdqa {{.*#+}} xmm10 = [2147483648,0,2147483648,0]
5173 ; SSE2-NEXT: movdqa %xmm7, %xmm8
5174 ; SSE2-NEXT: pxor %xmm10, %xmm8
5175 ; SSE2-NEXT: movdqa %xmm11, %xmm0
5176 ; SSE2-NEXT: pxor %xmm10, %xmm0
5177 ; SSE2-NEXT: movdqa %xmm0, %xmm11
5178 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
5179 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
5180 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm0
5181 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm0[1,1,3,3]
5182 ; SSE2-NEXT: pand %xmm12, %xmm0
5183 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
5184 ; SSE2-NEXT: por %xmm0, %xmm12
5185 ; SSE2-NEXT: pcmpeqd %xmm1, %xmm1
5186 ; SSE2-NEXT: movdqa %xmm12, %xmm8
5187 ; SSE2-NEXT: pxor %xmm1, %xmm8
5188 ; SSE2-NEXT: movdqa %xmm3, %xmm11
5189 ; SSE2-NEXT: pxor %xmm10, %xmm11
5190 ; SSE2-NEXT: movdqa %xmm6, %xmm13
5191 ; SSE2-NEXT: pxor %xmm10, %xmm13
5192 ; SSE2-NEXT: movdqa %xmm13, %xmm14
5193 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
5194 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm14[0,0,2,2]
5195 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm13
5196 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
5197 ; SSE2-NEXT: pand %xmm15, %xmm11
5198 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm14[1,1,3,3]
5199 ; SSE2-NEXT: por %xmm11, %xmm13
5200 ; SSE2-NEXT: movdqa %xmm2, %xmm11
5201 ; SSE2-NEXT: pxor %xmm10, %xmm11
5202 ; SSE2-NEXT: movdqa %xmm5, %xmm14
5203 ; SSE2-NEXT: pxor %xmm10, %xmm14
5204 ; SSE2-NEXT: movdqa %xmm14, %xmm15
5205 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
5206 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm14
5207 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm15[0,0,2,2]
5208 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
5209 ; SSE2-NEXT: pand %xmm11, %xmm14
5210 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm15[1,1,3,3]
5211 ; SSE2-NEXT: por %xmm14, %xmm15
5212 ; SSE2-NEXT: movdqa %xmm9, %xmm11
5213 ; SSE2-NEXT: pxor %xmm10, %xmm11
5214 ; SSE2-NEXT: pxor %xmm4, %xmm10
5215 ; SSE2-NEXT: movdqa %xmm10, %xmm14
5216 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
5217 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm10
5218 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm14[0,0,2,2]
5219 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm10[1,1,3,3]
5220 ; SSE2-NEXT: pand %xmm11, %xmm0
5221 ; SSE2-NEXT: movdqa %xmm13, %xmm10
5222 ; SSE2-NEXT: pxor %xmm1, %xmm10
5223 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
5224 ; SSE2-NEXT: por %xmm0, %xmm14
5225 ; SSE2-NEXT: movdqa %xmm15, %xmm11
5226 ; SSE2-NEXT: pxor %xmm1, %xmm11
5227 ; SSE2-NEXT: pxor %xmm14, %xmm1
5228 ; SSE2-NEXT: pandn %xmm9, %xmm14
5229 ; SSE2-NEXT: pandn %xmm4, %xmm1
5230 ; SSE2-NEXT: por %xmm14, %xmm1
5231 ; SSE2-NEXT: pandn %xmm2, %xmm15
5232 ; SSE2-NEXT: pandn %xmm5, %xmm11
5233 ; SSE2-NEXT: por %xmm15, %xmm11
5234 ; SSE2-NEXT: pandn %xmm3, %xmm13
5235 ; SSE2-NEXT: pandn %xmm6, %xmm10
5236 ; SSE2-NEXT: por %xmm13, %xmm10
5237 ; SSE2-NEXT: pandn %xmm7, %xmm12
5238 ; SSE2-NEXT: pandn -{{[0-9]+}}(%rsp), %xmm8 # 16-byte Folded Reload
5239 ; SSE2-NEXT: por %xmm12, %xmm8
5240 ; SSE2-NEXT: movdqa %xmm1, %xmm0
5241 ; SSE2-NEXT: movdqa %xmm11, %xmm1
5242 ; SSE2-NEXT: movdqa %xmm10, %xmm2
5243 ; SSE2-NEXT: movdqa %xmm8, %xmm3
5244 ; SSE2-NEXT: retq
5318 ; SSE2-LABEL: test125:
5319 ; SSE2: # BB#0: # %entry
5320 ; SSE2-NEXT: movdqa {{.*#+}} xmm9 = [2147483648,2147483648,2147483648,2147483648]
5321 ; SSE2-NEXT: movdqa %xmm3, %xmm8
5322 ; SSE2-NEXT: pxor %xmm9, %xmm8
5323 ; SSE2-NEXT: movdqa %xmm7, %xmm10
5324 ; SSE2-NEXT: pxor %xmm9, %xmm10
5325 ; SSE2-NEXT: movdqa %xmm10, %xmm11
5326 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
5327 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
5328 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm10
5329 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm10[1,1,3,3]
5330 ; SSE2-NEXT: pand %xmm12, %xmm10
5331 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm11[1,1,3,3]
5332 ; SSE2-NEXT: por %xmm10, %xmm8
5333 ; SSE2-NEXT: movdqa %xmm2, %xmm10
5334 ; SSE2-NEXT: pxor %xmm9, %xmm10
5335 ; SSE2-NEXT: movdqa %xmm6, %xmm11
5336 ; SSE2-NEXT: pxor %xmm9, %xmm11
5337 ; SSE2-NEXT: movdqa %xmm11, %xmm12
5338 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm12
5339 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm12[0,0,2,2]
5340 ; SSE2-NEXT: pcmpeqd %xmm10, %xmm11
5341 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm11[1,1,3,3]
5342 ; SSE2-NEXT: pand %xmm13, %xmm11
5343 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm12[1,1,3,3]
5344 ; SSE2-NEXT: por %xmm11, %xmm10
5345 ; SSE2-NEXT: movdqa %xmm1, %xmm11
5346 ; SSE2-NEXT: pxor %xmm9, %xmm11
5347 ; SSE2-NEXT: movdqa %xmm5, %xmm12
5348 ; SSE2-NEXT: pxor %xmm9, %xmm12
5349 ; SSE2-NEXT: movdqa %xmm12, %xmm13
5350 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm13
5351 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
5352 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm12
5353 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm12[1,1,3,3]
5354 ; SSE2-NEXT: pand %xmm14, %xmm11
5355 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm13[1,1,3,3]
5356 ; SSE2-NEXT: por %xmm11, %xmm12
5357 ; SSE2-NEXT: movdqa %xmm0, %xmm11
5358 ; SSE2-NEXT: pxor %xmm9, %xmm11
5359 ; SSE2-NEXT: pxor %xmm4, %xmm9
5360 ; SSE2-NEXT: movdqa %xmm9, %xmm13
5361 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm13
5362 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
5363 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm9
5364 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm9[1,1,3,3]
5365 ; SSE2-NEXT: pand %xmm14, %xmm9
5366 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
5367 ; SSE2-NEXT: por %xmm9, %xmm11
5368 ; SSE2-NEXT: pand %xmm11, %xmm0
5369 ; SSE2-NEXT: pandn %xmm4, %xmm11
5370 ; SSE2-NEXT: por %xmm11, %xmm0
5371 ; SSE2-NEXT: pand %xmm12, %xmm1
5372 ; SSE2-NEXT: pandn %xmm5, %xmm12
5373 ; SSE2-NEXT: por %xmm12, %xmm1
5374 ; SSE2-NEXT: pand %xmm10, %xmm2
5375 ; SSE2-NEXT: pandn %xmm6, %xmm10
5376 ; SSE2-NEXT: por %xmm10, %xmm2
5377 ; SSE2-NEXT: pand %xmm8, %xmm3
5378 ; SSE2-NEXT: pandn %xmm7, %xmm8
5379 ; SSE2-NEXT: por %xmm8, %xmm3
5380 ; SSE2-NEXT: retq
5467 ; SSE2-LABEL: test126:
5468 ; SSE2: # BB#0: # %entry
5469 ; SSE2-NEXT: movdqa %xmm7, %xmm8
5470 ; SSE2-NEXT: movdqa %xmm8, -{{[0-9]+}}(%rsp) # 16-byte Spill
5471 ; SSE2-NEXT: movdqa %xmm3, %xmm7
5472 ; SSE2-NEXT: movdqa %xmm2, %xmm3
5473 ; SSE2-NEXT: movdqa %xmm1, %xmm2
5474 ; SSE2-NEXT: movdqa %xmm0, %xmm9
5475 ; SSE2-NEXT: movdqa {{.*#+}} xmm10 = [2147483648,2147483648,2147483648,2147483648]
5476 ; SSE2-NEXT: pxor %xmm10, %xmm8
5477 ; SSE2-NEXT: movdqa %xmm7, %xmm0
5478 ; SSE2-NEXT: pxor %xmm10, %xmm0
5479 ; SSE2-NEXT: movdqa %xmm0, %xmm11
5480 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
5481 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
5482 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm0
5483 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm0[1,1,3,3]
5484 ; SSE2-NEXT: pand %xmm12, %xmm0
5485 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
5486 ; SSE2-NEXT: por %xmm0, %xmm12
5487 ; SSE2-NEXT: pcmpeqd %xmm1, %xmm1
5488 ; SSE2-NEXT: movdqa %xmm12, %xmm8
5489 ; SSE2-NEXT: pxor %xmm1, %xmm8
5490 ; SSE2-NEXT: movdqa %xmm6, %xmm11
5491 ; SSE2-NEXT: pxor %xmm10, %xmm11
5492 ; SSE2-NEXT: movdqa %xmm3, %xmm13
5493 ; SSE2-NEXT: pxor %xmm10, %xmm13
5494 ; SSE2-NEXT: movdqa %xmm13, %xmm14
5495 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
5496 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm14[0,0,2,2]
5497 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm13
5498 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
5499 ; SSE2-NEXT: pand %xmm15, %xmm11
5500 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm14[1,1,3,3]
5501 ; SSE2-NEXT: por %xmm11, %xmm13
5502 ; SSE2-NEXT: movdqa %xmm5, %xmm11
5503 ; SSE2-NEXT: pxor %xmm10, %xmm11
5504 ; SSE2-NEXT: movdqa %xmm2, %xmm14
5505 ; SSE2-NEXT: pxor %xmm10, %xmm14
5506 ; SSE2-NEXT: movdqa %xmm14, %xmm15
5507 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
5508 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm14
5509 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm15[0,0,2,2]
5510 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
5511 ; SSE2-NEXT: pand %xmm11, %xmm14
5512 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm15[1,1,3,3]
5513 ; SSE2-NEXT: por %xmm14, %xmm15
5514 ; SSE2-NEXT: movdqa %xmm4, %xmm11
5515 ; SSE2-NEXT: pxor %xmm10, %xmm11
5516 ; SSE2-NEXT: pxor %xmm9, %xmm10
5517 ; SSE2-NEXT: movdqa %xmm10, %xmm14
5518 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
5519 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm10
5520 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm14[0,0,2,2]
5521 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm10[1,1,3,3]
5522 ; SSE2-NEXT: pand %xmm11, %xmm0
5523 ; SSE2-NEXT: movdqa %xmm13, %xmm10
5524 ; SSE2-NEXT: pxor %xmm1, %xmm10
5525 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
5526 ; SSE2-NEXT: por %xmm0, %xmm14
5527 ; SSE2-NEXT: movdqa %xmm15, %xmm11
5528 ; SSE2-NEXT: pxor %xmm1, %xmm11
5529 ; SSE2-NEXT: pxor %xmm14, %xmm1
5530 ; SSE2-NEXT: pandn %xmm9, %xmm14
5531 ; SSE2-NEXT: pandn %xmm4, %xmm1
5532 ; SSE2-NEXT: por %xmm14, %xmm1
5533 ; SSE2-NEXT: pandn %xmm2, %xmm15
5534 ; SSE2-NEXT: pandn %xmm5, %xmm11
5535 ; SSE2-NEXT: por %xmm15, %xmm11
5536 ; SSE2-NEXT: pandn %xmm3, %xmm13
5537 ; SSE2-NEXT: pandn %xmm6, %xmm10
5538 ; SSE2-NEXT: por %xmm13, %xmm10
5539 ; SSE2-NEXT: pandn %xmm7, %xmm12
5540 ; SSE2-NEXT: pandn -{{[0-9]+}}(%rsp), %xmm8 # 16-byte Folded Reload
5541 ; SSE2-NEXT: por %xmm12, %xmm8
5542 ; SSE2-NEXT: movdqa %xmm1, %xmm0
5543 ; SSE2-NEXT: movdqa %xmm11, %xmm1
5544 ; SSE2-NEXT: movdqa %xmm10, %xmm2
5545 ; SSE2-NEXT: movdqa %xmm8, %xmm3
5546 ; SSE2-NEXT: retq
5646 ; SSE2-LABEL: test127:
5647 ; SSE2: # BB#0: # %entry
5648 ; SSE2-NEXT: movdqa {{.*#+}} xmm9 = [2147483648,2147483648,2147483648,2147483648]
5649 ; SSE2-NEXT: movdqa %xmm7, %xmm8
5650 ; SSE2-NEXT: pxor %xmm9, %xmm8
5651 ; SSE2-NEXT: movdqa %xmm3, %xmm10
5652 ; SSE2-NEXT: pxor %xmm9, %xmm10
5653 ; SSE2-NEXT: movdqa %xmm10, %xmm11
5654 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
5655 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
5656 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm10
5657 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm10[1,1,3,3]
5658 ; SSE2-NEXT: pand %xmm12, %xmm10
5659 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm11[1,1,3,3]
5660 ; SSE2-NEXT: por %xmm10, %xmm8
5661 ; SSE2-NEXT: movdqa %xmm6, %xmm10
5662 ; SSE2-NEXT: pxor %xmm9, %xmm10
5663 ; SSE2-NEXT: movdqa %xmm2, %xmm11
5664 ; SSE2-NEXT: pxor %xmm9, %xmm11
5665 ; SSE2-NEXT: movdqa %xmm11, %xmm12
5666 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm12
5667 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm12[0,0,2,2]
5668 ; SSE2-NEXT: pcmpeqd %xmm10, %xmm11
5669 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm11[1,1,3,3]
5670 ; SSE2-NEXT: pand %xmm13, %xmm11
5671 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm12[1,1,3,3]
5672 ; SSE2-NEXT: por %xmm11, %xmm10
5673 ; SSE2-NEXT: movdqa %xmm5, %xmm11
5674 ; SSE2-NEXT: pxor %xmm9, %xmm11
5675 ; SSE2-NEXT: movdqa %xmm1, %xmm12
5676 ; SSE2-NEXT: pxor %xmm9, %xmm12
5677 ; SSE2-NEXT: movdqa %xmm12, %xmm13
5678 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm13
5679 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
5680 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm12
5681 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm12[1,1,3,3]
5682 ; SSE2-NEXT: pand %xmm14, %xmm11
5683 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm13[1,1,3,3]
5684 ; SSE2-NEXT: por %xmm11, %xmm12
5685 ; SSE2-NEXT: movdqa %xmm4, %xmm11
5686 ; SSE2-NEXT: pxor %xmm9, %xmm11
5687 ; SSE2-NEXT: pxor %xmm0, %xmm9
5688 ; SSE2-NEXT: movdqa %xmm9, %xmm13
5689 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm13
5690 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
5691 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm9
5692 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm9[1,1,3,3]
5693 ; SSE2-NEXT: pand %xmm14, %xmm9
5694 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
5695 ; SSE2-NEXT: por %xmm9, %xmm11
5696 ; SSE2-NEXT: pand %xmm11, %xmm0
5697 ; SSE2-NEXT: pandn %xmm4, %xmm11
5698 ; SSE2-NEXT: por %xmm11, %xmm0
5699 ; SSE2-NEXT: pand %xmm12, %xmm1
5700 ; SSE2-NEXT: pandn %xmm5, %xmm12
5701 ; SSE2-NEXT: por %xmm12, %xmm1
5702 ; SSE2-NEXT: pand %xmm10, %xmm2
5703 ; SSE2-NEXT: pandn %xmm6, %xmm10
5704 ; SSE2-NEXT: por %xmm10, %xmm2
5705 ; SSE2-NEXT: pand %xmm8, %xmm3
5706 ; SSE2-NEXT: pandn %xmm7, %xmm8
5707 ; SSE2-NEXT: por %xmm8, %xmm3
5708 ; SSE2-NEXT: retq
5795 ; SSE2-LABEL: test128:
5796 ; SSE2: # BB#0: # %entry
5797 ; SSE2-NEXT: movdqa %xmm7, %xmm11
5798 ; SSE2-NEXT: movdqa %xmm11, -{{[0-9]+}}(%rsp) # 16-byte Spill
5799 ; SSE2-NEXT: movdqa %xmm3, %xmm7
5800 ; SSE2-NEXT: movdqa %xmm2, %xmm3
5801 ; SSE2-NEXT: movdqa %xmm1, %xmm2
5802 ; SSE2-NEXT: movdqa %xmm0, %xmm9
5803 ; SSE2-NEXT: movdqa {{.*#+}} xmm10 = [2147483648,2147483648,2147483648,2147483648]
5804 ; SSE2-NEXT: movdqa %xmm7, %xmm8
5805 ; SSE2-NEXT: pxor %xmm10, %xmm8
5806 ; SSE2-NEXT: movdqa %xmm11, %xmm0
5807 ; SSE2-NEXT: pxor %xmm10, %xmm0
5808 ; SSE2-NEXT: movdqa %xmm0, %xmm11
5809 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
5810 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
5811 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm0
5812 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm0[1,1,3,3]
5813 ; SSE2-NEXT: pand %xmm12, %xmm0
5814 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
5815 ; SSE2-NEXT: por %xmm0, %xmm12
5816 ; SSE2-NEXT: pcmpeqd %xmm1, %xmm1
5817 ; SSE2-NEXT: movdqa %xmm12, %xmm8
5818 ; SSE2-NEXT: pxor %xmm1, %xmm8
5819 ; SSE2-NEXT: movdqa %xmm3, %xmm11
5820 ; SSE2-NEXT: pxor %xmm10, %xmm11
5821 ; SSE2-NEXT: movdqa %xmm6, %xmm13
5822 ; SSE2-NEXT: pxor %xmm10, %xmm13
5823 ; SSE2-NEXT: movdqa %xmm13, %xmm14
5824 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
5825 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm14[0,0,2,2]
5826 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm13
5827 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
5828 ; SSE2-NEXT: pand %xmm15, %xmm11
5829 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm14[1,1,3,3]
5830 ; SSE2-NEXT: por %xmm11, %xmm13
5831 ; SSE2-NEXT: movdqa %xmm2, %xmm11
5832 ; SSE2-NEXT: pxor %xmm10, %xmm11
5833 ; SSE2-NEXT: movdqa %xmm5, %xmm14
5834 ; SSE2-NEXT: pxor %xmm10, %xmm14
5835 ; SSE2-NEXT: movdqa %xmm14, %xmm15
5836 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
5837 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm14
5838 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm15[0,0,2,2]
5839 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
5840 ; SSE2-NEXT: pand %xmm11, %xmm14
5841 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm15[1,1,3,3]
5842 ; SSE2-NEXT: por %xmm14, %xmm15
5843 ; SSE2-NEXT: movdqa %xmm9, %xmm11
5844 ; SSE2-NEXT: pxor %xmm10, %xmm11
5845 ; SSE2-NEXT: pxor %xmm4, %xmm10
5846 ; SSE2-NEXT: movdqa %xmm10, %xmm14
5847 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
5848 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm10
5849 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm14[0,0,2,2]
5850 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm10[1,1,3,3]
5851 ; SSE2-NEXT: pand %xmm11, %xmm0
5852 ; SSE2-NEXT: movdqa %xmm13, %xmm10
5853 ; SSE2-NEXT: pxor %xmm1, %xmm10
5854 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
5855 ; SSE2-NEXT: por %xmm0, %xmm14
5856 ; SSE2-NEXT: movdqa %xmm15, %xmm11
5857 ; SSE2-NEXT: pxor %xmm1, %xmm11
5858 ; SSE2-NEXT: pxor %xmm14, %xmm1
5859 ; SSE2-NEXT: pandn %xmm9, %xmm14
5860 ; SSE2-NEXT: pandn %xmm4, %xmm1
5861 ; SSE2-NEXT: por %xmm14, %xmm1
5862 ; SSE2-NEXT: pandn %xmm2, %xmm15
5863 ; SSE2-NEXT: pandn %xmm5, %xmm11
5864 ; SSE2-NEXT: por %xmm15, %xmm11
5865 ; SSE2-NEXT: pandn %xmm3, %xmm13
5866 ; SSE2-NEXT: pandn %xmm6, %xmm10
5867 ; SSE2-NEXT: por %xmm13, %xmm10
5868 ; SSE2-NEXT: pandn %xmm7, %xmm12
5869 ; SSE2-NEXT: pandn -{{[0-9]+}}(%rsp), %xmm8 # 16-byte Folded Reload
5870 ; SSE2-NEXT: por %xmm12, %xmm8
5871 ; SSE2-NEXT: movdqa %xmm1, %xmm0
5872 ; SSE2-NEXT: movdqa %xmm11, %xmm1
5873 ; SSE2-NEXT: movdqa %xmm10, %xmm2
5874 ; SSE2-NEXT: movdqa %xmm8, %xmm3
5875 ; SSE2-NEXT: retq
5975 ; SSE2-LABEL: test129:
5976 ; SSE2: # BB#0: # %entry
5977 ; SSE2-NEXT: movdqa %xmm3, %xmm8
5978 ; SSE2-NEXT: movdqa %xmm7, %xmm3
5979 ; SSE2-NEXT: pcmpgtb %xmm8, %xmm3
5980 ; SSE2-NEXT: movdqa %xmm6, %xmm9
5981 ; SSE2-NEXT: pcmpgtb %xmm2, %xmm9
5982 ; SSE2-NEXT: movdqa %xmm5, %xmm10
5983 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm10
5984 ; SSE2-NEXT: movdqa %xmm4, %xmm11
5985 ; SSE2-NEXT: pcmpgtb %xmm0, %xmm11
5986 ; SSE2-NEXT: pand %xmm11, %xmm4
5987 ; SSE2-NEXT: pandn %xmm0, %xmm11
5988 ; SSE2-NEXT: por %xmm4, %xmm11
5989 ; SSE2-NEXT: pand %xmm10, %xmm5
5990 ; SSE2-NEXT: pandn %xmm1, %xmm10
5991 ; SSE2-NEXT: por %xmm5, %xmm10
5992 ; SSE2-NEXT: pand %xmm9, %xmm6
5993 ; SSE2-NEXT: pandn %xmm2, %xmm9
5994 ; SSE2-NEXT: por %xmm6, %xmm9
5995 ; SSE2-NEXT: pand %xmm3, %xmm7
5996 ; SSE2-NEXT: pandn %xmm8, %xmm3
5997 ; SSE2-NEXT: por %xmm7, %xmm3
5998 ; SSE2-NEXT: movdqa %xmm11, %xmm0
5999 ; SSE2-NEXT: movdqa %xmm10, %xmm1
6000 ; SSE2-NEXT: movdqa %xmm9, %xmm2
6001 ; SSE2-NEXT: retq
6042 ; SSE2-LABEL: test130:
6043 ; SSE2: # BB#0: # %entry
6044 ; SSE2-NEXT: movdqa %xmm2, %xmm8
6045 ; SSE2-NEXT: movdqa %xmm3, %xmm12
6046 ; SSE2-NEXT: pcmpgtb %xmm7, %xmm12
6047 ; SSE2-NEXT: pcmpeqd %xmm13, %xmm13
6048 ; SSE2-NEXT: movdqa %xmm12, %xmm9
6049 ; SSE2-NEXT: pxor %xmm13, %xmm9
6050 ; SSE2-NEXT: movdqa %xmm8, %xmm14
6051 ; SSE2-NEXT: pcmpgtb %xmm6, %xmm14
6052 ; SSE2-NEXT: movdqa %xmm14, %xmm2
6053 ; SSE2-NEXT: pxor %xmm13, %xmm2
6054 ; SSE2-NEXT: movdqa %xmm1, %xmm15
6055 ; SSE2-NEXT: pcmpgtb %xmm5, %xmm15
6056 ; SSE2-NEXT: movdqa %xmm15, %xmm10
6057 ; SSE2-NEXT: pxor %xmm13, %xmm10
6058 ; SSE2-NEXT: movdqa %xmm0, %xmm11
6059 ; SSE2-NEXT: pcmpgtb %xmm4, %xmm11
6060 ; SSE2-NEXT: pxor %xmm11, %xmm13
6061 ; SSE2-NEXT: pandn %xmm4, %xmm11
6062 ; SSE2-NEXT: pandn %xmm0, %xmm13
6063 ; SSE2-NEXT: por %xmm13, %xmm11
6064 ; SSE2-NEXT: pandn %xmm5, %xmm15
6065 ; SSE2-NEXT: pandn %xmm1, %xmm10
6066 ; SSE2-NEXT: por %xmm15, %xmm10
6067 ; SSE2-NEXT: pandn %xmm6, %xmm14
6068 ; SSE2-NEXT: pandn %xmm8, %xmm2
6069 ; SSE2-NEXT: por %xmm14, %xmm2
6070 ; SSE2-NEXT: pandn %xmm7, %xmm12
6071 ; SSE2-NEXT: pandn %xmm3, %xmm9
6072 ; SSE2-NEXT: por %xmm12, %xmm9
6073 ; SSE2-NEXT: movdqa %xmm11, %xmm0
6074 ; SSE2-NEXT: movdqa %xmm10, %xmm1
6075 ; SSE2-NEXT: movdqa %xmm9, %xmm3
6076 ; SSE2-NEXT: retq
6117 ; SSE2-LABEL: test131:
6118 ; SSE2: # BB#0: # %entry
6119 ; SSE2-NEXT: movdqa %xmm3, %xmm8
6120 ; SSE2-NEXT: pcmpgtb %xmm7, %xmm3
6121 ; SSE2-NEXT: movdqa %xmm2, %xmm9
6122 ; SSE2-NEXT: pcmpgtb %xmm6, %xmm9
6123 ; SSE2-NEXT: movdqa %xmm1, %xmm10
6124 ; SSE2-NEXT: pcmpgtb %xmm5, %xmm10
6125 ; SSE2-NEXT: movdqa %xmm0, %xmm11
6126 ; SSE2-NEXT: pcmpgtb %xmm4, %xmm11
6127 ; SSE2-NEXT: pand %xmm11, %xmm4
6128 ; SSE2-NEXT: pandn %xmm0, %xmm11
6129 ; SSE2-NEXT: por %xmm4, %xmm11
6130 ; SSE2-NEXT: pand %xmm10, %xmm5
6131 ; SSE2-NEXT: pandn %xmm1, %xmm10
6132 ; SSE2-NEXT: por %xmm5, %xmm10
6133 ; SSE2-NEXT: pand %xmm9, %xmm6
6134 ; SSE2-NEXT: pandn %xmm2, %xmm9
6135 ; SSE2-NEXT: por %xmm6, %xmm9
6136 ; SSE2-NEXT: pand %xmm3, %xmm7
6137 ; SSE2-NEXT: pandn %xmm8, %xmm3
6138 ; SSE2-NEXT: por %xmm7, %xmm3
6139 ; SSE2-NEXT: movdqa %xmm11, %xmm0
6140 ; SSE2-NEXT: movdqa %xmm10, %xmm1
6141 ; SSE2-NEXT: movdqa %xmm9, %xmm2
6142 ; SSE2-NEXT: retq
6183 ; SSE2-LABEL: test132:
6184 ; SSE2: # BB#0: # %entry
6185 ; SSE2-NEXT: movdqa %xmm2, %xmm8
6186 ; SSE2-NEXT: movdqa %xmm0, %xmm10
6187 ; SSE2-NEXT: movdqa %xmm7, %xmm12
6188 ; SSE2-NEXT: pcmpgtb %xmm3, %xmm12
6189 ; SSE2-NEXT: pcmpeqd %xmm0, %xmm0
6190 ; SSE2-NEXT: movdqa %xmm12, %xmm9
6191 ; SSE2-NEXT: pxor %xmm0, %xmm9
6192 ; SSE2-NEXT: movdqa %xmm6, %xmm13
6193 ; SSE2-NEXT: pcmpgtb %xmm8, %xmm13
6194 ; SSE2-NEXT: movdqa %xmm13, %xmm2
6195 ; SSE2-NEXT: pxor %xmm0, %xmm2
6196 ; SSE2-NEXT: movdqa %xmm5, %xmm14
6197 ; SSE2-NEXT: pcmpgtb %xmm1, %xmm14
6198 ; SSE2-NEXT: movdqa %xmm14, %xmm11
6199 ; SSE2-NEXT: pxor %xmm0, %xmm11
6200 ; SSE2-NEXT: movdqa %xmm4, %xmm15
6201 ; SSE2-NEXT: pcmpgtb %xmm10, %xmm15
6202 ; SSE2-NEXT: pxor %xmm15, %xmm0
6203 ; SSE2-NEXT: pandn %xmm4, %xmm15
6204 ; SSE2-NEXT: pandn %xmm10, %xmm0
6205 ; SSE2-NEXT: por %xmm15, %xmm0
6206 ; SSE2-NEXT: pandn %xmm5, %xmm14
6207 ; SSE2-NEXT: pandn %xmm1, %xmm11
6208 ; SSE2-NEXT: por %xmm14, %xmm11
6209 ; SSE2-NEXT: pandn %xmm6, %xmm13
6210 ; SSE2-NEXT: pandn %xmm8, %xmm2
6211 ; SSE2-NEXT: por %xmm13, %xmm2
6212 ; SSE2-NEXT: pandn %xmm7, %xmm12
6213 ; SSE2-NEXT: pandn %xmm3, %xmm9
6214 ; SSE2-NEXT: por %xmm12, %xmm9
6215 ; SSE2-NEXT: movdqa %xmm11, %xmm1
6216 ; SSE2-NEXT: movdqa %xmm9, %xmm3
6217 ; SSE2-NEXT: retq
6570 ; SSE2-LABEL: test141:
6571 ; SSE2: # BB#0: # %entry
6572 ; SSE2-NEXT: movdqa %xmm0, %xmm11
6573 ; SSE2-NEXT: movdqa {{.*#+}} xmm0 = [32768,32768,32768,32768,32768,32768,32768,32768]
6574 ; SSE2-NEXT: movdqa %xmm3, %xmm9
6575 ; SSE2-NEXT: pxor %xmm0, %xmm9
6576 ; SSE2-NEXT: movdqa %xmm7, %xmm8
6577 ; SSE2-NEXT: pxor %xmm0, %xmm8
6578 ; SSE2-NEXT: pcmpgtw %xmm9, %xmm8
6579 ; SSE2-NEXT: movdqa %xmm2, %xmm10
6580 ; SSE2-NEXT: pxor %xmm0, %xmm10
6581 ; SSE2-NEXT: movdqa %xmm6, %xmm9
6582 ; SSE2-NEXT: pxor %xmm0, %xmm9
6583 ; SSE2-NEXT: pcmpgtw %xmm10, %xmm9
6584 ; SSE2-NEXT: movdqa %xmm1, %xmm12
6585 ; SSE2-NEXT: pxor %xmm0, %xmm12
6586 ; SSE2-NEXT: movdqa %xmm5, %xmm10
6587 ; SSE2-NEXT: pxor %xmm0, %xmm10
6588 ; SSE2-NEXT: pcmpgtw %xmm12, %xmm10
6589 ; SSE2-NEXT: movdqa %xmm11, %xmm12
6590 ; SSE2-NEXT: pxor %xmm0, %xmm12
6591 ; SSE2-NEXT: pxor %xmm4, %xmm0
6592 ; SSE2-NEXT: pcmpgtw %xmm12, %xmm0
6593 ; SSE2-NEXT: pand %xmm0, %xmm4
6594 ; SSE2-NEXT: pandn %xmm11, %xmm0
6595 ; SSE2-NEXT: por %xmm4, %xmm0
6596 ; SSE2-NEXT: pand %xmm10, %xmm5
6597 ; SSE2-NEXT: pandn %xmm1, %xmm10
6598 ; SSE2-NEXT: por %xmm5, %xmm10
6599 ; SSE2-NEXT: pand %xmm9, %xmm6
6600 ; SSE2-NEXT: pandn %xmm2, %xmm9
6601 ; SSE2-NEXT: por %xmm6, %xmm9
6602 ; SSE2-NEXT: pand %xmm8, %xmm7
6603 ; SSE2-NEXT: pandn %xmm3, %xmm8
6604 ; SSE2-NEXT: por %xmm7, %xmm8
6605 ; SSE2-NEXT: movdqa %xmm10, %xmm1
6606 ; SSE2-NEXT: movdqa %xmm9, %xmm2
6607 ; SSE2-NEXT: movdqa %xmm8, %xmm3
6608 ; SSE2-NEXT: retq
6649 ; SSE2-LABEL: test142:
6650 ; SSE2: # BB#0: # %entry
6651 ; SSE2-NEXT: movdqa %xmm3, %xmm8
6652 ; SSE2-NEXT: movdqa %xmm2, %xmm9
6653 ; SSE2-NEXT: movdqa %xmm1, %xmm10
6654 ; SSE2-NEXT: psubusw %xmm7, %xmm3
6655 ; SSE2-NEXT: pxor %xmm12, %xmm12
6656 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm3
6657 ; SSE2-NEXT: psubusw %xmm6, %xmm2
6658 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm2
6659 ; SSE2-NEXT: psubusw %xmm5, %xmm1
6660 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm1
6661 ; SSE2-NEXT: movdqa %xmm0, %xmm11
6662 ; SSE2-NEXT: psubusw %xmm4, %xmm11
6663 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm11
6664 ; SSE2-NEXT: pand %xmm11, %xmm4
6665 ; SSE2-NEXT: pandn %xmm0, %xmm11
6666 ; SSE2-NEXT: por %xmm4, %xmm11
6667 ; SSE2-NEXT: pand %xmm1, %xmm5
6668 ; SSE2-NEXT: pandn %xmm10, %xmm1
6669 ; SSE2-NEXT: por %xmm5, %xmm1
6670 ; SSE2-NEXT: pand %xmm2, %xmm6
6671 ; SSE2-NEXT: pandn %xmm9, %xmm2
6672 ; SSE2-NEXT: por %xmm6, %xmm2
6673 ; SSE2-NEXT: pand %xmm3, %xmm7
6674 ; SSE2-NEXT: pandn %xmm8, %xmm3
6675 ; SSE2-NEXT: por %xmm7, %xmm3
6676 ; SSE2-NEXT: movdqa %xmm11, %xmm0
6677 ; SSE2-NEXT: retq
6718 ; SSE2-LABEL: test143:
6719 ; SSE2: # BB#0: # %entry
6720 ; SSE2-NEXT: movdqa %xmm0, %xmm11
6721 ; SSE2-NEXT: movdqa {{.*#+}} xmm0 = [32768,32768,32768,32768,32768,32768,32768,32768]
6722 ; SSE2-NEXT: movdqa %xmm7, %xmm9
6723 ; SSE2-NEXT: pxor %xmm0, %xmm9
6724 ; SSE2-NEXT: movdqa %xmm3, %xmm8
6725 ; SSE2-NEXT: pxor %xmm0, %xmm8
6726 ; SSE2-NEXT: pcmpgtw %xmm9, %xmm8
6727 ; SSE2-NEXT: movdqa %xmm6, %xmm10
6728 ; SSE2-NEXT: pxor %xmm0, %xmm10
6729 ; SSE2-NEXT: movdqa %xmm2, %xmm9
6730 ; SSE2-NEXT: pxor %xmm0, %xmm9
6731 ; SSE2-NEXT: pcmpgtw %xmm10, %xmm9
6732 ; SSE2-NEXT: movdqa %xmm5, %xmm12
6733 ; SSE2-NEXT: pxor %xmm0, %xmm12
6734 ; SSE2-NEXT: movdqa %xmm1, %xmm10
6735 ; SSE2-NEXT: pxor %xmm0, %xmm10
6736 ; SSE2-NEXT: pcmpgtw %xmm12, %xmm10
6737 ; SSE2-NEXT: movdqa %xmm4, %xmm12
6738 ; SSE2-NEXT: pxor %xmm0, %xmm12
6739 ; SSE2-NEXT: pxor %xmm11, %xmm0
6740 ; SSE2-NEXT: pcmpgtw %xmm12, %xmm0
6741 ; SSE2-NEXT: pand %xmm0, %xmm4
6742 ; SSE2-NEXT: pandn %xmm11, %xmm0
6743 ; SSE2-NEXT: por %xmm4, %xmm0
6744 ; SSE2-NEXT: pand %xmm10, %xmm5
6745 ; SSE2-NEXT: pandn %xmm1, %xmm10
6746 ; SSE2-NEXT: por %xmm5, %xmm10
6747 ; SSE2-NEXT: pand %xmm9, %xmm6
6748 ; SSE2-NEXT: pandn %xmm2, %xmm9
6749 ; SSE2-NEXT: por %xmm6, %xmm9
6750 ; SSE2-NEXT: pand %xmm8, %xmm7
6751 ; SSE2-NEXT: pandn %xmm3, %xmm8
6752 ; SSE2-NEXT: por %xmm7, %xmm8
6753 ; SSE2-NEXT: movdqa %xmm10, %xmm1
6754 ; SSE2-NEXT: movdqa %xmm9, %xmm2
6755 ; SSE2-NEXT: movdqa %xmm8, %xmm3
6756 ; SSE2-NEXT: retq
6797 ; SSE2-LABEL: test144:
6798 ; SSE2: # BB#0: # %entry
6799 ; SSE2-NEXT: movdqa %xmm3, %xmm8
6800 ; SSE2-NEXT: movdqa %xmm2, %xmm9
6801 ; SSE2-NEXT: movdqa %xmm1, %xmm10
6802 ; SSE2-NEXT: movdqa %xmm7, %xmm3
6803 ; SSE2-NEXT: psubusw %xmm8, %xmm3
6804 ; SSE2-NEXT: pxor %xmm12, %xmm12
6805 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm3
6806 ; SSE2-NEXT: movdqa %xmm6, %xmm2
6807 ; SSE2-NEXT: psubusw %xmm9, %xmm2
6808 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm2
6809 ; SSE2-NEXT: movdqa %xmm5, %xmm1
6810 ; SSE2-NEXT: psubusw %xmm10, %xmm1
6811 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm1
6812 ; SSE2-NEXT: movdqa %xmm4, %xmm11
6813 ; SSE2-NEXT: psubusw %xmm0, %xmm11
6814 ; SSE2-NEXT: pcmpeqw %xmm12, %xmm11
6815 ; SSE2-NEXT: pand %xmm11, %xmm4
6816 ; SSE2-NEXT: pandn %xmm0, %xmm11
6817 ; SSE2-NEXT: por %xmm4, %xmm11
6818 ; SSE2-NEXT: pand %xmm1, %xmm5
6819 ; SSE2-NEXT: pandn %xmm10, %xmm1
6820 ; SSE2-NEXT: por %xmm5, %xmm1
6821 ; SSE2-NEXT: pand %xmm2, %xmm6
6822 ; SSE2-NEXT: pandn %xmm9, %xmm2
6823 ; SSE2-NEXT: por %xmm6, %xmm2
6824 ; SSE2-NEXT: pand %xmm3, %xmm7
6825 ; SSE2-NEXT: pandn %xmm8, %xmm3
6826 ; SSE2-NEXT: por %xmm7, %xmm3
6827 ; SSE2-NEXT: movdqa %xmm11, %xmm0
6828 ; SSE2-NEXT: retq
6869 ; SSE2-LABEL: test145:
6870 ; SSE2: # BB#0: # %entry
6871 ; SSE2-NEXT: movdqa %xmm3, %xmm8
6872 ; SSE2-NEXT: movdqa %xmm7, %xmm3
6873 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm3
6874 ; SSE2-NEXT: movdqa %xmm6, %xmm9
6875 ; SSE2-NEXT: pcmpgtd %xmm2, %xmm9
6876 ; SSE2-NEXT: movdqa %xmm5, %xmm10
6877 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm10
6878 ; SSE2-NEXT: movdqa %xmm4, %xmm11
6879 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm11
6880 ; SSE2-NEXT: pand %xmm11, %xmm4
6881 ; SSE2-NEXT: pandn %xmm0, %xmm11
6882 ; SSE2-NEXT: por %xmm4, %xmm11
6883 ; SSE2-NEXT: pand %xmm10, %xmm5
6884 ; SSE2-NEXT: pandn %xmm1, %xmm10
6885 ; SSE2-NEXT: por %xmm5, %xmm10
6886 ; SSE2-NEXT: pand %xmm9, %xmm6
6887 ; SSE2-NEXT: pandn %xmm2, %xmm9
6888 ; SSE2-NEXT: por %xmm6, %xmm9
6889 ; SSE2-NEXT: pand %xmm3, %xmm7
6890 ; SSE2-NEXT: pandn %xmm8, %xmm3
6891 ; SSE2-NEXT: por %xmm7, %xmm3
6892 ; SSE2-NEXT: movdqa %xmm11, %xmm0
6893 ; SSE2-NEXT: movdqa %xmm10, %xmm1
6894 ; SSE2-NEXT: movdqa %xmm9, %xmm2
6895 ; SSE2-NEXT: retq
6936 ; SSE2-LABEL: test146:
6937 ; SSE2: # BB#0: # %entry
6938 ; SSE2-NEXT: movdqa %xmm2, %xmm8
6939 ; SSE2-NEXT: movdqa %xmm3, %xmm12
6940 ; SSE2-NEXT: pcmpgtd %xmm7, %xmm12
6941 ; SSE2-NEXT: pcmpeqd %xmm13, %xmm13
6942 ; SSE2-NEXT: movdqa %xmm12, %xmm9
6943 ; SSE2-NEXT: pxor %xmm13, %xmm9
6944 ; SSE2-NEXT: movdqa %xmm8, %xmm14
6945 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm14
6946 ; SSE2-NEXT: movdqa %xmm14, %xmm2
6947 ; SSE2-NEXT: pxor %xmm13, %xmm2
6948 ; SSE2-NEXT: movdqa %xmm1, %xmm15
6949 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm15
6950 ; SSE2-NEXT: movdqa %xmm15, %xmm10
6951 ; SSE2-NEXT: pxor %xmm13, %xmm10
6952 ; SSE2-NEXT: movdqa %xmm0, %xmm11
6953 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm11
6954 ; SSE2-NEXT: pxor %xmm11, %xmm13
6955 ; SSE2-NEXT: pandn %xmm4, %xmm11
6956 ; SSE2-NEXT: pandn %xmm0, %xmm13
6957 ; SSE2-NEXT: por %xmm13, %xmm11
6958 ; SSE2-NEXT: pandn %xmm5, %xmm15
6959 ; SSE2-NEXT: pandn %xmm1, %xmm10
6960 ; SSE2-NEXT: por %xmm15, %xmm10
6961 ; SSE2-NEXT: pandn %xmm6, %xmm14
6962 ; SSE2-NEXT: pandn %xmm8, %xmm2
6963 ; SSE2-NEXT: por %xmm14, %xmm2
6964 ; SSE2-NEXT: pandn %xmm7, %xmm12
6965 ; SSE2-NEXT: pandn %xmm3, %xmm9
6966 ; SSE2-NEXT: por %xmm12, %xmm9
6967 ; SSE2-NEXT: movdqa %xmm11, %xmm0
6968 ; SSE2-NEXT: movdqa %xmm10, %xmm1
6969 ; SSE2-NEXT: movdqa %xmm9, %xmm3
6970 ; SSE2-NEXT: retq
7011 ; SSE2-LABEL: test147:
7012 ; SSE2: # BB#0: # %entry
7013 ; SSE2-NEXT: movdqa %xmm3, %xmm8
7014 ; SSE2-NEXT: pcmpgtd %xmm7, %xmm3
7015 ; SSE2-NEXT: movdqa %xmm2, %xmm9
7016 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm9
7017 ; SSE2-NEXT: movdqa %xmm1, %xmm10
7018 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm10
7019 ; SSE2-NEXT: movdqa %xmm0, %xmm11
7020 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm11
7021 ; SSE2-NEXT: pand %xmm11, %xmm4
7022 ; SSE2-NEXT: pandn %xmm0, %xmm11
7023 ; SSE2-NEXT: por %xmm4, %xmm11
7024 ; SSE2-NEXT: pand %xmm10, %xmm5
7025 ; SSE2-NEXT: pandn %xmm1, %xmm10
7026 ; SSE2-NEXT: por %xmm5, %xmm10
7027 ; SSE2-NEXT: pand %xmm9, %xmm6
7028 ; SSE2-NEXT: pandn %xmm2, %xmm9
7029 ; SSE2-NEXT: por %xmm6, %xmm9
7030 ; SSE2-NEXT: pand %xmm3, %xmm7
7031 ; SSE2-NEXT: pandn %xmm8, %xmm3
7032 ; SSE2-NEXT: por %xmm7, %xmm3
7033 ; SSE2-NEXT: movdqa %xmm11, %xmm0
7034 ; SSE2-NEXT: movdqa %xmm10, %xmm1
7035 ; SSE2-NEXT: movdqa %xmm9, %xmm2
7036 ; SSE2-NEXT: retq
7077 ; SSE2-LABEL: test148:
7078 ; SSE2: # BB#0: # %entry
7079 ; SSE2-NEXT: movdqa %xmm2, %xmm8
7080 ; SSE2-NEXT: movdqa %xmm0, %xmm10
7081 ; SSE2-NEXT: movdqa %xmm7, %xmm12
7082 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm12
7083 ; SSE2-NEXT: pcmpeqd %xmm0, %xmm0
7084 ; SSE2-NEXT: movdqa %xmm12, %xmm9
7085 ; SSE2-NEXT: pxor %xmm0, %xmm9
7086 ; SSE2-NEXT: movdqa %xmm6, %xmm13
7087 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm13
7088 ; SSE2-NEXT: movdqa %xmm13, %xmm2
7089 ; SSE2-NEXT: pxor %xmm0, %xmm2
7090 ; SSE2-NEXT: movdqa %xmm5, %xmm14
7091 ; SSE2-NEXT: pcmpgtd %xmm1, %xmm14
7092 ; SSE2-NEXT: movdqa %xmm14, %xmm11
7093 ; SSE2-NEXT: pxor %xmm0, %xmm11
7094 ; SSE2-NEXT: movdqa %xmm4, %xmm15
7095 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm15
7096 ; SSE2-NEXT: pxor %xmm15, %xmm0
7097 ; SSE2-NEXT: pandn %xmm4, %xmm15
7098 ; SSE2-NEXT: pandn %xmm10, %xmm0
7099 ; SSE2-NEXT: por %xmm15, %xmm0
7100 ; SSE2-NEXT: pandn %xmm5, %xmm14
7101 ; SSE2-NEXT: pandn %xmm1, %xmm11
7102 ; SSE2-NEXT: por %xmm14, %xmm11
7103 ; SSE2-NEXT: pandn %xmm6, %xmm13
7104 ; SSE2-NEXT: pandn %xmm8, %xmm2
7105 ; SSE2-NEXT: por %xmm13, %xmm2
7106 ; SSE2-NEXT: pandn %xmm7, %xmm12
7107 ; SSE2-NEXT: pandn %xmm3, %xmm9
7108 ; SSE2-NEXT: por %xmm12, %xmm9
7109 ; SSE2-NEXT: movdqa %xmm11, %xmm1
7110 ; SSE2-NEXT: movdqa %xmm9, %xmm3
7111 ; SSE2-NEXT: retq
7152 ; SSE2-LABEL: test149:
7153 ; SSE2: # BB#0: # %entry
7154 ; SSE2-NEXT: movdqa %xmm0, %xmm11
7155 ; SSE2-NEXT: movdqa {{.*#+}} xmm0 = [2147483648,2147483648,2147483648,2147483648]
7156 ; SSE2-NEXT: movdqa %xmm3, %xmm9
7157 ; SSE2-NEXT: pxor %xmm0, %xmm9
7158 ; SSE2-NEXT: movdqa %xmm7, %xmm8
7159 ; SSE2-NEXT: pxor %xmm0, %xmm8
7160 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm8
7161 ; SSE2-NEXT: movdqa %xmm2, %xmm10
7162 ; SSE2-NEXT: pxor %xmm0, %xmm10
7163 ; SSE2-NEXT: movdqa %xmm6, %xmm9
7164 ; SSE2-NEXT: pxor %xmm0, %xmm9
7165 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm9
7166 ; SSE2-NEXT: movdqa %xmm1, %xmm12
7167 ; SSE2-NEXT: pxor %xmm0, %xmm12
7168 ; SSE2-NEXT: movdqa %xmm5, %xmm10
7169 ; SSE2-NEXT: pxor %xmm0, %xmm10
7170 ; SSE2-NEXT: pcmpgtd %xmm12, %xmm10
7171 ; SSE2-NEXT: movdqa %xmm11, %xmm12
7172 ; SSE2-NEXT: pxor %xmm0, %xmm12
7173 ; SSE2-NEXT: pxor %xmm4, %xmm0
7174 ; SSE2-NEXT: pcmpgtd %xmm12, %xmm0
7175 ; SSE2-NEXT: pand %xmm0, %xmm4
7176 ; SSE2-NEXT: pandn %xmm11, %xmm0
7177 ; SSE2-NEXT: por %xmm4, %xmm0
7178 ; SSE2-NEXT: pand %xmm10, %xmm5
7179 ; SSE2-NEXT: pandn %xmm1, %xmm10
7180 ; SSE2-NEXT: por %xmm5, %xmm10
7181 ; SSE2-NEXT: pand %xmm9, %xmm6
7182 ; SSE2-NEXT: pandn %xmm2, %xmm9
7183 ; SSE2-NEXT: por %xmm6, %xmm9
7184 ; SSE2-NEXT: pand %xmm8, %xmm7
7185 ; SSE2-NEXT: pandn %xmm3, %xmm8
7186 ; SSE2-NEXT: por %xmm7, %xmm8
7187 ; SSE2-NEXT: movdqa %xmm10, %xmm1
7188 ; SSE2-NEXT: movdqa %xmm9, %xmm2
7189 ; SSE2-NEXT: movdqa %xmm8, %xmm3
7190 ; SSE2-NEXT: retq
7231 ; SSE2-LABEL: test150:
7232 ; SSE2: # BB#0: # %entry
7233 ; SSE2-NEXT: movdqa %xmm0, %xmm10
7234 ; SSE2-NEXT: movdqa {{.*#+}} xmm14 = [2147483648,2147483648,2147483648,2147483648]
7235 ; SSE2-NEXT: movdqa %xmm7, %xmm0
7236 ; SSE2-NEXT: pxor %xmm14, %xmm0
7237 ; SSE2-NEXT: movdqa %xmm3, %xmm12
7238 ; SSE2-NEXT: pxor %xmm14, %xmm12
7239 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm12
7240 ; SSE2-NEXT: pcmpeqd %xmm0, %xmm0
7241 ; SSE2-NEXT: movdqa %xmm12, %xmm8
7242 ; SSE2-NEXT: pxor %xmm0, %xmm8
7243 ; SSE2-NEXT: movdqa %xmm6, %xmm9
7244 ; SSE2-NEXT: pxor %xmm14, %xmm9
7245 ; SSE2-NEXT: movdqa %xmm2, %xmm13
7246 ; SSE2-NEXT: pxor %xmm14, %xmm13
7247 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm13
7248 ; SSE2-NEXT: movdqa %xmm13, %xmm9
7249 ; SSE2-NEXT: pxor %xmm0, %xmm9
7250 ; SSE2-NEXT: movdqa %xmm5, %xmm11
7251 ; SSE2-NEXT: pxor %xmm14, %xmm11
7252 ; SSE2-NEXT: movdqa %xmm1, %xmm15
7253 ; SSE2-NEXT: pxor %xmm14, %xmm15
7254 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
7255 ; SSE2-NEXT: movdqa %xmm4, %xmm11
7256 ; SSE2-NEXT: pxor %xmm14, %xmm11
7257 ; SSE2-NEXT: pxor %xmm10, %xmm14
7258 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
7259 ; SSE2-NEXT: movdqa %xmm15, %xmm11
7260 ; SSE2-NEXT: pxor %xmm0, %xmm11
7261 ; SSE2-NEXT: pxor %xmm14, %xmm0
7262 ; SSE2-NEXT: pandn %xmm4, %xmm14
7263 ; SSE2-NEXT: pandn %xmm10, %xmm0
7264 ; SSE2-NEXT: por %xmm14, %xmm0
7265 ; SSE2-NEXT: pandn %xmm5, %xmm15
7266 ; SSE2-NEXT: pandn %xmm1, %xmm11
7267 ; SSE2-NEXT: por %xmm15, %xmm11
7268 ; SSE2-NEXT: pandn %xmm6, %xmm13
7269 ; SSE2-NEXT: pandn %xmm2, %xmm9
7270 ; SSE2-NEXT: por %xmm13, %xmm9
7271 ; SSE2-NEXT: pandn %xmm7, %xmm12
7272 ; SSE2-NEXT: pandn %xmm3, %xmm8
7273 ; SSE2-NEXT: por %xmm12, %xmm8
7274 ; SSE2-NEXT: movdqa %xmm11, %xmm1
7275 ; SSE2-NEXT: movdqa %xmm9, %xmm2
7276 ; SSE2-NEXT: movdqa %xmm8, %xmm3
7277 ; SSE2-NEXT: retq
7318 ; SSE2-LABEL: test151:
7319 ; SSE2: # BB#0: # %entry
7320 ; SSE2-NEXT: movdqa %xmm0, %xmm11
7321 ; SSE2-NEXT: movdqa {{.*#+}} xmm0 = [2147483648,2147483648,2147483648,2147483648]
7322 ; SSE2-NEXT: movdqa %xmm7, %xmm9
7323 ; SSE2-NEXT: pxor %xmm0, %xmm9
7324 ; SSE2-NEXT: movdqa %xmm3, %xmm8
7325 ; SSE2-NEXT: pxor %xmm0, %xmm8
7326 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm8
7327 ; SSE2-NEXT: movdqa %xmm6, %xmm10
7328 ; SSE2-NEXT: pxor %xmm0, %xmm10
7329 ; SSE2-NEXT: movdqa %xmm2, %xmm9
7330 ; SSE2-NEXT: pxor %xmm0, %xmm9
7331 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm9
7332 ; SSE2-NEXT: movdqa %xmm5, %xmm12
7333 ; SSE2-NEXT: pxor %xmm0, %xmm12
7334 ; SSE2-NEXT: movdqa %xmm1, %xmm10
7335 ; SSE2-NEXT: pxor %xmm0, %xmm10
7336 ; SSE2-NEXT: pcmpgtd %xmm12, %xmm10
7337 ; SSE2-NEXT: movdqa %xmm4, %xmm12
7338 ; SSE2-NEXT: pxor %xmm0, %xmm12
7339 ; SSE2-NEXT: pxor %xmm11, %xmm0
7340 ; SSE2-NEXT: pcmpgtd %xmm12, %xmm0
7341 ; SSE2-NEXT: pand %xmm0, %xmm4
7342 ; SSE2-NEXT: pandn %xmm11, %xmm0
7343 ; SSE2-NEXT: por %xmm4, %xmm0
7344 ; SSE2-NEXT: pand %xmm10, %xmm5
7345 ; SSE2-NEXT: pandn %xmm1, %xmm10
7346 ; SSE2-NEXT: por %xmm5, %xmm10
7347 ; SSE2-NEXT: pand %xmm9, %xmm6
7348 ; SSE2-NEXT: pandn %xmm2, %xmm9
7349 ; SSE2-NEXT: por %xmm6, %xmm9
7350 ; SSE2-NEXT: pand %xmm8, %xmm7
7351 ; SSE2-NEXT: pandn %xmm3, %xmm8
7352 ; SSE2-NEXT: por %xmm7, %xmm8
7353 ; SSE2-NEXT: movdqa %xmm10, %xmm1
7354 ; SSE2-NEXT: movdqa %xmm9, %xmm2
7355 ; SSE2-NEXT: movdqa %xmm8, %xmm3
7356 ; SSE2-NEXT: retq
7397 ; SSE2-LABEL: test152:
7398 ; SSE2: # BB#0: # %entry
7399 ; SSE2-NEXT: movdqa %xmm0, %xmm10
7400 ; SSE2-NEXT: movdqa {{.*#+}} xmm14 = [2147483648,2147483648,2147483648,2147483648]
7401 ; SSE2-NEXT: movdqa %xmm3, %xmm0
7402 ; SSE2-NEXT: pxor %xmm14, %xmm0
7403 ; SSE2-NEXT: movdqa %xmm7, %xmm12
7404 ; SSE2-NEXT: pxor %xmm14, %xmm12
7405 ; SSE2-NEXT: pcmpgtd %xmm0, %xmm12
7406 ; SSE2-NEXT: pcmpeqd %xmm0, %xmm0
7407 ; SSE2-NEXT: movdqa %xmm12, %xmm8
7408 ; SSE2-NEXT: pxor %xmm0, %xmm8
7409 ; SSE2-NEXT: movdqa %xmm2, %xmm9
7410 ; SSE2-NEXT: pxor %xmm14, %xmm9
7411 ; SSE2-NEXT: movdqa %xmm6, %xmm13
7412 ; SSE2-NEXT: pxor %xmm14, %xmm13
7413 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm13
7414 ; SSE2-NEXT: movdqa %xmm13, %xmm9
7415 ; SSE2-NEXT: pxor %xmm0, %xmm9
7416 ; SSE2-NEXT: movdqa %xmm1, %xmm11
7417 ; SSE2-NEXT: pxor %xmm14, %xmm11
7418 ; SSE2-NEXT: movdqa %xmm5, %xmm15
7419 ; SSE2-NEXT: pxor %xmm14, %xmm15
7420 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
7421 ; SSE2-NEXT: movdqa %xmm10, %xmm11
7422 ; SSE2-NEXT: pxor %xmm14, %xmm11
7423 ; SSE2-NEXT: pxor %xmm4, %xmm14
7424 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
7425 ; SSE2-NEXT: movdqa %xmm15, %xmm11
7426 ; SSE2-NEXT: pxor %xmm0, %xmm11
7427 ; SSE2-NEXT: pxor %xmm14, %xmm0
7428 ; SSE2-NEXT: pandn %xmm4, %xmm14
7429 ; SSE2-NEXT: pandn %xmm10, %xmm0
7430 ; SSE2-NEXT: por %xmm14, %xmm0
7431 ; SSE2-NEXT: pandn %xmm5, %xmm15
7432 ; SSE2-NEXT: pandn %xmm1, %xmm11
7433 ; SSE2-NEXT: por %xmm15, %xmm11
7434 ; SSE2-NEXT: pandn %xmm6, %xmm13
7435 ; SSE2-NEXT: pandn %xmm2, %xmm9
7436 ; SSE2-NEXT: por %xmm13, %xmm9
7437 ; SSE2-NEXT: pandn %xmm7, %xmm12
7438 ; SSE2-NEXT: pandn %xmm3, %xmm8
7439 ; SSE2-NEXT: por %xmm12, %xmm8
7440 ; SSE2-NEXT: movdqa %xmm11, %xmm1
7441 ; SSE2-NEXT: movdqa %xmm9, %xmm2
7442 ; SSE2-NEXT: movdqa %xmm8, %xmm3
7443 ; SSE2-NEXT: retq
7486 ; SSE2-LABEL: test153:
7487 ; SSE2: # BB#0: # %entry
7488 ; SSE2-NEXT: movdqa {{.*#+}} xmm11 = [2147483648,0,2147483648,0]
7489 ; SSE2-NEXT: movdqa %xmm3, %xmm8
7490 ; SSE2-NEXT: pxor %xmm11, %xmm8
7491 ; SSE2-NEXT: movdqa %xmm7, %xmm9
7492 ; SSE2-NEXT: pxor %xmm11, %xmm9
7493 ; SSE2-NEXT: movdqa %xmm9, %xmm10
7494 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm10
7495 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm10[0,0,2,2]
7496 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm9
7497 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm9[1,1,3,3]
7498 ; SSE2-NEXT: pand %xmm12, %xmm9
7499 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm10[1,1,3,3]
7500 ; SSE2-NEXT: por %xmm9, %xmm8
7501 ; SSE2-NEXT: movdqa %xmm2, %xmm9
7502 ; SSE2-NEXT: pxor %xmm11, %xmm9
7503 ; SSE2-NEXT: movdqa %xmm6, %xmm10
7504 ; SSE2-NEXT: pxor %xmm11, %xmm10
7505 ; SSE2-NEXT: movdqa %xmm10, %xmm12
7506 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm12
7507 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm12[0,0,2,2]
7508 ; SSE2-NEXT: pcmpeqd %xmm9, %xmm10
7509 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm10[1,1,3,3]
7510 ; SSE2-NEXT: pand %xmm13, %xmm10
7511 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm12[1,1,3,3]
7512 ; SSE2-NEXT: por %xmm10, %xmm9
7513 ; SSE2-NEXT: movdqa %xmm1, %xmm10
7514 ; SSE2-NEXT: pxor %xmm11, %xmm10
7515 ; SSE2-NEXT: movdqa %xmm5, %xmm12
7516 ; SSE2-NEXT: pxor %xmm11, %xmm12
7517 ; SSE2-NEXT: movdqa %xmm12, %xmm13
7518 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm13
7519 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
7520 ; SSE2-NEXT: pcmpeqd %xmm10, %xmm12
7521 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm12[1,1,3,3]
7522 ; SSE2-NEXT: pand %xmm14, %xmm12
7523 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm13[1,1,3,3]
7524 ; SSE2-NEXT: por %xmm12, %xmm10
7525 ; SSE2-NEXT: movdqa %xmm0, %xmm12
7526 ; SSE2-NEXT: pxor %xmm11, %xmm12
7527 ; SSE2-NEXT: pxor %xmm4, %xmm11
7528 ; SSE2-NEXT: movdqa %xmm11, %xmm13
7529 ; SSE2-NEXT: pcmpgtd %xmm12, %xmm13
7530 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
7531 ; SSE2-NEXT: pcmpeqd %xmm12, %xmm11
7532 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
7533 ; SSE2-NEXT: pand %xmm14, %xmm12
7534 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
7535 ; SSE2-NEXT: por %xmm12, %xmm11
7536 ; SSE2-NEXT: pand %xmm11, %xmm4
7537 ; SSE2-NEXT: pandn %xmm0, %xmm11
7538 ; SSE2-NEXT: por %xmm4, %xmm11
7539 ; SSE2-NEXT: pand %xmm10, %xmm5
7540 ; SSE2-NEXT: pandn %xmm1, %xmm10
7541 ; SSE2-NEXT: por %xmm5, %xmm10
7542 ; SSE2-NEXT: pand %xmm9, %xmm6
7543 ; SSE2-NEXT: pandn %xmm2, %xmm9
7544 ; SSE2-NEXT: por %xmm6, %xmm9
7545 ; SSE2-NEXT: pand %xmm8, %xmm7
7546 ; SSE2-NEXT: pandn %xmm3, %xmm8
7547 ; SSE2-NEXT: por %xmm7, %xmm8
7548 ; SSE2-NEXT: movdqa %xmm11, %xmm0
7549 ; SSE2-NEXT: movdqa %xmm10, %xmm1
7550 ; SSE2-NEXT: movdqa %xmm9, %xmm2
7551 ; SSE2-NEXT: movdqa %xmm8, %xmm3
7552 ; SSE2-NEXT: retq
7610 ; SSE2-LABEL: test154:
7611 ; SSE2: # BB#0: # %entry
7612 ; SSE2-NEXT: movdqa %xmm7, %xmm8
7613 ; SSE2-NEXT: movdqa %xmm8, -{{[0-9]+}}(%rsp) # 16-byte Spill
7614 ; SSE2-NEXT: movdqa %xmm3, %xmm7
7615 ; SSE2-NEXT: movdqa %xmm2, %xmm3
7616 ; SSE2-NEXT: movdqa %xmm1, %xmm2
7617 ; SSE2-NEXT: movdqa %xmm0, %xmm9
7618 ; SSE2-NEXT: movdqa {{.*#+}} xmm10 = [2147483648,0,2147483648,0]
7619 ; SSE2-NEXT: pxor %xmm10, %xmm8
7620 ; SSE2-NEXT: movdqa %xmm7, %xmm0
7621 ; SSE2-NEXT: pxor %xmm10, %xmm0
7622 ; SSE2-NEXT: movdqa %xmm0, %xmm11
7623 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
7624 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
7625 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm0
7626 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm0[1,1,3,3]
7627 ; SSE2-NEXT: pand %xmm12, %xmm0
7628 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
7629 ; SSE2-NEXT: por %xmm0, %xmm12
7630 ; SSE2-NEXT: pcmpeqd %xmm1, %xmm1
7631 ; SSE2-NEXT: movdqa %xmm12, %xmm8
7632 ; SSE2-NEXT: pxor %xmm1, %xmm8
7633 ; SSE2-NEXT: movdqa %xmm6, %xmm11
7634 ; SSE2-NEXT: pxor %xmm10, %xmm11
7635 ; SSE2-NEXT: movdqa %xmm3, %xmm13
7636 ; SSE2-NEXT: pxor %xmm10, %xmm13
7637 ; SSE2-NEXT: movdqa %xmm13, %xmm14
7638 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
7639 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm14[0,0,2,2]
7640 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm13
7641 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
7642 ; SSE2-NEXT: pand %xmm15, %xmm11
7643 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm14[1,1,3,3]
7644 ; SSE2-NEXT: por %xmm11, %xmm13
7645 ; SSE2-NEXT: movdqa %xmm5, %xmm11
7646 ; SSE2-NEXT: pxor %xmm10, %xmm11
7647 ; SSE2-NEXT: movdqa %xmm2, %xmm14
7648 ; SSE2-NEXT: pxor %xmm10, %xmm14
7649 ; SSE2-NEXT: movdqa %xmm14, %xmm15
7650 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
7651 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm14
7652 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm15[0,0,2,2]
7653 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
7654 ; SSE2-NEXT: pand %xmm11, %xmm14
7655 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm15[1,1,3,3]
7656 ; SSE2-NEXT: por %xmm14, %xmm15
7657 ; SSE2-NEXT: movdqa %xmm4, %xmm11
7658 ; SSE2-NEXT: pxor %xmm10, %xmm11
7659 ; SSE2-NEXT: pxor %xmm9, %xmm10
7660 ; SSE2-NEXT: movdqa %xmm10, %xmm14
7661 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
7662 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm10
7663 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm14[0,0,2,2]
7664 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm10[1,1,3,3]
7665 ; SSE2-NEXT: pand %xmm11, %xmm0
7666 ; SSE2-NEXT: movdqa %xmm13, %xmm10
7667 ; SSE2-NEXT: pxor %xmm1, %xmm10
7668 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
7669 ; SSE2-NEXT: por %xmm0, %xmm14
7670 ; SSE2-NEXT: movdqa %xmm15, %xmm11
7671 ; SSE2-NEXT: pxor %xmm1, %xmm11
7672 ; SSE2-NEXT: pxor %xmm14, %xmm1
7673 ; SSE2-NEXT: pandn %xmm4, %xmm14
7674 ; SSE2-NEXT: pandn %xmm9, %xmm1
7675 ; SSE2-NEXT: por %xmm14, %xmm1
7676 ; SSE2-NEXT: pandn %xmm5, %xmm15
7677 ; SSE2-NEXT: pandn %xmm2, %xmm11
7678 ; SSE2-NEXT: por %xmm15, %xmm11
7679 ; SSE2-NEXT: pandn %xmm6, %xmm13
7680 ; SSE2-NEXT: pandn %xmm3, %xmm10
7681 ; SSE2-NEXT: por %xmm13, %xmm10
7682 ; SSE2-NEXT: pandn -{{[0-9]+}}(%rsp), %xmm12 # 16-byte Folded Reload
7683 ; SSE2-NEXT: pandn %xmm7, %xmm8
7684 ; SSE2-NEXT: por %xmm12, %xmm8
7685 ; SSE2-NEXT: movdqa %xmm1, %xmm0
7686 ; SSE2-NEXT: movdqa %xmm11, %xmm1
7687 ; SSE2-NEXT: movdqa %xmm10, %xmm2
7688 ; SSE2-NEXT: movdqa %xmm8, %xmm3
7689 ; SSE2-NEXT: retq
7759 ; SSE2-LABEL: test155:
7760 ; SSE2: # BB#0: # %entry
7761 ; SSE2-NEXT: movdqa {{.*#+}} xmm11 = [2147483648,0,2147483648,0]
7762 ; SSE2-NEXT: movdqa %xmm7, %xmm8
7763 ; SSE2-NEXT: pxor %xmm11, %xmm8
7764 ; SSE2-NEXT: movdqa %xmm3, %xmm9
7765 ; SSE2-NEXT: pxor %xmm11, %xmm9
7766 ; SSE2-NEXT: movdqa %xmm9, %xmm10
7767 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm10
7768 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm10[0,0,2,2]
7769 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm9
7770 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm9[1,1,3,3]
7771 ; SSE2-NEXT: pand %xmm12, %xmm9
7772 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm10[1,1,3,3]
7773 ; SSE2-NEXT: por %xmm9, %xmm8
7774 ; SSE2-NEXT: movdqa %xmm6, %xmm9
7775 ; SSE2-NEXT: pxor %xmm11, %xmm9
7776 ; SSE2-NEXT: movdqa %xmm2, %xmm10
7777 ; SSE2-NEXT: pxor %xmm11, %xmm10
7778 ; SSE2-NEXT: movdqa %xmm10, %xmm12
7779 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm12
7780 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm12[0,0,2,2]
7781 ; SSE2-NEXT: pcmpeqd %xmm9, %xmm10
7782 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm10[1,1,3,3]
7783 ; SSE2-NEXT: pand %xmm13, %xmm10
7784 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm12[1,1,3,3]
7785 ; SSE2-NEXT: por %xmm10, %xmm9
7786 ; SSE2-NEXT: movdqa %xmm5, %xmm10
7787 ; SSE2-NEXT: pxor %xmm11, %xmm10
7788 ; SSE2-NEXT: movdqa %xmm1, %xmm12
7789 ; SSE2-NEXT: pxor %xmm11, %xmm12
7790 ; SSE2-NEXT: movdqa %xmm12, %xmm13
7791 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm13
7792 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
7793 ; SSE2-NEXT: pcmpeqd %xmm10, %xmm12
7794 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm12[1,1,3,3]
7795 ; SSE2-NEXT: pand %xmm14, %xmm12
7796 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm13[1,1,3,3]
7797 ; SSE2-NEXT: por %xmm12, %xmm10
7798 ; SSE2-NEXT: movdqa %xmm4, %xmm12
7799 ; SSE2-NEXT: pxor %xmm11, %xmm12
7800 ; SSE2-NEXT: pxor %xmm0, %xmm11
7801 ; SSE2-NEXT: movdqa %xmm11, %xmm13
7802 ; SSE2-NEXT: pcmpgtd %xmm12, %xmm13
7803 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
7804 ; SSE2-NEXT: pcmpeqd %xmm12, %xmm11
7805 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
7806 ; SSE2-NEXT: pand %xmm14, %xmm12
7807 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
7808 ; SSE2-NEXT: por %xmm12, %xmm11
7809 ; SSE2-NEXT: pand %xmm11, %xmm4
7810 ; SSE2-NEXT: pandn %xmm0, %xmm11
7811 ; SSE2-NEXT: por %xmm4, %xmm11
7812 ; SSE2-NEXT: pand %xmm10, %xmm5
7813 ; SSE2-NEXT: pandn %xmm1, %xmm10
7814 ; SSE2-NEXT: por %xmm5, %xmm10
7815 ; SSE2-NEXT: pand %xmm9, %xmm6
7816 ; SSE2-NEXT: pandn %xmm2, %xmm9
7817 ; SSE2-NEXT: por %xmm6, %xmm9
7818 ; SSE2-NEXT: pand %xmm8, %xmm7
7819 ; SSE2-NEXT: pandn %xmm3, %xmm8
7820 ; SSE2-NEXT: por %xmm7, %xmm8
7821 ; SSE2-NEXT: movdqa %xmm11, %xmm0
7822 ; SSE2-NEXT: movdqa %xmm10, %xmm1
7823 ; SSE2-NEXT: movdqa %xmm9, %xmm2
7824 ; SSE2-NEXT: movdqa %xmm8, %xmm3
7825 ; SSE2-NEXT: retq
7882 ; SSE2-LABEL: test156:
7883 ; SSE2: # BB#0: # %entry
7884 ; SSE2-NEXT: movdqa %xmm7, %xmm11
7885 ; SSE2-NEXT: movdqa %xmm11, -{{[0-9]+}}(%rsp) # 16-byte Spill
7886 ; SSE2-NEXT: movdqa %xmm3, %xmm7
7887 ; SSE2-NEXT: movdqa %xmm2, %xmm3
7888 ; SSE2-NEXT: movdqa %xmm1, %xmm2
7889 ; SSE2-NEXT: movdqa %xmm0, %xmm9
7890 ; SSE2-NEXT: movdqa {{.*#+}} xmm10 = [2147483648,0,2147483648,0]
7891 ; SSE2-NEXT: movdqa %xmm7, %xmm8
7892 ; SSE2-NEXT: pxor %xmm10, %xmm8
7893 ; SSE2-NEXT: movdqa %xmm11, %xmm0
7894 ; SSE2-NEXT: pxor %xmm10, %xmm0
7895 ; SSE2-NEXT: movdqa %xmm0, %xmm11
7896 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
7897 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
7898 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm0
7899 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm0[1,1,3,3]
7900 ; SSE2-NEXT: pand %xmm12, %xmm0
7901 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
7902 ; SSE2-NEXT: por %xmm0, %xmm12
7903 ; SSE2-NEXT: pcmpeqd %xmm1, %xmm1
7904 ; SSE2-NEXT: movdqa %xmm12, %xmm8
7905 ; SSE2-NEXT: pxor %xmm1, %xmm8
7906 ; SSE2-NEXT: movdqa %xmm3, %xmm11
7907 ; SSE2-NEXT: pxor %xmm10, %xmm11
7908 ; SSE2-NEXT: movdqa %xmm6, %xmm13
7909 ; SSE2-NEXT: pxor %xmm10, %xmm13
7910 ; SSE2-NEXT: movdqa %xmm13, %xmm14
7911 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
7912 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm14[0,0,2,2]
7913 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm13
7914 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
7915 ; SSE2-NEXT: pand %xmm15, %xmm11
7916 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm14[1,1,3,3]
7917 ; SSE2-NEXT: por %xmm11, %xmm13
7918 ; SSE2-NEXT: movdqa %xmm2, %xmm11
7919 ; SSE2-NEXT: pxor %xmm10, %xmm11
7920 ; SSE2-NEXT: movdqa %xmm5, %xmm14
7921 ; SSE2-NEXT: pxor %xmm10, %xmm14
7922 ; SSE2-NEXT: movdqa %xmm14, %xmm15
7923 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
7924 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm14
7925 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm15[0,0,2,2]
7926 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
7927 ; SSE2-NEXT: pand %xmm11, %xmm14
7928 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm15[1,1,3,3]
7929 ; SSE2-NEXT: por %xmm14, %xmm15
7930 ; SSE2-NEXT: movdqa %xmm9, %xmm11
7931 ; SSE2-NEXT: pxor %xmm10, %xmm11
7932 ; SSE2-NEXT: pxor %xmm4, %xmm10
7933 ; SSE2-NEXT: movdqa %xmm10, %xmm14
7934 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
7935 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm10
7936 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm14[0,0,2,2]
7937 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm10[1,1,3,3]
7938 ; SSE2-NEXT: pand %xmm11, %xmm0
7939 ; SSE2-NEXT: movdqa %xmm13, %xmm10
7940 ; SSE2-NEXT: pxor %xmm1, %xmm10
7941 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
7942 ; SSE2-NEXT: por %xmm0, %xmm14
7943 ; SSE2-NEXT: movdqa %xmm15, %xmm11
7944 ; SSE2-NEXT: pxor %xmm1, %xmm11
7945 ; SSE2-NEXT: pxor %xmm14, %xmm1
7946 ; SSE2-NEXT: pandn %xmm4, %xmm14
7947 ; SSE2-NEXT: pandn %xmm9, %xmm1
7948 ; SSE2-NEXT: por %xmm14, %xmm1
7949 ; SSE2-NEXT: pandn %xmm5, %xmm15
7950 ; SSE2-NEXT: pandn %xmm2, %xmm11
7951 ; SSE2-NEXT: por %xmm15, %xmm11
7952 ; SSE2-NEXT: pandn %xmm6, %xmm13
7953 ; SSE2-NEXT: pandn %xmm3, %xmm10
7954 ; SSE2-NEXT: por %xmm13, %xmm10
7955 ; SSE2-NEXT: pandn -{{[0-9]+}}(%rsp), %xmm12 # 16-byte Folded Reload
7956 ; SSE2-NEXT: pandn %xmm7, %xmm8
7957 ; SSE2-NEXT: por %xmm12, %xmm8
7958 ; SSE2-NEXT: movdqa %xmm1, %xmm0
7959 ; SSE2-NEXT: movdqa %xmm11, %xmm1
7960 ; SSE2-NEXT: movdqa %xmm10, %xmm2
7961 ; SSE2-NEXT: movdqa %xmm8, %xmm3
7962 ; SSE2-NEXT: retq
8033 ; SSE2-LABEL: test157:
8034 ; SSE2: # BB#0: # %entry
8035 ; SSE2-NEXT: movdqa {{.*#+}} xmm11 = [2147483648,2147483648,2147483648,2147483648]
8036 ; SSE2-NEXT: movdqa %xmm3, %xmm8
8037 ; SSE2-NEXT: pxor %xmm11, %xmm8
8038 ; SSE2-NEXT: movdqa %xmm7, %xmm9
8039 ; SSE2-NEXT: pxor %xmm11, %xmm9
8040 ; SSE2-NEXT: movdqa %xmm9, %xmm10
8041 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm10
8042 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm10[0,0,2,2]
8043 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm9
8044 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm9[1,1,3,3]
8045 ; SSE2-NEXT: pand %xmm12, %xmm9
8046 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm10[1,1,3,3]
8047 ; SSE2-NEXT: por %xmm9, %xmm8
8048 ; SSE2-NEXT: movdqa %xmm2, %xmm9
8049 ; SSE2-NEXT: pxor %xmm11, %xmm9
8050 ; SSE2-NEXT: movdqa %xmm6, %xmm10
8051 ; SSE2-NEXT: pxor %xmm11, %xmm10
8052 ; SSE2-NEXT: movdqa %xmm10, %xmm12
8053 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm12
8054 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm12[0,0,2,2]
8055 ; SSE2-NEXT: pcmpeqd %xmm9, %xmm10
8056 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm10[1,1,3,3]
8057 ; SSE2-NEXT: pand %xmm13, %xmm10
8058 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm12[1,1,3,3]
8059 ; SSE2-NEXT: por %xmm10, %xmm9
8060 ; SSE2-NEXT: movdqa %xmm1, %xmm10
8061 ; SSE2-NEXT: pxor %xmm11, %xmm10
8062 ; SSE2-NEXT: movdqa %xmm5, %xmm12
8063 ; SSE2-NEXT: pxor %xmm11, %xmm12
8064 ; SSE2-NEXT: movdqa %xmm12, %xmm13
8065 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm13
8066 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
8067 ; SSE2-NEXT: pcmpeqd %xmm10, %xmm12
8068 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm12[1,1,3,3]
8069 ; SSE2-NEXT: pand %xmm14, %xmm12
8070 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm13[1,1,3,3]
8071 ; SSE2-NEXT: por %xmm12, %xmm10
8072 ; SSE2-NEXT: movdqa %xmm0, %xmm12
8073 ; SSE2-NEXT: pxor %xmm11, %xmm12
8074 ; SSE2-NEXT: pxor %xmm4, %xmm11
8075 ; SSE2-NEXT: movdqa %xmm11, %xmm13
8076 ; SSE2-NEXT: pcmpgtd %xmm12, %xmm13
8077 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
8078 ; SSE2-NEXT: pcmpeqd %xmm12, %xmm11
8079 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
8080 ; SSE2-NEXT: pand %xmm14, %xmm12
8081 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
8082 ; SSE2-NEXT: por %xmm12, %xmm11
8083 ; SSE2-NEXT: pand %xmm11, %xmm4
8084 ; SSE2-NEXT: pandn %xmm0, %xmm11
8085 ; SSE2-NEXT: por %xmm4, %xmm11
8086 ; SSE2-NEXT: pand %xmm10, %xmm5
8087 ; SSE2-NEXT: pandn %xmm1, %xmm10
8088 ; SSE2-NEXT: por %xmm5, %xmm10
8089 ; SSE2-NEXT: pand %xmm9, %xmm6
8090 ; SSE2-NEXT: pandn %xmm2, %xmm9
8091 ; SSE2-NEXT: por %xmm6, %xmm9
8092 ; SSE2-NEXT: pand %xmm8, %xmm7
8093 ; SSE2-NEXT: pandn %xmm3, %xmm8
8094 ; SSE2-NEXT: por %xmm7, %xmm8
8095 ; SSE2-NEXT: movdqa %xmm11, %xmm0
8096 ; SSE2-NEXT: movdqa %xmm10, %xmm1
8097 ; SSE2-NEXT: movdqa %xmm9, %xmm2
8098 ; SSE2-NEXT: movdqa %xmm8, %xmm3
8099 ; SSE2-NEXT: retq
8183 ; SSE2-LABEL: test158:
8184 ; SSE2: # BB#0: # %entry
8185 ; SSE2-NEXT: movdqa %xmm7, %xmm8
8186 ; SSE2-NEXT: movdqa %xmm8, -{{[0-9]+}}(%rsp) # 16-byte Spill
8187 ; SSE2-NEXT: movdqa %xmm3, %xmm7
8188 ; SSE2-NEXT: movdqa %xmm2, %xmm3
8189 ; SSE2-NEXT: movdqa %xmm1, %xmm2
8190 ; SSE2-NEXT: movdqa %xmm0, %xmm9
8191 ; SSE2-NEXT: movdqa {{.*#+}} xmm10 = [2147483648,2147483648,2147483648,2147483648]
8192 ; SSE2-NEXT: pxor %xmm10, %xmm8
8193 ; SSE2-NEXT: movdqa %xmm7, %xmm0
8194 ; SSE2-NEXT: pxor %xmm10, %xmm0
8195 ; SSE2-NEXT: movdqa %xmm0, %xmm11
8196 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
8197 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
8198 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm0
8199 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm0[1,1,3,3]
8200 ; SSE2-NEXT: pand %xmm12, %xmm0
8201 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
8202 ; SSE2-NEXT: por %xmm0, %xmm12
8203 ; SSE2-NEXT: pcmpeqd %xmm1, %xmm1
8204 ; SSE2-NEXT: movdqa %xmm12, %xmm8
8205 ; SSE2-NEXT: pxor %xmm1, %xmm8
8206 ; SSE2-NEXT: movdqa %xmm6, %xmm11
8207 ; SSE2-NEXT: pxor %xmm10, %xmm11
8208 ; SSE2-NEXT: movdqa %xmm3, %xmm13
8209 ; SSE2-NEXT: pxor %xmm10, %xmm13
8210 ; SSE2-NEXT: movdqa %xmm13, %xmm14
8211 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
8212 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm14[0,0,2,2]
8213 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm13
8214 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
8215 ; SSE2-NEXT: pand %xmm15, %xmm11
8216 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm14[1,1,3,3]
8217 ; SSE2-NEXT: por %xmm11, %xmm13
8218 ; SSE2-NEXT: movdqa %xmm5, %xmm11
8219 ; SSE2-NEXT: pxor %xmm10, %xmm11
8220 ; SSE2-NEXT: movdqa %xmm2, %xmm14
8221 ; SSE2-NEXT: pxor %xmm10, %xmm14
8222 ; SSE2-NEXT: movdqa %xmm14, %xmm15
8223 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
8224 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm14
8225 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm15[0,0,2,2]
8226 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
8227 ; SSE2-NEXT: pand %xmm11, %xmm14
8228 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm15[1,1,3,3]
8229 ; SSE2-NEXT: por %xmm14, %xmm15
8230 ; SSE2-NEXT: movdqa %xmm4, %xmm11
8231 ; SSE2-NEXT: pxor %xmm10, %xmm11
8232 ; SSE2-NEXT: pxor %xmm9, %xmm10
8233 ; SSE2-NEXT: movdqa %xmm10, %xmm14
8234 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
8235 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm10
8236 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm14[0,0,2,2]
8237 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm10[1,1,3,3]
8238 ; SSE2-NEXT: pand %xmm11, %xmm0
8239 ; SSE2-NEXT: movdqa %xmm13, %xmm10
8240 ; SSE2-NEXT: pxor %xmm1, %xmm10
8241 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
8242 ; SSE2-NEXT: por %xmm0, %xmm14
8243 ; SSE2-NEXT: movdqa %xmm15, %xmm11
8244 ; SSE2-NEXT: pxor %xmm1, %xmm11
8245 ; SSE2-NEXT: pxor %xmm14, %xmm1
8246 ; SSE2-NEXT: pandn %xmm4, %xmm14
8247 ; SSE2-NEXT: pandn %xmm9, %xmm1
8248 ; SSE2-NEXT: por %xmm14, %xmm1
8249 ; SSE2-NEXT: pandn %xmm5, %xmm15
8250 ; SSE2-NEXT: pandn %xmm2, %xmm11
8251 ; SSE2-NEXT: por %xmm15, %xmm11
8252 ; SSE2-NEXT: pandn %xmm6, %xmm13
8253 ; SSE2-NEXT: pandn %xmm3, %xmm10
8254 ; SSE2-NEXT: por %xmm13, %xmm10
8255 ; SSE2-NEXT: pandn -{{[0-9]+}}(%rsp), %xmm12 # 16-byte Folded Reload
8256 ; SSE2-NEXT: pandn %xmm7, %xmm8
8257 ; SSE2-NEXT: por %xmm12, %xmm8
8258 ; SSE2-NEXT: movdqa %xmm1, %xmm0
8259 ; SSE2-NEXT: movdqa %xmm11, %xmm1
8260 ; SSE2-NEXT: movdqa %xmm10, %xmm2
8261 ; SSE2-NEXT: movdqa %xmm8, %xmm3
8262 ; SSE2-NEXT: retq
8359 ; SSE2-LABEL: test159:
8360 ; SSE2: # BB#0: # %entry
8361 ; SSE2-NEXT: movdqa {{.*#+}} xmm11 = [2147483648,2147483648,2147483648,2147483648]
8362 ; SSE2-NEXT: movdqa %xmm7, %xmm8
8363 ; SSE2-NEXT: pxor %xmm11, %xmm8
8364 ; SSE2-NEXT: movdqa %xmm3, %xmm9
8365 ; SSE2-NEXT: pxor %xmm11, %xmm9
8366 ; SSE2-NEXT: movdqa %xmm9, %xmm10
8367 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm10
8368 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm10[0,0,2,2]
8369 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm9
8370 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm9[1,1,3,3]
8371 ; SSE2-NEXT: pand %xmm12, %xmm9
8372 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm10[1,1,3,3]
8373 ; SSE2-NEXT: por %xmm9, %xmm8
8374 ; SSE2-NEXT: movdqa %xmm6, %xmm9
8375 ; SSE2-NEXT: pxor %xmm11, %xmm9
8376 ; SSE2-NEXT: movdqa %xmm2, %xmm10
8377 ; SSE2-NEXT: pxor %xmm11, %xmm10
8378 ; SSE2-NEXT: movdqa %xmm10, %xmm12
8379 ; SSE2-NEXT: pcmpgtd %xmm9, %xmm12
8380 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm12[0,0,2,2]
8381 ; SSE2-NEXT: pcmpeqd %xmm9, %xmm10
8382 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm10[1,1,3,3]
8383 ; SSE2-NEXT: pand %xmm13, %xmm10
8384 ; SSE2-NEXT: pshufd {{.*#+}} xmm9 = xmm12[1,1,3,3]
8385 ; SSE2-NEXT: por %xmm10, %xmm9
8386 ; SSE2-NEXT: movdqa %xmm5, %xmm10
8387 ; SSE2-NEXT: pxor %xmm11, %xmm10
8388 ; SSE2-NEXT: movdqa %xmm1, %xmm12
8389 ; SSE2-NEXT: pxor %xmm11, %xmm12
8390 ; SSE2-NEXT: movdqa %xmm12, %xmm13
8391 ; SSE2-NEXT: pcmpgtd %xmm10, %xmm13
8392 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
8393 ; SSE2-NEXT: pcmpeqd %xmm10, %xmm12
8394 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm12[1,1,3,3]
8395 ; SSE2-NEXT: pand %xmm14, %xmm12
8396 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm13[1,1,3,3]
8397 ; SSE2-NEXT: por %xmm12, %xmm10
8398 ; SSE2-NEXT: movdqa %xmm4, %xmm12
8399 ; SSE2-NEXT: pxor %xmm11, %xmm12
8400 ; SSE2-NEXT: pxor %xmm0, %xmm11
8401 ; SSE2-NEXT: movdqa %xmm11, %xmm13
8402 ; SSE2-NEXT: pcmpgtd %xmm12, %xmm13
8403 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm13[0,0,2,2]
8404 ; SSE2-NEXT: pcmpeqd %xmm12, %xmm11
8405 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
8406 ; SSE2-NEXT: pand %xmm14, %xmm12
8407 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
8408 ; SSE2-NEXT: por %xmm12, %xmm11
8409 ; SSE2-NEXT: pand %xmm11, %xmm4
8410 ; SSE2-NEXT: pandn %xmm0, %xmm11
8411 ; SSE2-NEXT: por %xmm4, %xmm11
8412 ; SSE2-NEXT: pand %xmm10, %xmm5
8413 ; SSE2-NEXT: pandn %xmm1, %xmm10
8414 ; SSE2-NEXT: por %xmm5, %xmm10
8415 ; SSE2-NEXT: pand %xmm9, %xmm6
8416 ; SSE2-NEXT: pandn %xmm2, %xmm9
8417 ; SSE2-NEXT: por %xmm6, %xmm9
8418 ; SSE2-NEXT: pand %xmm8, %xmm7
8419 ; SSE2-NEXT: pandn %xmm3, %xmm8
8420 ; SSE2-NEXT: por %xmm7, %xmm8
8421 ; SSE2-NEXT: movdqa %xmm11, %xmm0
8422 ; SSE2-NEXT: movdqa %xmm10, %xmm1
8423 ; SSE2-NEXT: movdqa %xmm9, %xmm2
8424 ; SSE2-NEXT: movdqa %xmm8, %xmm3
8425 ; SSE2-NEXT: retq
8509 ; SSE2-LABEL: test160:
8510 ; SSE2: # BB#0: # %entry
8511 ; SSE2-NEXT: movdqa %xmm7, %xmm11
8512 ; SSE2-NEXT: movdqa %xmm11, -{{[0-9]+}}(%rsp) # 16-byte Spill
8513 ; SSE2-NEXT: movdqa %xmm3, %xmm7
8514 ; SSE2-NEXT: movdqa %xmm2, %xmm3
8515 ; SSE2-NEXT: movdqa %xmm1, %xmm2
8516 ; SSE2-NEXT: movdqa %xmm0, %xmm9
8517 ; SSE2-NEXT: movdqa {{.*#+}} xmm10 = [2147483648,2147483648,2147483648,2147483648]
8518 ; SSE2-NEXT: movdqa %xmm7, %xmm8
8519 ; SSE2-NEXT: pxor %xmm10, %xmm8
8520 ; SSE2-NEXT: movdqa %xmm11, %xmm0
8521 ; SSE2-NEXT: pxor %xmm10, %xmm0
8522 ; SSE2-NEXT: movdqa %xmm0, %xmm11
8523 ; SSE2-NEXT: pcmpgtd %xmm8, %xmm11
8524 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[0,0,2,2]
8525 ; SSE2-NEXT: pcmpeqd %xmm8, %xmm0
8526 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm0[1,1,3,3]
8527 ; SSE2-NEXT: pand %xmm12, %xmm0
8528 ; SSE2-NEXT: pshufd {{.*#+}} xmm12 = xmm11[1,1,3,3]
8529 ; SSE2-NEXT: por %xmm0, %xmm12
8530 ; SSE2-NEXT: pcmpeqd %xmm1, %xmm1
8531 ; SSE2-NEXT: movdqa %xmm12, %xmm8
8532 ; SSE2-NEXT: pxor %xmm1, %xmm8
8533 ; SSE2-NEXT: movdqa %xmm3, %xmm11
8534 ; SSE2-NEXT: pxor %xmm10, %xmm11
8535 ; SSE2-NEXT: movdqa %xmm6, %xmm13
8536 ; SSE2-NEXT: pxor %xmm10, %xmm13
8537 ; SSE2-NEXT: movdqa %xmm13, %xmm14
8538 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
8539 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm14[0,0,2,2]
8540 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm13
8541 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm13[1,1,3,3]
8542 ; SSE2-NEXT: pand %xmm15, %xmm11
8543 ; SSE2-NEXT: pshufd {{.*#+}} xmm13 = xmm14[1,1,3,3]
8544 ; SSE2-NEXT: por %xmm11, %xmm13
8545 ; SSE2-NEXT: movdqa %xmm2, %xmm11
8546 ; SSE2-NEXT: pxor %xmm10, %xmm11
8547 ; SSE2-NEXT: movdqa %xmm5, %xmm14
8548 ; SSE2-NEXT: pxor %xmm10, %xmm14
8549 ; SSE2-NEXT: movdqa %xmm14, %xmm15
8550 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm15
8551 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm14
8552 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm15[0,0,2,2]
8553 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
8554 ; SSE2-NEXT: pand %xmm11, %xmm14
8555 ; SSE2-NEXT: pshufd {{.*#+}} xmm15 = xmm15[1,1,3,3]
8556 ; SSE2-NEXT: por %xmm14, %xmm15
8557 ; SSE2-NEXT: movdqa %xmm9, %xmm11
8558 ; SSE2-NEXT: pxor %xmm10, %xmm11
8559 ; SSE2-NEXT: pxor %xmm4, %xmm10
8560 ; SSE2-NEXT: movdqa %xmm10, %xmm14
8561 ; SSE2-NEXT: pcmpgtd %xmm11, %xmm14
8562 ; SSE2-NEXT: pcmpeqd %xmm11, %xmm10
8563 ; SSE2-NEXT: pshufd {{.*#+}} xmm11 = xmm14[0,0,2,2]
8564 ; SSE2-NEXT: pshufd {{.*#+}} xmm0 = xmm10[1,1,3,3]
8565 ; SSE2-NEXT: pand %xmm11, %xmm0
8566 ; SSE2-NEXT: movdqa %xmm13, %xmm10
8567 ; SSE2-NEXT: pxor %xmm1, %xmm10
8568 ; SSE2-NEXT: pshufd {{.*#+}} xmm14 = xmm14[1,1,3,3]
8569 ; SSE2-NEXT: por %xmm0, %xmm14
8570 ; SSE2-NEXT: movdqa %xmm15, %xmm11
8571 ; SSE2-NEXT: pxor %xmm1, %xmm11
8572 ; SSE2-NEXT: pxor %xmm14, %xmm1
8573 ; SSE2-NEXT: pandn %xmm4, %xmm14
8574 ; SSE2-NEXT: pandn %xmm9, %xmm1
8575 ; SSE2-NEXT: por %xmm14, %xmm1
8576 ; SSE2-NEXT: pandn %xmm5, %xmm15
8577 ; SSE2-NEXT: pandn %xmm2, %xmm11
8578 ; SSE2-NEXT: por %xmm15, %xmm11
8579 ; SSE2-NEXT: pandn %xmm6, %xmm13
8580 ; SSE2-NEXT: pandn %xmm3, %xmm10
8581 ; SSE2-NEXT: por %xmm13, %xmm10
8582 ; SSE2-NEXT: pandn -{{[0-9]+}}(%rsp), %xmm12 # 16-byte Folded Reload
8583 ; SSE2-NEXT: pandn %xmm7, %xmm8
8584 ; SSE2-NEXT: por %xmm12, %xmm8
8585 ; SSE2-NEXT: movdqa %xmm1, %xmm0
8586 ; SSE2-NEXT: movdqa %xmm11, %xmm1
8587 ; SSE2-NEXT: movdqa %xmm10, %xmm2
8588 ; SSE2-NEXT: movdqa %xmm8, %xmm3
8589 ; SSE2-NEXT: retq
8686 ; SSE2-LABEL: test161:
8687 ; SSE2: # BB#0: # %entry
8688 ; SSE2-NEXT: movdqa {{.*#+}} xmm4 = [2147483648,0,2147483648,0]
8689 ; SSE2-NEXT: movdqa %xmm1, %xmm5
8690 ; SSE2-NEXT: pxor %xmm4, %xmm5
8691 ; SSE2-NEXT: movdqa %xmm3, %xmm6
8692 ; SSE2-NEXT: pxor %xmm4, %xmm6
8693 ; SSE2-NEXT: movdqa %xmm6, %xmm7
8694 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm7
8695 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
8696 ; SSE2-NEXT: pcmpeqd %xmm5, %xmm6
8697 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm6[1,1,3,3]
8698 ; SSE2-NEXT: pand %xmm8, %xmm5
8699 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
8700 ; SSE2-NEXT: por %xmm5, %xmm6
8701 ; SSE2-NEXT: movdqa %xmm0, %xmm5
8702 ; SSE2-NEXT: pxor %xmm4, %xmm5
8703 ; SSE2-NEXT: pxor %xmm2, %xmm4
8704 ; SSE2-NEXT: movdqa %xmm4, %xmm7
8705 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm7
8706 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
8707 ; SSE2-NEXT: pcmpeqd %xmm5, %xmm4
8708 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm4[1,1,3,3]
8709 ; SSE2-NEXT: pand %xmm8, %xmm4
8710 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm7[1,1,3,3]
8711 ; SSE2-NEXT: por %xmm4, %xmm5
8712 ; SSE2-NEXT: pand %xmm5, %xmm0
8713 ; SSE2-NEXT: pandn %xmm2, %xmm5
8714 ; SSE2-NEXT: por %xmm5, %xmm0
8715 ; SSE2-NEXT: pand %xmm6, %xmm1
8716 ; SSE2-NEXT: pandn %xmm3, %xmm6
8717 ; SSE2-NEXT: por %xmm6, %xmm1
8718 ; SSE2-NEXT: retq
8761 ; SSE2-LABEL: test162:
8762 ; SSE2: # BB#0: # %entry
8763 ; SSE2-NEXT: movdqa {{.*#+}} xmm7 = [2147483648,0,2147483648,0]
8764 ; SSE2-NEXT: movdqa %xmm3, %xmm4
8765 ; SSE2-NEXT: pxor %xmm7, %xmm4
8766 ; SSE2-NEXT: movdqa %xmm1, %xmm5
8767 ; SSE2-NEXT: pxor %xmm7, %xmm5
8768 ; SSE2-NEXT: movdqa %xmm5, %xmm6
8769 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm6
8770 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[0,0,2,2]
8771 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm5
8772 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm5[1,1,3,3]
8773 ; SSE2-NEXT: pand %xmm8, %xmm4
8774 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[1,1,3,3]
8775 ; SSE2-NEXT: por %xmm4, %xmm8
8776 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
8777 ; SSE2-NEXT: movdqa %xmm8, %xmm9
8778 ; SSE2-NEXT: pxor %xmm4, %xmm9
8779 ; SSE2-NEXT: movdqa %xmm2, %xmm6
8780 ; SSE2-NEXT: pxor %xmm7, %xmm6
8781 ; SSE2-NEXT: pxor %xmm0, %xmm7
8782 ; SSE2-NEXT: movdqa %xmm7, %xmm5
8783 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
8784 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm5[0,0,2,2]
8785 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm7
8786 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
8787 ; SSE2-NEXT: pand %xmm10, %xmm6
8788 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm5[1,1,3,3]
8789 ; SSE2-NEXT: por %xmm6, %xmm5
8790 ; SSE2-NEXT: pxor %xmm5, %xmm4
8791 ; SSE2-NEXT: pandn %xmm0, %xmm5
8792 ; SSE2-NEXT: pandn %xmm2, %xmm4
8793 ; SSE2-NEXT: por %xmm5, %xmm4
8794 ; SSE2-NEXT: pandn %xmm1, %xmm8
8795 ; SSE2-NEXT: pandn %xmm3, %xmm9
8796 ; SSE2-NEXT: por %xmm8, %xmm9
8797 ; SSE2-NEXT: movdqa %xmm4, %xmm0
8798 ; SSE2-NEXT: movdqa %xmm9, %xmm1
8799 ; SSE2-NEXT: retq
8849 ; SSE2-LABEL: test163:
8850 ; SSE2: # BB#0: # %entry
8851 ; SSE2-NEXT: movdqa {{.*#+}} xmm4 = [2147483648,0,2147483648,0]
8852 ; SSE2-NEXT: movdqa %xmm3, %xmm5
8853 ; SSE2-NEXT: pxor %xmm4, %xmm5
8854 ; SSE2-NEXT: movdqa %xmm1, %xmm6
8855 ; SSE2-NEXT: pxor %xmm4, %xmm6
8856 ; SSE2-NEXT: movdqa %xmm6, %xmm7
8857 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm7
8858 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
8859 ; SSE2-NEXT: pcmpeqd %xmm5, %xmm6
8860 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm6[1,1,3,3]
8861 ; SSE2-NEXT: pand %xmm8, %xmm5
8862 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
8863 ; SSE2-NEXT: por %xmm5, %xmm6
8864 ; SSE2-NEXT: movdqa %xmm2, %xmm5
8865 ; SSE2-NEXT: pxor %xmm4, %xmm5
8866 ; SSE2-NEXT: pxor %xmm0, %xmm4
8867 ; SSE2-NEXT: movdqa %xmm4, %xmm7
8868 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm7
8869 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
8870 ; SSE2-NEXT: pcmpeqd %xmm5, %xmm4
8871 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm4[1,1,3,3]
8872 ; SSE2-NEXT: pand %xmm8, %xmm4
8873 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm7[1,1,3,3]
8874 ; SSE2-NEXT: por %xmm4, %xmm5
8875 ; SSE2-NEXT: pand %xmm5, %xmm0
8876 ; SSE2-NEXT: pandn %xmm2, %xmm5
8877 ; SSE2-NEXT: por %xmm5, %xmm0
8878 ; SSE2-NEXT: pand %xmm6, %xmm1
8879 ; SSE2-NEXT: pandn %xmm3, %xmm6
8880 ; SSE2-NEXT: por %xmm6, %xmm1
8881 ; SSE2-NEXT: retq
8923 ; SSE2-LABEL: test164:
8924 ; SSE2: # BB#0: # %entry
8925 ; SSE2-NEXT: movdqa {{.*#+}} xmm7 = [2147483648,0,2147483648,0]
8926 ; SSE2-NEXT: movdqa %xmm1, %xmm4
8927 ; SSE2-NEXT: pxor %xmm7, %xmm4
8928 ; SSE2-NEXT: movdqa %xmm3, %xmm5
8929 ; SSE2-NEXT: pxor %xmm7, %xmm5
8930 ; SSE2-NEXT: movdqa %xmm5, %xmm6
8931 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm6
8932 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[0,0,2,2]
8933 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm5
8934 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm5[1,1,3,3]
8935 ; SSE2-NEXT: pand %xmm8, %xmm4
8936 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[1,1,3,3]
8937 ; SSE2-NEXT: por %xmm4, %xmm8
8938 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
8939 ; SSE2-NEXT: movdqa %xmm8, %xmm9
8940 ; SSE2-NEXT: pxor %xmm4, %xmm9
8941 ; SSE2-NEXT: movdqa %xmm0, %xmm6
8942 ; SSE2-NEXT: pxor %xmm7, %xmm6
8943 ; SSE2-NEXT: pxor %xmm2, %xmm7
8944 ; SSE2-NEXT: movdqa %xmm7, %xmm5
8945 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
8946 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm5[0,0,2,2]
8947 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm7
8948 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
8949 ; SSE2-NEXT: pand %xmm10, %xmm6
8950 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm5[1,1,3,3]
8951 ; SSE2-NEXT: por %xmm6, %xmm5
8952 ; SSE2-NEXT: pxor %xmm5, %xmm4
8953 ; SSE2-NEXT: pandn %xmm0, %xmm5
8954 ; SSE2-NEXT: pandn %xmm2, %xmm4
8955 ; SSE2-NEXT: por %xmm5, %xmm4
8956 ; SSE2-NEXT: pandn %xmm1, %xmm8
8957 ; SSE2-NEXT: pandn %xmm3, %xmm9
8958 ; SSE2-NEXT: por %xmm8, %xmm9
8959 ; SSE2-NEXT: movdqa %xmm4, %xmm0
8960 ; SSE2-NEXT: movdqa %xmm9, %xmm1
8961 ; SSE2-NEXT: retq
9012 ; SSE2-LABEL: test165:
9013 ; SSE2: # BB#0: # %entry
9014 ; SSE2-NEXT: movdqa {{.*#+}} xmm4 = [2147483648,2147483648,2147483648,2147483648]
9015 ; SSE2-NEXT: movdqa %xmm1, %xmm5
9016 ; SSE2-NEXT: pxor %xmm4, %xmm5
9017 ; SSE2-NEXT: movdqa %xmm3, %xmm6
9018 ; SSE2-NEXT: pxor %xmm4, %xmm6
9019 ; SSE2-NEXT: movdqa %xmm6, %xmm7
9020 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm7
9021 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9022 ; SSE2-NEXT: pcmpeqd %xmm5, %xmm6
9023 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm6[1,1,3,3]
9024 ; SSE2-NEXT: pand %xmm8, %xmm5
9025 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
9026 ; SSE2-NEXT: por %xmm5, %xmm6
9027 ; SSE2-NEXT: movdqa %xmm0, %xmm5
9028 ; SSE2-NEXT: pxor %xmm4, %xmm5
9029 ; SSE2-NEXT: pxor %xmm2, %xmm4
9030 ; SSE2-NEXT: movdqa %xmm4, %xmm7
9031 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm7
9032 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9033 ; SSE2-NEXT: pcmpeqd %xmm5, %xmm4
9034 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm4[1,1,3,3]
9035 ; SSE2-NEXT: pand %xmm8, %xmm4
9036 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm7[1,1,3,3]
9037 ; SSE2-NEXT: por %xmm4, %xmm5
9038 ; SSE2-NEXT: pand %xmm5, %xmm0
9039 ; SSE2-NEXT: pandn %xmm2, %xmm5
9040 ; SSE2-NEXT: por %xmm5, %xmm0
9041 ; SSE2-NEXT: pand %xmm6, %xmm1
9042 ; SSE2-NEXT: pandn %xmm3, %xmm6
9043 ; SSE2-NEXT: por %xmm6, %xmm1
9044 ; SSE2-NEXT: retq
9101 ; SSE2-LABEL: test166:
9102 ; SSE2: # BB#0: # %entry
9103 ; SSE2-NEXT: movdqa {{.*#+}} xmm7 = [2147483648,2147483648,2147483648,2147483648]
9104 ; SSE2-NEXT: movdqa %xmm3, %xmm4
9105 ; SSE2-NEXT: pxor %xmm7, %xmm4
9106 ; SSE2-NEXT: movdqa %xmm1, %xmm5
9107 ; SSE2-NEXT: pxor %xmm7, %xmm5
9108 ; SSE2-NEXT: movdqa %xmm5, %xmm6
9109 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm6
9110 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[0,0,2,2]
9111 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm5
9112 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm5[1,1,3,3]
9113 ; SSE2-NEXT: pand %xmm8, %xmm4
9114 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[1,1,3,3]
9115 ; SSE2-NEXT: por %xmm4, %xmm8
9116 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
9117 ; SSE2-NEXT: movdqa %xmm8, %xmm9
9118 ; SSE2-NEXT: pxor %xmm4, %xmm9
9119 ; SSE2-NEXT: movdqa %xmm2, %xmm6
9120 ; SSE2-NEXT: pxor %xmm7, %xmm6
9121 ; SSE2-NEXT: pxor %xmm0, %xmm7
9122 ; SSE2-NEXT: movdqa %xmm7, %xmm5
9123 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
9124 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm5[0,0,2,2]
9125 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm7
9126 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
9127 ; SSE2-NEXT: pand %xmm10, %xmm6
9128 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm5[1,1,3,3]
9129 ; SSE2-NEXT: por %xmm6, %xmm5
9130 ; SSE2-NEXT: pxor %xmm5, %xmm4
9131 ; SSE2-NEXT: pandn %xmm0, %xmm5
9132 ; SSE2-NEXT: pandn %xmm2, %xmm4
9133 ; SSE2-NEXT: por %xmm5, %xmm4
9134 ; SSE2-NEXT: pandn %xmm1, %xmm8
9135 ; SSE2-NEXT: pandn %xmm3, %xmm9
9136 ; SSE2-NEXT: por %xmm8, %xmm9
9137 ; SSE2-NEXT: movdqa %xmm4, %xmm0
9138 ; SSE2-NEXT: movdqa %xmm9, %xmm1
9139 ; SSE2-NEXT: retq
9204 ; SSE2-LABEL: test167:
9205 ; SSE2: # BB#0: # %entry
9206 ; SSE2-NEXT: movdqa {{.*#+}} xmm4 = [2147483648,2147483648,2147483648,2147483648]
9207 ; SSE2-NEXT: movdqa %xmm3, %xmm5
9208 ; SSE2-NEXT: pxor %xmm4, %xmm5
9209 ; SSE2-NEXT: movdqa %xmm1, %xmm6
9210 ; SSE2-NEXT: pxor %xmm4, %xmm6
9211 ; SSE2-NEXT: movdqa %xmm6, %xmm7
9212 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm7
9213 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9214 ; SSE2-NEXT: pcmpeqd %xmm5, %xmm6
9215 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm6[1,1,3,3]
9216 ; SSE2-NEXT: pand %xmm8, %xmm5
9217 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
9218 ; SSE2-NEXT: por %xmm5, %xmm6
9219 ; SSE2-NEXT: movdqa %xmm2, %xmm5
9220 ; SSE2-NEXT: pxor %xmm4, %xmm5
9221 ; SSE2-NEXT: pxor %xmm0, %xmm4
9222 ; SSE2-NEXT: movdqa %xmm4, %xmm7
9223 ; SSE2-NEXT: pcmpgtd %xmm5, %xmm7
9224 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9225 ; SSE2-NEXT: pcmpeqd %xmm5, %xmm4
9226 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm4[1,1,3,3]
9227 ; SSE2-NEXT: pand %xmm8, %xmm4
9228 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm7[1,1,3,3]
9229 ; SSE2-NEXT: por %xmm4, %xmm5
9230 ; SSE2-NEXT: pand %xmm5, %xmm0
9231 ; SSE2-NEXT: pandn %xmm2, %xmm5
9232 ; SSE2-NEXT: por %xmm5, %xmm0
9233 ; SSE2-NEXT: pand %xmm6, %xmm1
9234 ; SSE2-NEXT: pandn %xmm3, %xmm6
9235 ; SSE2-NEXT: por %xmm6, %xmm1
9236 ; SSE2-NEXT: retq
9293 ; SSE2-LABEL: test168:
9294 ; SSE2: # BB#0: # %entry
9295 ; SSE2-NEXT: movdqa {{.*#+}} xmm7 = [2147483648,2147483648,2147483648,2147483648]
9296 ; SSE2-NEXT: movdqa %xmm1, %xmm4
9297 ; SSE2-NEXT: pxor %xmm7, %xmm4
9298 ; SSE2-NEXT: movdqa %xmm3, %xmm5
9299 ; SSE2-NEXT: pxor %xmm7, %xmm5
9300 ; SSE2-NEXT: movdqa %xmm5, %xmm6
9301 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm6
9302 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[0,0,2,2]
9303 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm5
9304 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm5[1,1,3,3]
9305 ; SSE2-NEXT: pand %xmm8, %xmm4
9306 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[1,1,3,3]
9307 ; SSE2-NEXT: por %xmm4, %xmm8
9308 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
9309 ; SSE2-NEXT: movdqa %xmm8, %xmm9
9310 ; SSE2-NEXT: pxor %xmm4, %xmm9
9311 ; SSE2-NEXT: movdqa %xmm0, %xmm6
9312 ; SSE2-NEXT: pxor %xmm7, %xmm6
9313 ; SSE2-NEXT: pxor %xmm2, %xmm7
9314 ; SSE2-NEXT: movdqa %xmm7, %xmm5
9315 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
9316 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm5[0,0,2,2]
9317 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm7
9318 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
9319 ; SSE2-NEXT: pand %xmm10, %xmm6
9320 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm5[1,1,3,3]
9321 ; SSE2-NEXT: por %xmm6, %xmm5
9322 ; SSE2-NEXT: pxor %xmm5, %xmm4
9323 ; SSE2-NEXT: pandn %xmm0, %xmm5
9324 ; SSE2-NEXT: pandn %xmm2, %xmm4
9325 ; SSE2-NEXT: por %xmm5, %xmm4
9326 ; SSE2-NEXT: pandn %xmm1, %xmm8
9327 ; SSE2-NEXT: pandn %xmm3, %xmm9
9328 ; SSE2-NEXT: por %xmm8, %xmm9
9329 ; SSE2-NEXT: movdqa %xmm4, %xmm0
9330 ; SSE2-NEXT: movdqa %xmm9, %xmm1
9331 ; SSE2-NEXT: retq
9396 ; SSE2-LABEL: test169:
9397 ; SSE2: # BB#0: # %entry
9398 ; SSE2-NEXT: movdqa {{.*#+}} xmm5 = [2147483648,0,2147483648,0]
9399 ; SSE2-NEXT: movdqa %xmm1, %xmm4
9400 ; SSE2-NEXT: pxor %xmm5, %xmm4
9401 ; SSE2-NEXT: movdqa %xmm3, %xmm6
9402 ; SSE2-NEXT: pxor %xmm5, %xmm6
9403 ; SSE2-NEXT: movdqa %xmm6, %xmm7
9404 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm7
9405 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9406 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm6
9407 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm6[1,1,3,3]
9408 ; SSE2-NEXT: pand %xmm8, %xmm6
9409 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm7[1,1,3,3]
9410 ; SSE2-NEXT: por %xmm6, %xmm4
9411 ; SSE2-NEXT: movdqa %xmm0, %xmm6
9412 ; SSE2-NEXT: pxor %xmm5, %xmm6
9413 ; SSE2-NEXT: pxor %xmm2, %xmm5
9414 ; SSE2-NEXT: movdqa %xmm5, %xmm7
9415 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm7
9416 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9417 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm5
9418 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm5[1,1,3,3]
9419 ; SSE2-NEXT: pand %xmm8, %xmm6
9420 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm7[1,1,3,3]
9421 ; SSE2-NEXT: por %xmm6, %xmm5
9422 ; SSE2-NEXT: pand %xmm5, %xmm2
9423 ; SSE2-NEXT: pandn %xmm0, %xmm5
9424 ; SSE2-NEXT: por %xmm2, %xmm5
9425 ; SSE2-NEXT: pand %xmm4, %xmm3
9426 ; SSE2-NEXT: pandn %xmm1, %xmm4
9427 ; SSE2-NEXT: por %xmm3, %xmm4
9428 ; SSE2-NEXT: movdqa %xmm5, %xmm0
9429 ; SSE2-NEXT: movdqa %xmm4, %xmm1
9430 ; SSE2-NEXT: retq
9472 ; SSE2-LABEL: test170:
9473 ; SSE2: # BB#0: # %entry
9474 ; SSE2-NEXT: movdqa {{.*#+}} xmm7 = [2147483648,0,2147483648,0]
9475 ; SSE2-NEXT: movdqa %xmm3, %xmm4
9476 ; SSE2-NEXT: pxor %xmm7, %xmm4
9477 ; SSE2-NEXT: movdqa %xmm1, %xmm5
9478 ; SSE2-NEXT: pxor %xmm7, %xmm5
9479 ; SSE2-NEXT: movdqa %xmm5, %xmm6
9480 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm6
9481 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[0,0,2,2]
9482 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm5
9483 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm5[1,1,3,3]
9484 ; SSE2-NEXT: pand %xmm8, %xmm4
9485 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[1,1,3,3]
9486 ; SSE2-NEXT: por %xmm4, %xmm8
9487 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
9488 ; SSE2-NEXT: movdqa %xmm8, %xmm9
9489 ; SSE2-NEXT: pxor %xmm4, %xmm9
9490 ; SSE2-NEXT: movdqa %xmm2, %xmm6
9491 ; SSE2-NEXT: pxor %xmm7, %xmm6
9492 ; SSE2-NEXT: pxor %xmm0, %xmm7
9493 ; SSE2-NEXT: movdqa %xmm7, %xmm5
9494 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
9495 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm5[0,0,2,2]
9496 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm7
9497 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
9498 ; SSE2-NEXT: pand %xmm10, %xmm6
9499 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm5[1,1,3,3]
9500 ; SSE2-NEXT: por %xmm6, %xmm5
9501 ; SSE2-NEXT: pxor %xmm5, %xmm4
9502 ; SSE2-NEXT: pandn %xmm2, %xmm5
9503 ; SSE2-NEXT: pandn %xmm0, %xmm4
9504 ; SSE2-NEXT: por %xmm5, %xmm4
9505 ; SSE2-NEXT: pandn %xmm3, %xmm8
9506 ; SSE2-NEXT: pandn %xmm1, %xmm9
9507 ; SSE2-NEXT: por %xmm8, %xmm9
9508 ; SSE2-NEXT: movdqa %xmm4, %xmm0
9509 ; SSE2-NEXT: movdqa %xmm9, %xmm1
9510 ; SSE2-NEXT: retq
9559 ; SSE2-LABEL: test171:
9560 ; SSE2: # BB#0: # %entry
9561 ; SSE2-NEXT: movdqa {{.*#+}} xmm5 = [2147483648,0,2147483648,0]
9562 ; SSE2-NEXT: movdqa %xmm3, %xmm4
9563 ; SSE2-NEXT: pxor %xmm5, %xmm4
9564 ; SSE2-NEXT: movdqa %xmm1, %xmm6
9565 ; SSE2-NEXT: pxor %xmm5, %xmm6
9566 ; SSE2-NEXT: movdqa %xmm6, %xmm7
9567 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm7
9568 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9569 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm6
9570 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm6[1,1,3,3]
9571 ; SSE2-NEXT: pand %xmm8, %xmm6
9572 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm7[1,1,3,3]
9573 ; SSE2-NEXT: por %xmm6, %xmm4
9574 ; SSE2-NEXT: movdqa %xmm2, %xmm6
9575 ; SSE2-NEXT: pxor %xmm5, %xmm6
9576 ; SSE2-NEXT: pxor %xmm0, %xmm5
9577 ; SSE2-NEXT: movdqa %xmm5, %xmm7
9578 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm7
9579 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9580 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm5
9581 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm5[1,1,3,3]
9582 ; SSE2-NEXT: pand %xmm8, %xmm6
9583 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm7[1,1,3,3]
9584 ; SSE2-NEXT: por %xmm6, %xmm5
9585 ; SSE2-NEXT: pand %xmm5, %xmm2
9586 ; SSE2-NEXT: pandn %xmm0, %xmm5
9587 ; SSE2-NEXT: por %xmm2, %xmm5
9588 ; SSE2-NEXT: pand %xmm4, %xmm3
9589 ; SSE2-NEXT: pandn %xmm1, %xmm4
9590 ; SSE2-NEXT: por %xmm3, %xmm4
9591 ; SSE2-NEXT: movdqa %xmm5, %xmm0
9592 ; SSE2-NEXT: movdqa %xmm4, %xmm1
9593 ; SSE2-NEXT: retq
9634 ; SSE2-LABEL: test172:
9635 ; SSE2: # BB#0: # %entry
9636 ; SSE2-NEXT: movdqa {{.*#+}} xmm7 = [2147483648,0,2147483648,0]
9637 ; SSE2-NEXT: movdqa %xmm1, %xmm4
9638 ; SSE2-NEXT: pxor %xmm7, %xmm4
9639 ; SSE2-NEXT: movdqa %xmm3, %xmm5
9640 ; SSE2-NEXT: pxor %xmm7, %xmm5
9641 ; SSE2-NEXT: movdqa %xmm5, %xmm6
9642 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm6
9643 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[0,0,2,2]
9644 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm5
9645 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm5[1,1,3,3]
9646 ; SSE2-NEXT: pand %xmm8, %xmm4
9647 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[1,1,3,3]
9648 ; SSE2-NEXT: por %xmm4, %xmm8
9649 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
9650 ; SSE2-NEXT: movdqa %xmm8, %xmm9
9651 ; SSE2-NEXT: pxor %xmm4, %xmm9
9652 ; SSE2-NEXT: movdqa %xmm0, %xmm6
9653 ; SSE2-NEXT: pxor %xmm7, %xmm6
9654 ; SSE2-NEXT: pxor %xmm2, %xmm7
9655 ; SSE2-NEXT: movdqa %xmm7, %xmm5
9656 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
9657 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm5[0,0,2,2]
9658 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm7
9659 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
9660 ; SSE2-NEXT: pand %xmm10, %xmm6
9661 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm5[1,1,3,3]
9662 ; SSE2-NEXT: por %xmm6, %xmm5
9663 ; SSE2-NEXT: pxor %xmm5, %xmm4
9664 ; SSE2-NEXT: pandn %xmm2, %xmm5
9665 ; SSE2-NEXT: pandn %xmm0, %xmm4
9666 ; SSE2-NEXT: por %xmm5, %xmm4
9667 ; SSE2-NEXT: pandn %xmm3, %xmm8
9668 ; SSE2-NEXT: pandn %xmm1, %xmm9
9669 ; SSE2-NEXT: por %xmm8, %xmm9
9670 ; SSE2-NEXT: movdqa %xmm4, %xmm0
9671 ; SSE2-NEXT: movdqa %xmm9, %xmm1
9672 ; SSE2-NEXT: retq
9722 ; SSE2-LABEL: test173:
9723 ; SSE2: # BB#0: # %entry
9724 ; SSE2-NEXT: movdqa {{.*#+}} xmm5 = [2147483648,2147483648,2147483648,2147483648]
9725 ; SSE2-NEXT: movdqa %xmm1, %xmm4
9726 ; SSE2-NEXT: pxor %xmm5, %xmm4
9727 ; SSE2-NEXT: movdqa %xmm3, %xmm6
9728 ; SSE2-NEXT: pxor %xmm5, %xmm6
9729 ; SSE2-NEXT: movdqa %xmm6, %xmm7
9730 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm7
9731 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9732 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm6
9733 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm6[1,1,3,3]
9734 ; SSE2-NEXT: pand %xmm8, %xmm6
9735 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm7[1,1,3,3]
9736 ; SSE2-NEXT: por %xmm6, %xmm4
9737 ; SSE2-NEXT: movdqa %xmm0, %xmm6
9738 ; SSE2-NEXT: pxor %xmm5, %xmm6
9739 ; SSE2-NEXT: pxor %xmm2, %xmm5
9740 ; SSE2-NEXT: movdqa %xmm5, %xmm7
9741 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm7
9742 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9743 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm5
9744 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm5[1,1,3,3]
9745 ; SSE2-NEXT: pand %xmm8, %xmm6
9746 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm7[1,1,3,3]
9747 ; SSE2-NEXT: por %xmm6, %xmm5
9748 ; SSE2-NEXT: pand %xmm5, %xmm2
9749 ; SSE2-NEXT: pandn %xmm0, %xmm5
9750 ; SSE2-NEXT: por %xmm2, %xmm5
9751 ; SSE2-NEXT: pand %xmm4, %xmm3
9752 ; SSE2-NEXT: pandn %xmm1, %xmm4
9753 ; SSE2-NEXT: por %xmm3, %xmm4
9754 ; SSE2-NEXT: movdqa %xmm5, %xmm0
9755 ; SSE2-NEXT: movdqa %xmm4, %xmm1
9756 ; SSE2-NEXT: retq
9812 ; SSE2-LABEL: test174:
9813 ; SSE2: # BB#0: # %entry
9814 ; SSE2-NEXT: movdqa {{.*#+}} xmm7 = [2147483648,2147483648,2147483648,2147483648]
9815 ; SSE2-NEXT: movdqa %xmm3, %xmm4
9816 ; SSE2-NEXT: pxor %xmm7, %xmm4
9817 ; SSE2-NEXT: movdqa %xmm1, %xmm5
9818 ; SSE2-NEXT: pxor %xmm7, %xmm5
9819 ; SSE2-NEXT: movdqa %xmm5, %xmm6
9820 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm6
9821 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[0,0,2,2]
9822 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm5
9823 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm5[1,1,3,3]
9824 ; SSE2-NEXT: pand %xmm8, %xmm4
9825 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[1,1,3,3]
9826 ; SSE2-NEXT: por %xmm4, %xmm8
9827 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
9828 ; SSE2-NEXT: movdqa %xmm8, %xmm9
9829 ; SSE2-NEXT: pxor %xmm4, %xmm9
9830 ; SSE2-NEXT: movdqa %xmm2, %xmm6
9831 ; SSE2-NEXT: pxor %xmm7, %xmm6
9832 ; SSE2-NEXT: pxor %xmm0, %xmm7
9833 ; SSE2-NEXT: movdqa %xmm7, %xmm5
9834 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
9835 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm5[0,0,2,2]
9836 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm7
9837 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
9838 ; SSE2-NEXT: pand %xmm10, %xmm6
9839 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm5[1,1,3,3]
9840 ; SSE2-NEXT: por %xmm6, %xmm5
9841 ; SSE2-NEXT: pxor %xmm5, %xmm4
9842 ; SSE2-NEXT: pandn %xmm2, %xmm5
9843 ; SSE2-NEXT: pandn %xmm0, %xmm4
9844 ; SSE2-NEXT: por %xmm5, %xmm4
9845 ; SSE2-NEXT: pandn %xmm3, %xmm8
9846 ; SSE2-NEXT: pandn %xmm1, %xmm9
9847 ; SSE2-NEXT: por %xmm8, %xmm9
9848 ; SSE2-NEXT: movdqa %xmm4, %xmm0
9849 ; SSE2-NEXT: movdqa %xmm9, %xmm1
9850 ; SSE2-NEXT: retq
9914 ; SSE2-LABEL: test175:
9915 ; SSE2: # BB#0: # %entry
9916 ; SSE2-NEXT: movdqa {{.*#+}} xmm5 = [2147483648,2147483648,2147483648,2147483648]
9917 ; SSE2-NEXT: movdqa %xmm3, %xmm4
9918 ; SSE2-NEXT: pxor %xmm5, %xmm4
9919 ; SSE2-NEXT: movdqa %xmm1, %xmm6
9920 ; SSE2-NEXT: pxor %xmm5, %xmm6
9921 ; SSE2-NEXT: movdqa %xmm6, %xmm7
9922 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm7
9923 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9924 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm6
9925 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm6[1,1,3,3]
9926 ; SSE2-NEXT: pand %xmm8, %xmm6
9927 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm7[1,1,3,3]
9928 ; SSE2-NEXT: por %xmm6, %xmm4
9929 ; SSE2-NEXT: movdqa %xmm2, %xmm6
9930 ; SSE2-NEXT: pxor %xmm5, %xmm6
9931 ; SSE2-NEXT: pxor %xmm0, %xmm5
9932 ; SSE2-NEXT: movdqa %xmm5, %xmm7
9933 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm7
9934 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm7[0,0,2,2]
9935 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm5
9936 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm5[1,1,3,3]
9937 ; SSE2-NEXT: pand %xmm8, %xmm6
9938 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm7[1,1,3,3]
9939 ; SSE2-NEXT: por %xmm6, %xmm5
9940 ; SSE2-NEXT: pand %xmm5, %xmm2
9941 ; SSE2-NEXT: pandn %xmm0, %xmm5
9942 ; SSE2-NEXT: por %xmm2, %xmm5
9943 ; SSE2-NEXT: pand %xmm4, %xmm3
9944 ; SSE2-NEXT: pandn %xmm1, %xmm4
9945 ; SSE2-NEXT: por %xmm3, %xmm4
9946 ; SSE2-NEXT: movdqa %xmm5, %xmm0
9947 ; SSE2-NEXT: movdqa %xmm4, %xmm1
9948 ; SSE2-NEXT: retq
10004 ; SSE2-LABEL: test176:
10005 ; SSE2: # BB#0: # %entry
10006 ; SSE2-NEXT: movdqa {{.*#+}} xmm7 = [2147483648,2147483648,2147483648,2147483648]
10007 ; SSE2-NEXT: movdqa %xmm1, %xmm4
10008 ; SSE2-NEXT: pxor %xmm7, %xmm4
10009 ; SSE2-NEXT: movdqa %xmm3, %xmm5
10010 ; SSE2-NEXT: pxor %xmm7, %xmm5
10011 ; SSE2-NEXT: movdqa %xmm5, %xmm6
10012 ; SSE2-NEXT: pcmpgtd %xmm4, %xmm6
10013 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[0,0,2,2]
10014 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm5
10015 ; SSE2-NEXT: pshufd {{.*#+}} xmm4 = xmm5[1,1,3,3]
10016 ; SSE2-NEXT: pand %xmm8, %xmm4
10017 ; SSE2-NEXT: pshufd {{.*#+}} xmm8 = xmm6[1,1,3,3]
10018 ; SSE2-NEXT: por %xmm4, %xmm8
10019 ; SSE2-NEXT: pcmpeqd %xmm4, %xmm4
10020 ; SSE2-NEXT: movdqa %xmm8, %xmm9
10021 ; SSE2-NEXT: pxor %xmm4, %xmm9
10022 ; SSE2-NEXT: movdqa %xmm0, %xmm6
10023 ; SSE2-NEXT: pxor %xmm7, %xmm6
10024 ; SSE2-NEXT: pxor %xmm2, %xmm7
10025 ; SSE2-NEXT: movdqa %xmm7, %xmm5
10026 ; SSE2-NEXT: pcmpgtd %xmm6, %xmm5
10027 ; SSE2-NEXT: pshufd {{.*#+}} xmm10 = xmm5[0,0,2,2]
10028 ; SSE2-NEXT: pcmpeqd %xmm6, %xmm7
10029 ; SSE2-NEXT: pshufd {{.*#+}} xmm6 = xmm7[1,1,3,3]
10030 ; SSE2-NEXT: pand %xmm10, %xmm6
10031 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm5[1,1,3,3]
10032 ; SSE2-NEXT: por %xmm6, %xmm5
10033 ; SSE2-NEXT: pxor %xmm5, %xmm4
10034 ; SSE2-NEXT: pandn %xmm2, %xmm5
10035 ; SSE2-NEXT: pandn %xmm0, %xmm4
10036 ; SSE2-NEXT: por %xmm5, %xmm4
10037 ; SSE2-NEXT: pandn %xmm3, %xmm8
10038 ; SSE2-NEXT: pandn %xmm1, %xmm9
10039 ; SSE2-NEXT: por %xmm8, %xmm9
10040 ; SSE2-NEXT: movdqa %xmm4, %xmm0
10041 ; SSE2-NEXT: movdqa %xmm9, %xmm1
10042 ; SSE2-NEXT: retq
10106 ; SSE2-LABEL: test177:
10107 ; SSE2: # BB#0: # %entry
10108 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,0,2147483648,0]
10109 ; SSE2-NEXT: movdqa %xmm0, %xmm3
10110 ; SSE2-NEXT: pxor %xmm2, %xmm3
10111 ; SSE2-NEXT: pxor %xmm1, %xmm2
10112 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10113 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10114 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10115 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10116 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10117 ; SSE2-NEXT: pand %xmm5, %xmm2
10118 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10119 ; SSE2-NEXT: por %xmm2, %xmm3
10120 ; SSE2-NEXT: pand %xmm3, %xmm0
10121 ; SSE2-NEXT: pandn %xmm1, %xmm3
10122 ; SSE2-NEXT: por %xmm3, %xmm0
10123 ; SSE2-NEXT: retq
10157 ; SSE2-LABEL: test178:
10158 ; SSE2: # BB#0: # %entry
10159 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,0,2147483648,0]
10160 ; SSE2-NEXT: movdqa %xmm1, %xmm3
10161 ; SSE2-NEXT: pxor %xmm2, %xmm3
10162 ; SSE2-NEXT: pxor %xmm0, %xmm2
10163 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10164 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10165 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10166 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10167 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10168 ; SSE2-NEXT: pand %xmm5, %xmm2
10169 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10170 ; SSE2-NEXT: por %xmm2, %xmm3
10171 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
10172 ; SSE2-NEXT: pxor %xmm3, %xmm2
10173 ; SSE2-NEXT: pandn %xmm0, %xmm3
10174 ; SSE2-NEXT: pandn %xmm1, %xmm2
10175 ; SSE2-NEXT: por %xmm3, %xmm2
10176 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10177 ; SSE2-NEXT: retq
10216 ; SSE2-LABEL: test179:
10217 ; SSE2: # BB#0: # %entry
10218 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,0,2147483648,0]
10219 ; SSE2-NEXT: movdqa %xmm1, %xmm3
10220 ; SSE2-NEXT: pxor %xmm2, %xmm3
10221 ; SSE2-NEXT: pxor %xmm0, %xmm2
10222 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10223 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10224 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10225 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10226 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10227 ; SSE2-NEXT: pand %xmm5, %xmm2
10228 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10229 ; SSE2-NEXT: por %xmm2, %xmm3
10230 ; SSE2-NEXT: pand %xmm3, %xmm0
10231 ; SSE2-NEXT: pandn %xmm1, %xmm3
10232 ; SSE2-NEXT: por %xmm3, %xmm0
10233 ; SSE2-NEXT: retq
10266 ; SSE2-LABEL: test180:
10267 ; SSE2: # BB#0: # %entry
10268 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,0,2147483648,0]
10269 ; SSE2-NEXT: movdqa %xmm0, %xmm3
10270 ; SSE2-NEXT: pxor %xmm2, %xmm3
10271 ; SSE2-NEXT: pxor %xmm1, %xmm2
10272 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10273 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10274 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10275 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10276 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10277 ; SSE2-NEXT: pand %xmm5, %xmm2
10278 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10279 ; SSE2-NEXT: por %xmm2, %xmm3
10280 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
10281 ; SSE2-NEXT: pxor %xmm3, %xmm2
10282 ; SSE2-NEXT: pandn %xmm0, %xmm3
10283 ; SSE2-NEXT: pandn %xmm1, %xmm2
10284 ; SSE2-NEXT: por %xmm3, %xmm2
10285 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10286 ; SSE2-NEXT: retq
10326 ; SSE2-LABEL: test181:
10327 ; SSE2: # BB#0: # %entry
10328 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
10329 ; SSE2-NEXT: movdqa %xmm0, %xmm3
10330 ; SSE2-NEXT: pxor %xmm2, %xmm3
10331 ; SSE2-NEXT: pxor %xmm1, %xmm2
10332 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10333 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10334 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10335 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10336 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10337 ; SSE2-NEXT: pand %xmm5, %xmm2
10338 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10339 ; SSE2-NEXT: por %xmm2, %xmm3
10340 ; SSE2-NEXT: pand %xmm3, %xmm0
10341 ; SSE2-NEXT: pandn %xmm1, %xmm3
10342 ; SSE2-NEXT: por %xmm3, %xmm0
10343 ; SSE2-NEXT: retq
10386 ; SSE2-LABEL: test182:
10387 ; SSE2: # BB#0: # %entry
10388 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
10389 ; SSE2-NEXT: movdqa %xmm1, %xmm3
10390 ; SSE2-NEXT: pxor %xmm2, %xmm3
10391 ; SSE2-NEXT: pxor %xmm0, %xmm2
10392 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10393 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10394 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10395 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10396 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10397 ; SSE2-NEXT: pand %xmm5, %xmm2
10398 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10399 ; SSE2-NEXT: por %xmm2, %xmm3
10400 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
10401 ; SSE2-NEXT: pxor %xmm3, %xmm2
10402 ; SSE2-NEXT: pandn %xmm0, %xmm3
10403 ; SSE2-NEXT: pandn %xmm1, %xmm2
10404 ; SSE2-NEXT: por %xmm3, %xmm2
10405 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10406 ; SSE2-NEXT: retq
10455 ; SSE2-LABEL: test183:
10456 ; SSE2: # BB#0: # %entry
10457 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
10458 ; SSE2-NEXT: movdqa %xmm1, %xmm3
10459 ; SSE2-NEXT: pxor %xmm2, %xmm3
10460 ; SSE2-NEXT: pxor %xmm0, %xmm2
10461 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10462 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10463 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10464 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10465 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10466 ; SSE2-NEXT: pand %xmm5, %xmm2
10467 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10468 ; SSE2-NEXT: por %xmm2, %xmm3
10469 ; SSE2-NEXT: pand %xmm3, %xmm0
10470 ; SSE2-NEXT: pandn %xmm1, %xmm3
10471 ; SSE2-NEXT: por %xmm3, %xmm0
10472 ; SSE2-NEXT: retq
10515 ; SSE2-LABEL: test184:
10516 ; SSE2: # BB#0: # %entry
10517 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
10518 ; SSE2-NEXT: movdqa %xmm0, %xmm3
10519 ; SSE2-NEXT: pxor %xmm2, %xmm3
10520 ; SSE2-NEXT: pxor %xmm1, %xmm2
10521 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10522 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10523 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10524 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10525 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10526 ; SSE2-NEXT: pand %xmm5, %xmm2
10527 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10528 ; SSE2-NEXT: por %xmm2, %xmm3
10529 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
10530 ; SSE2-NEXT: pxor %xmm3, %xmm2
10531 ; SSE2-NEXT: pandn %xmm0, %xmm3
10532 ; SSE2-NEXT: pandn %xmm1, %xmm2
10533 ; SSE2-NEXT: por %xmm3, %xmm2
10534 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10535 ; SSE2-NEXT: retq
10583 ; SSE2-LABEL: test185:
10584 ; SSE2: # BB#0: # %entry
10585 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,0,2147483648,0]
10586 ; SSE2-NEXT: movdqa %xmm0, %xmm3
10587 ; SSE2-NEXT: pxor %xmm2, %xmm3
10588 ; SSE2-NEXT: pxor %xmm1, %xmm2
10589 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10590 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10591 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10592 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10593 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm2[1,1,3,3]
10594 ; SSE2-NEXT: pand %xmm5, %xmm3
10595 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm4[1,1,3,3]
10596 ; SSE2-NEXT: por %xmm3, %xmm2
10597 ; SSE2-NEXT: pand %xmm2, %xmm1
10598 ; SSE2-NEXT: pandn %xmm0, %xmm2
10599 ; SSE2-NEXT: por %xmm1, %xmm2
10600 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10601 ; SSE2-NEXT: retq
10635 ; SSE2-LABEL: test186:
10636 ; SSE2: # BB#0: # %entry
10637 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,0,2147483648,0]
10638 ; SSE2-NEXT: movdqa %xmm1, %xmm3
10639 ; SSE2-NEXT: pxor %xmm2, %xmm3
10640 ; SSE2-NEXT: pxor %xmm0, %xmm2
10641 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10642 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10643 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10644 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10645 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10646 ; SSE2-NEXT: pand %xmm5, %xmm2
10647 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10648 ; SSE2-NEXT: por %xmm2, %xmm3
10649 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
10650 ; SSE2-NEXT: pxor %xmm3, %xmm2
10651 ; SSE2-NEXT: pandn %xmm1, %xmm3
10652 ; SSE2-NEXT: pandn %xmm0, %xmm2
10653 ; SSE2-NEXT: por %xmm3, %xmm2
10654 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10655 ; SSE2-NEXT: retq
10694 ; SSE2-LABEL: test187:
10695 ; SSE2: # BB#0: # %entry
10696 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,0,2147483648,0]
10697 ; SSE2-NEXT: movdqa %xmm1, %xmm3
10698 ; SSE2-NEXT: pxor %xmm2, %xmm3
10699 ; SSE2-NEXT: pxor %xmm0, %xmm2
10700 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10701 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10702 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10703 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10704 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm2[1,1,3,3]
10705 ; SSE2-NEXT: pand %xmm5, %xmm3
10706 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm4[1,1,3,3]
10707 ; SSE2-NEXT: por %xmm3, %xmm2
10708 ; SSE2-NEXT: pand %xmm2, %xmm1
10709 ; SSE2-NEXT: pandn %xmm0, %xmm2
10710 ; SSE2-NEXT: por %xmm1, %xmm2
10711 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10712 ; SSE2-NEXT: retq
10745 ; SSE2-LABEL: test188:
10746 ; SSE2: # BB#0: # %entry
10747 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,0,2147483648,0]
10748 ; SSE2-NEXT: movdqa %xmm0, %xmm3
10749 ; SSE2-NEXT: pxor %xmm2, %xmm3
10750 ; SSE2-NEXT: pxor %xmm1, %xmm2
10751 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10752 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10753 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10754 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10755 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10756 ; SSE2-NEXT: pand %xmm5, %xmm2
10757 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10758 ; SSE2-NEXT: por %xmm2, %xmm3
10759 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
10760 ; SSE2-NEXT: pxor %xmm3, %xmm2
10761 ; SSE2-NEXT: pandn %xmm1, %xmm3
10762 ; SSE2-NEXT: pandn %xmm0, %xmm2
10763 ; SSE2-NEXT: por %xmm3, %xmm2
10764 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10765 ; SSE2-NEXT: retq
10805 ; SSE2-LABEL: test189:
10806 ; SSE2: # BB#0: # %entry
10807 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
10808 ; SSE2-NEXT: movdqa %xmm0, %xmm3
10809 ; SSE2-NEXT: pxor %xmm2, %xmm3
10810 ; SSE2-NEXT: pxor %xmm1, %xmm2
10811 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10812 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10813 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10814 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10815 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm2[1,1,3,3]
10816 ; SSE2-NEXT: pand %xmm5, %xmm3
10817 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm4[1,1,3,3]
10818 ; SSE2-NEXT: por %xmm3, %xmm2
10819 ; SSE2-NEXT: pand %xmm2, %xmm1
10820 ; SSE2-NEXT: pandn %xmm0, %xmm2
10821 ; SSE2-NEXT: por %xmm1, %xmm2
10822 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10823 ; SSE2-NEXT: retq
10866 ; SSE2-LABEL: test190:
10867 ; SSE2: # BB#0: # %entry
10868 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
10869 ; SSE2-NEXT: movdqa %xmm1, %xmm3
10870 ; SSE2-NEXT: pxor %xmm2, %xmm3
10871 ; SSE2-NEXT: pxor %xmm0, %xmm2
10872 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10873 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10874 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10875 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10876 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
10877 ; SSE2-NEXT: pand %xmm5, %xmm2
10878 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
10879 ; SSE2-NEXT: por %xmm2, %xmm3
10880 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
10881 ; SSE2-NEXT: pxor %xmm3, %xmm2
10882 ; SSE2-NEXT: pandn %xmm1, %xmm3
10883 ; SSE2-NEXT: pandn %xmm0, %xmm2
10884 ; SSE2-NEXT: por %xmm3, %xmm2
10885 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10886 ; SSE2-NEXT: retq
10935 ; SSE2-LABEL: test191:
10936 ; SSE2: # BB#0: # %entry
10937 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
10938 ; SSE2-NEXT: movdqa %xmm1, %xmm3
10939 ; SSE2-NEXT: pxor %xmm2, %xmm3
10940 ; SSE2-NEXT: pxor %xmm0, %xmm2
10941 ; SSE2-NEXT: movdqa %xmm2, %xmm4
10942 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
10943 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
10944 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
10945 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm2[1,1,3,3]
10946 ; SSE2-NEXT: pand %xmm5, %xmm3
10947 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm4[1,1,3,3]
10948 ; SSE2-NEXT: por %xmm3, %xmm2
10949 ; SSE2-NEXT: pand %xmm2, %xmm1
10950 ; SSE2-NEXT: pandn %xmm0, %xmm2
10951 ; SSE2-NEXT: por %xmm1, %xmm2
10952 ; SSE2-NEXT: movdqa %xmm2, %xmm0
10953 ; SSE2-NEXT: retq
10996 ; SSE2-LABEL: test192:
10997 ; SSE2: # BB#0: # %entry
10998 ; SSE2-NEXT: movdqa {{.*#+}} xmm2 = [2147483648,2147483648,2147483648,2147483648]
10999 ; SSE2-NEXT: movdqa %xmm0, %xmm3
11000 ; SSE2-NEXT: pxor %xmm2, %xmm3
11001 ; SSE2-NEXT: pxor %xmm1, %xmm2
11002 ; SSE2-NEXT: movdqa %xmm2, %xmm4
11003 ; SSE2-NEXT: pcmpgtd %xmm3, %xmm4
11004 ; SSE2-NEXT: pshufd {{.*#+}} xmm5 = xmm4[0,0,2,2]
11005 ; SSE2-NEXT: pcmpeqd %xmm3, %xmm2
11006 ; SSE2-NEXT: pshufd {{.*#+}} xmm2 = xmm2[1,1,3,3]
11007 ; SSE2-NEXT: pand %xmm5, %xmm2
11008 ; SSE2-NEXT: pshufd {{.*#+}} xmm3 = xmm4[1,1,3,3]
11009 ; SSE2-NEXT: por %xmm2, %xmm3
11010 ; SSE2-NEXT: pcmpeqd %xmm2, %xmm2
11011 ; SSE2-NEXT: pxor %xmm3, %xmm2
11012 ; SSE2-NEXT: pandn %xmm1, %xmm3
11013 ; SSE2-NEXT: pandn %xmm0, %xmm2
11014 ; SSE2-NEXT: por %xmm3, %xmm2
11015 ; SSE2-NEXT: movdqa %xmm2, %xmm0
11016 ; SSE2-NEXT: retq