testsuite: Avoid strict aliasing violations in some avx512 tests
authorJakub Jelinek <jakub@redhat.com>
Tue, 8 Dec 2020 10:19:49 +0000 (11:19 +0100)
committerJakub Jelinek <jakub@redhat.com>
Tue, 8 Dec 2020 10:19:49 +0000 (11:19 +0100)
These tests violated strict aliasing, fixed by using a union and
type punning through that.

2020-12-08  Jakub Jelinek  <jakub@redhat.com>

* gcc.target/i386/avx512dq-vandnpd-2.c (CALC): Use union
to avoid aliasing violations.
* gcc.target/i386/avx512dq-vandnps-2.c (CALC): Likewise.
* gcc.target/i386/avx512dq-vandpd-2.c (CALC): Likewise.
* gcc.target/i386/avx512dq-vandps-2.c (CALC): Likewise.
* gcc.target/i386/avx512dq-vorpd-2.c (CALC): Likewise.
* gcc.target/i386/avx512dq-vorps-2.c (CALC): Likewise.
* gcc.target/i386/avx512dq-vxorpd-2.c (CALC): Likewise.
* gcc.target/i386/avx512dq-vxorps-2.c (CALC): Likewise.

gcc/testsuite/gcc.target/i386/avx512dq-vandnpd-2.c
gcc/testsuite/gcc.target/i386/avx512dq-vandnps-2.c
gcc/testsuite/gcc.target/i386/avx512dq-vandpd-2.c
gcc/testsuite/gcc.target/i386/avx512dq-vandps-2.c
gcc/testsuite/gcc.target/i386/avx512dq-vorpd-2.c
gcc/testsuite/gcc.target/i386/avx512dq-vorps-2.c
gcc/testsuite/gcc.target/i386/avx512dq-vxorpd-2.c
gcc/testsuite/gcc.target/i386/avx512dq-vxorps-2.c

index 0be2b7ceeb7491defbffc50199a941afaa5961d2..0a7d19b77bed443fbebd484ec765532e55e2aa12 100644 (file)
@@ -16,8 +16,11 @@ CALC (double *s1, double *s2, double *r)
 
   for (i = 0; i < SIZE; i++)
     {
-      tmp = (~(*(long long *) &s1[i])) & (*(long long *) &s2[i]);
-      r[i] = *(double *) &tmp;
+      union U { double d; long long l; } u1, u2;
+      u1.d = s1[i];
+      u2.d = s2[i];
+      u1.l = (~u1.l) & u2.l;
+      r[i] = u1.d;
     }
 }
 
index 39a45c1417fddada2cbf78fe499adc1b46459b12..836a7abada6ef9552dca8b4531024a95bed59f87 100644 (file)
@@ -16,8 +16,11 @@ CALC (float *s1, float *s2, float *r)
 
   for (i = 0; i < SIZE; i++)
     {
-      tmp = (~(*(int *) &s1[i])) & (*(int *) &s2[i]);
-      r[i] = *(float *) &tmp;
+      union U { float f; int i; } u1, u2;
+      u1.f = s1[i];
+      u2.f = s2[i];
+      u1.i = (~u1.i) & u2.i;
+      r[i] = u1.f;
     }
 }
 
index 208336b6532e434522ac19ebf557dc3711265e53..b629c9fa8f1ddc6bfc4760a80bcefe2ed1b400bc 100644 (file)
@@ -16,8 +16,11 @@ CALC (double *s1, double *s2, double *r)
 
   for (i = 0; i < SIZE; i++)
     {
-      tmp = (*(long long *) &s1[i]) & (*(long long *) &s2[i]);
-      r[i] = *(double *) &tmp;
+      union U { double d; long long l; } u1, u2;
+      u1.d = s1[i];
+      u2.d = s2[i];
+      u1.l &= u2.l;
+      r[i] = u1.d;
     }
 }
 
index 50268b907e0662dfbd6a667fb1a5b1b28db36566..6e55e66b8e311554abc40f20a6c2da1e7760c05e 100644 (file)
@@ -16,8 +16,11 @@ CALC (float *s1, float *s2, float *r)
 
   for (i = 0; i < SIZE; i++)
     {
-      tmp = (*(int *) &s1[i]) & (*(int *) &s2[i]);
-      r[i] = *(float *) &tmp;
+      union U { float f; int i; } u1, u2;
+      u1.f = s1[i];
+      u2.f = s2[i];
+      u1.i &= u2.i;
+      r[i] = u1.f;
     }
 }
 
index 97fe84ea3d6355f1d73cd838f9fdea7cfbcfb6be..6376c1cdd9fda96f6e9ae81d53258a52451976a5 100644 (file)
@@ -15,8 +15,11 @@ CALC (double *src1, double *src2, double *dst)
 
   for (i = 0; i < SIZE; i++)
     {
-      long long tmp = (*(long long *) &src1[i]) | (*(long long *) &src2[i]);
-      dst[i] = *(double *) &tmp;
+      union U { double d; long long l; } u1, u2;
+      u1.d = src1[i];
+      u2.d = src2[i];
+      u1.l |= u2.l;
+      dst[i] = u1.d;
     }
 }
 
index 95a7c5f29edadf01909a3d67328d982cb31f5ac5..3d30247e0322e96009c00589c0876c484a10e363 100644 (file)
@@ -15,8 +15,11 @@ CALC (float *src1, float *src2, float *dst)
 
   for (i = 0; i < SIZE; i++)
     {
-      int tmp = (*(int *) &src1[i]) | (*(int *) &src2[i]);
-      dst[i] = *(float *) &tmp;
+      union U { float f; int i; } u1, u2;
+      u1.f = src1[i];
+      u2.f = src2[i];
+      u1.i |= u2.i;
+      dst[i] = u1.f;
     }
 }
 
index 4f4a07e0e56d8ed5ff9387a9079a9a01b99f0edd..068be60ae90c3334f85798c58bcb0ef29c8cd8b3 100644 (file)
@@ -15,8 +15,11 @@ CALC (double *src1, double *src2, double *dst)
 
   for (i = 0; i < SIZE; i++)
     {
-      long long tmp = (*(long long *) &src1[i]) ^ (*(long long *) &src2[i]);
-      dst[i] = *(double *) &tmp;
+      union U { double d; long long l; } u1, u2;
+      u1.d = src1[i];
+      u2.d = src2[i];
+      u1.l ^= u2.l;
+      dst[i] = u1.d;
     }
 }
 
index 144283e36a47adc3b05d6d5ae6eb074e031c1b4b..716bb81c6db2e6a0d34160ee098eac49e4e35b57 100644 (file)
@@ -15,8 +15,11 @@ CALC (float *src1, float *src2, float *dst)
 
   for (i = 0; i < SIZE; i++)
     {
-      int tmp = (*(int *) &src1[i]) ^ (*(int *) &src2[i]);
-      dst[i] = *(float *) &tmp;
+      union U { float f; int i; } u1, u2;
+      u1.f = src1[i];
+      u2.f = src2[i];
+      u1.i ^= u2.i;
+      dst[i] = u1.f;
     }
 }