aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gcc.target/i386/avx512f-kortestw-2.c
diff options
context:
space:
mode:
Diffstat (limited to 'gcc-4.9/gcc/testsuite/gcc.target/i386/avx512f-kortestw-2.c')
-rw-r--r--gcc-4.9/gcc/testsuite/gcc.target/i386/avx512f-kortestw-2.c53
1 files changed, 53 insertions, 0 deletions
diff --git a/gcc-4.9/gcc/testsuite/gcc.target/i386/avx512f-kortestw-2.c b/gcc-4.9/gcc/testsuite/gcc.target/i386/avx512f-kortestw-2.c
new file mode 100644
index 000000000..4b9cadcc2
--- /dev/null
+++ b/gcc-4.9/gcc/testsuite/gcc.target/i386/avx512f-kortestw-2.c
@@ -0,0 +1,53 @@
+/* { dg-do run } */
+/* { dg-options "-O2 -mavx512f" } */
+/* { dg-require-effective-target avx512f } */
+
+#include "avx512f-check.h"
+
+void
+avx512f_test () {
+ volatile __mmask16 k1;
+ __mmask16 k2;
+ volatile short r = 0;
+
+ /* Test kortestc. */
+ __asm__( "kmovw %1, %0" : "=k" (k1) : "r" (0) );
+ __asm__( "kmovw %1, %0" : "=k" (k2) : "r" (45) );
+
+ r += _mm512_kortestc (k1, k2);
+
+ __asm__( "kmovw %1, %0" : "=k" (k1) : "r" (0) );
+ __asm__( "kmovw %1, %0" : "=k" (k2) : "r" (0) );
+
+ r += _mm512_kortestc (k1, k2);
+ if (r)
+ abort ();
+
+ __asm__( "kmovw %1, %0" : "=k" (k1) : "r" (-1) );
+ __asm__( "kmovw %1, %0" : "=k" (k2) : "r" (0) );
+
+ r += _mm512_kortestc (k1, k2);
+ if (!r)
+ abort ();
+
+ r = 0;
+ /* Test kortestz. */
+ __asm__( "kmovw %1, %0" : "=k" (k1) : "r" (0) );
+ __asm__( "kmovw %1, %0" : "=k" (k2) : "r" (45) );
+
+ r += _mm512_kortestz (k1, k2);
+
+ __asm__( "kmovw %1, %0" : "=k" (k1) : "r" (-1) );
+ __asm__( "kmovw %1, %0" : "=k" (k2) : "r" (0) );
+
+ r += _mm512_kortestz (k1, k2);
+ if (r)
+ abort ();
+
+ __asm__( "kmovw %1, %0" : "=k" (k1) : "r" (0) );
+ __asm__( "kmovw %1, %0" : "=k" (k2) : "r" (0) );
+
+ r += _mm512_kortestz (k1, k2);
+ if (!r)
+ abort ();
+}