blob: e358ff56848d8ffeb4e6ebc37f4b4708838c2c62 [file] [log] [blame]
/* { dg-do compile { target { ! ia32 } } } */
/* { dg-options "-O2 -mavx512vl -mavx512dq" } */
#include <x86intrin.h>
__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 } } */