/* { dg-do compile { target { ! ia32 } } } */ /* { dg-options "-O2 -mavx512vl -mavx512dq" } */ #include __m128d f1 (__m128d a, __m128d b) { register __m128d c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm_and_pd (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vandpd\[^\n\r\]*xmm\[0-9\]" 1 } } */ __m128d f2 (__m128d a, __m128d b) { register __m128d c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm_or_pd (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vorpd\[^\n\r\]*xmm\[0-9\]" 1 } } */ __m128d f3 (__m128d a, __m128d b) { register __m128d c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm_xor_pd (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vxorpd\[^\n\r\]*xmm\[0-9\]" 1 } } */ __m128d f4 (__m128d a, __m128d b) { register __m128d c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm_andnot_pd (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vandnpd\[^\n\r\]*xmm\[0-9\]" 1 } } */ __m128 f5 (__m128 a, __m128 b) { register __m128 c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm_and_ps (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vandps\[^\n\r\]*xmm\[0-9\]" 1 } } */ __m128 f6 (__m128 a, __m128 b) { register __m128 c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm_or_ps (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vorps\[^\n\r\]*xmm\[0-9\]" 1 } } */ __m128 f7 (__m128 a, __m128 b) { register __m128 c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm_xor_ps (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vxorps\[^\n\r\]*xmm\[0-9\]" 1 } } */ __m128 f8 (__m128 a, __m128 b) { register __m128 c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm_andnot_ps (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vandnps\[^\n\r\]*xmm\[0-9\]" 1 } } */ __m256d f9 (__m256d a, __m256d b) { register __m256d c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm256_and_pd (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vandpd\[^\n\r\]*ymm\[0-9\]" 1 } } */ __m256d f10 (__m256d a, __m256d b) { register __m256d c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm256_or_pd (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vorpd\[^\n\r\]*ymm\[0-9\]" 1 } } */ __m256d f11 (__m256d a, __m256d b) { register __m256d c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm256_xor_pd (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vxorpd\[^\n\r\]*ymm\[0-9\]" 1 } } */ __m256d f12 (__m256d a, __m256d b) { register __m256d c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm256_andnot_pd (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vandnpd\[^\n\r\]*ymm\[0-9\]" 1 } } */ __m256 f13 (__m256 a, __m256 b) { register __m256 c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm256_and_ps (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vandps\[^\n\r\]*ymm\[0-9\]" 1 } } */ __m256 f14 (__m256 a, __m256 b) { register __m256 c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm256_or_ps (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vorps\[^\n\r\]*ymm\[0-9\]" 1 } } */ __m256 f15 (__m256 a, __m256 b) { register __m256 c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm256_xor_ps (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vxorps\[^\n\r\]*ymm\[0-9\]" 1 } } */ __m256 f16 (__m256 a, __m256 b) { register __m256 c __asm ("xmm16") = a; asm volatile ("" : "+v" (c)); c = _mm256_andnot_ps (c, b); asm volatile ("" : "+v" (c)); return c; } /* { dg-final { scan-assembler-times "vandnps\[^\n\r\]*ymm\[0-9\]" 1 } } */