summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/i386/avx512f-set-v8di-5.c
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gcc.target/i386/avx512f-set-v8di-5.c')
-rw-r--r--gcc/testsuite/gcc.target/i386/avx512f-set-v8di-5.c87
1 files changed, 87 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.target/i386/avx512f-set-v8di-5.c b/gcc/testsuite/gcc.target/i386/avx512f-set-v8di-5.c
new file mode 100644
index 00000000000..76ec4438897
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/avx512f-set-v8di-5.c
@@ -0,0 +1,87 @@
+/* { dg-do run } */
+/* { dg-options "-O2 -mavx512f" } */
+/* { dg-require-effective-target avx512f } */
+
+#include "avx512f-check.h"
+
+static __m512i
+__attribute__ ((noinline))
+foo (long long x, int i)
+{
+ switch (i)
+ {
+ case 7:
+ return _mm512_set_epi64 (x, 1, 1, 1, 1, 1, 1, 1);
+ case 6:
+ return _mm512_set_epi64 (1, x, 1, 1, 1, 1, 1, 1);
+ case 5:
+ return _mm512_set_epi64 (1, 1, x, 1, 1, 1, 1, 1);
+ case 4:
+ return _mm512_set_epi64 (1, 1, 1, x, 1, 1, 1, 1);
+ case 3:
+ return _mm512_set_epi64 (1, 1, 1, 1, x, 1, 1, 1);
+ case 2:
+ return _mm512_set_epi64 (1, 1, 1, 1, 1, x, 1, 1);
+ case 1:
+ return _mm512_set_epi64 (1, 1, 1, 1, 1, 1, x, 1);
+ case 0:
+ return _mm512_set_epi64 (1, 1, 1, 1, 1, 1, 1, x);
+ default:
+ abort ();
+ }
+}
+
+static __m512i
+__attribute__ ((noinline))
+foo_r (long long x, int i)
+{
+ switch (i)
+ {
+ case 0:
+ return _mm512_setr_epi64 (x, 1, 1, 1, 1, 1, 1, 1);
+ case 1:
+ return _mm512_setr_epi64 (1, x, 1, 1, 1, 1, 1, 1);
+ case 2:
+ return _mm512_setr_epi64 (1, 1, x, 1, 1, 1, 1, 1);
+ case 3:
+ return _mm512_setr_epi64 (1, 1, 1, x, 1, 1, 1, 1);
+ case 4:
+ return _mm512_setr_epi64 (1, 1, 1, 1, x, 1, 1, 1);
+ case 5:
+ return _mm512_setr_epi64 (1, 1, 1, 1, 1, x, 1, 1);
+ case 6:
+ return _mm512_setr_epi64 (1, 1, 1, 1, 1, 1, x, 1);
+ case 7:
+ return _mm512_setr_epi64 (1, 1, 1, 1, 1, 1, 1, x);
+ default:
+ abort ();
+ }
+}
+
+static void
+avx512f_test (void)
+{
+ long long e = 0xabadbeef01234567LL;
+ long long v[8];
+ union512i_q res;
+ int i, j;
+
+ for (i = 0; i < 8; i++)
+ {
+ for (j = 0; j < 8; j++)
+ v[j] = 1;
+ v[i] = e;
+
+ res.x = foo (e, i);
+
+ if (check_union512i_q (res, v))
+ abort ();
+
+ res.x = _mm512_setzero_si512 ();
+
+ res.x = foo_r (e, i);
+
+ if (check_union512i_q (res, v))
+ abort ();
+ }
+}