diff options
author | Jakub Jelinek <jakub@redhat.com> | 2016-05-10 16:30:02 +0200 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2016-05-10 16:30:02 +0200 |
commit | 4b59d19ffdb4857e14328d8d783176b97ccde23e (patch) | |
tree | 2d07650232d9d348ae2623cc257cce9b7030dcaa /gcc/testsuite | |
parent | 9b5ee426fcfe9d473edff34cd65f99c057799d7d (diff) | |
download | gcc-4b59d19ffdb4857e14328d8d783176b97ccde23e.zip gcc-4b59d19ffdb4857e14328d8d783176b97ccde23e.tar.gz gcc-4b59d19ffdb4857e14328d8d783176b97ccde23e.tar.bz2 |
re PR target/70927 ([6 only] avx512dq instructions emitted even with -mavx512vl -mno-avx512dq)
PR target/70927
* config/i386/sse.md (<sse>_andnot<mode>3<mask_name>),
*<code><mode>3<mask_name>): For !TARGET_AVX512DQ and EVEX encoding,
use vp*[dq] instead of v*p[sd] instructions and adjust mode attribute
accordingly.
* gcc.target/i386/avx512vl-logic-1.c: New test.
* gcc.target/i386/avx512vl-logic-2.c: New test.
* gcc.target/i386/avx512dq-logic-2.c: New test.
From-SVN: r236083
Diffstat (limited to 'gcc/testsuite')
-rw-r--r-- | gcc/testsuite/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/testsuite/gcc.target/i386/avx512dq-logic-2.c | 196 | ||||
-rw-r--r-- | gcc/testsuite/gcc.target/i386/avx512vl-logic-1.c | 132 | ||||
-rw-r--r-- | gcc/testsuite/gcc.target/i386/avx512vl-logic-2.c | 196 |
4 files changed, 531 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 58d0c8d..deec34e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,10 @@ +2016-05-10 Jakub Jelinek <jakub@redhat.com> + + PR target/70927 + * gcc.target/i386/avx512vl-logic-1.c: New test. + * gcc.target/i386/avx512vl-logic-2.c: New test. + * gcc.target/i386/avx512dq-logic-2.c: New test. + 2016-05-10 Bill Schmidt <wschmidt@linux.vnet.ibm.com> PR target/70963 diff --git a/gcc/testsuite/gcc.target/i386/avx512dq-logic-2.c b/gcc/testsuite/gcc.target/i386/avx512dq-logic-2.c new file mode 100644 index 0000000..e358ff5 --- /dev/null +++ b/gcc/testsuite/gcc.target/i386/avx512dq-logic-2.c @@ -0,0 +1,196 @@ +/* { 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 } } */ diff --git a/gcc/testsuite/gcc.target/i386/avx512vl-logic-1.c b/gcc/testsuite/gcc.target/i386/avx512vl-logic-1.c new file mode 100644 index 0000000..ec5f3d9 --- /dev/null +++ b/gcc/testsuite/gcc.target/i386/avx512vl-logic-1.c @@ -0,0 +1,132 @@ +/* { dg-do compile } */ +/* { dg-options "-O2 -mavx512vl -mno-avx512dq" } */ + +#include <x86intrin.h> + +__m128d +f1 (__m128d a, __m128d b) +{ + return _mm_and_pd (a, b); +} + +/* { dg-final { scan-assembler-times "vandpd\[^\n\r\]*xmm\[0-9\]" 1 } } */ + +__m128d +f2 (__m128d a, __m128d b) +{ + return _mm_or_pd (a, b); +} + +/* { dg-final { scan-assembler-times "vorpd\[^\n\r\]*xmm\[0-9\]" 1 } } */ + +__m128d +f3 (__m128d a, __m128d b) +{ + return _mm_xor_pd (a, b); +} + +/* { dg-final { scan-assembler-times "vxorpd\[^\n\r\]*xmm\[0-9\]" 1 } } */ + +__m128d +f4 (__m128d a, __m128d b) +{ + return _mm_andnot_pd (a, b); +} + +/* { dg-final { scan-assembler-times "vandnpd\[^\n\r\]*xmm\[0-9\]" 1 } } */ + +__m128 +f5 (__m128 a, __m128 b) +{ + return _mm_and_ps (a, b); +} + +/* { dg-final { scan-assembler-times "vandps\[^\n\r\]*xmm\[0-9\]" 1 } } */ + +__m128 +f6 (__m128 a, __m128 b) +{ + return _mm_or_ps (a, b); +} + +/* { dg-final { scan-assembler-times "vorps\[^\n\r\]*xmm\[0-9\]" 1 } } */ + +__m128 +f7 (__m128 a, __m128 b) +{ + return _mm_xor_ps (a, b); +} + +/* { dg-final { scan-assembler-times "vxorps\[^\n\r\]*xmm\[0-9\]" 1 } } */ + +__m128 +f8 (__m128 a, __m128 b) +{ + return _mm_andnot_ps (a, b); +} + +/* { dg-final { scan-assembler-times "vandnps\[^\n\r\]*xmm\[0-9\]" 1 } } */ + +__m256d +f9 (__m256d a, __m256d b) +{ + return _mm256_and_pd (a, b); +} + +/* { dg-final { scan-assembler-times "vandpd\[^\n\r\]*ymm\[0-9\]" 1 } } */ + +__m256d +f10 (__m256d a, __m256d b) +{ + return _mm256_or_pd (a, b); +} + +/* { dg-final { scan-assembler-times "vorpd\[^\n\r\]*ymm\[0-9\]" 1 } } */ + +__m256d +f11 (__m256d a, __m256d b) +{ + return _mm256_xor_pd (a, b); +} + +/* { dg-final { scan-assembler-times "vxorpd\[^\n\r\]*ymm\[0-9\]" 1 } } */ + +__m256d +f12 (__m256d a, __m256d b) +{ + return _mm256_andnot_pd (a, b); +} + +/* { dg-final { scan-assembler-times "vandnpd\[^\n\r\]*ymm\[0-9\]" 1 } } */ + +__m256 +f13 (__m256 a, __m256 b) +{ + return _mm256_and_ps (a, b); +} + +/* { dg-final { scan-assembler-times "vandps\[^\n\r\]*ymm\[0-9\]" 1 } } */ + +__m256 +f14 (__m256 a, __m256 b) +{ + return _mm256_or_ps (a, b); +} + +/* { dg-final { scan-assembler-times "vorps\[^\n\r\]*ymm\[0-9\]" 1 } } */ + +__m256 +f15 (__m256 a, __m256 b) +{ + return _mm256_xor_ps (a, b); +} + +/* { dg-final { scan-assembler-times "vxorps\[^\n\r\]*ymm\[0-9\]" 1 } } */ + +__m256 +f16 (__m256 a, __m256 b) +{ + return _mm256_andnot_ps (a, b); +} + +/* { dg-final { scan-assembler-times "vandnps\[^\n\r\]*ymm\[0-9\]" 1 } } */ diff --git a/gcc/testsuite/gcc.target/i386/avx512vl-logic-2.c b/gcc/testsuite/gcc.target/i386/avx512vl-logic-2.c new file mode 100644 index 0000000..7ccef27 --- /dev/null +++ b/gcc/testsuite/gcc.target/i386/avx512vl-logic-2.c @@ -0,0 +1,196 @@ +/* { dg-do compile { target { ! ia32 } } } */ +/* { dg-options "-O2 -mavx512vl -mno-avx512dq" } */ + +#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 "vpandq\[^\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 "vporq\[^\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 "vpxorq\[^\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 "vpandnq\[^\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 "vpandd\[^\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 "vpord\[^\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 "vpxord\[^\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 "vpandnd\[^\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 "vpandq\[^\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 "vporq\[^\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 "vpxorq\[^\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 "vpandnq\[^\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 "vpandd\[^\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 "vpord\[^\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 "vpxord\[^\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 "vpandnd\[^\n\r\]*ymm\[0-9\]" 1 } } */ |