1 /* { dg-do compile { target i?86-*-* x86_64-*-* } } */
2 /* { dg-options "-O2 -msse2 -march=athlon" } */
3 /* { dg-final { scan-assembler "andpd" } } */
4 /* { dg-final { scan-assembler "andnpd" } } */
5 /* { dg-final { scan-assembler "xorpd" } } */
6 /* { dg-final { scan-assembler "orpd" } } */
7 /* { dg-final { scan-assembler-not "movdqa" } } */
8 /* { dg-final { scan-assembler "movapd" } } */
10 /* Verify that we generate proper instruction without memory operand. */
12 #include <xmmintrin.h>
14 t1(__m128d a, __m128d b)
18 return _mm_and_pd (a,b);
21 t2(__m128d a, __m128d b)
25 return _mm_andnot_pd (a,b);
28 t3(__m128d a, __m128d b)
32 return _mm_or_pd (a,b);
35 t4(__m128d a, __m128d b)
39 return _mm_xor_pd (a,b);