aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/i386/pr113079.c
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gcc.target/i386/pr113079.c')
-rw-r--r--gcc/testsuite/gcc.target/i386/pr113079.c57
1 files changed, 57 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.target/i386/pr113079.c b/gcc/testsuite/gcc.target/i386/pr113079.c
new file mode 100644
index 0000000..a2232c2
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr113079.c
@@ -0,0 +1,57 @@
+/* { dg-do compile { target { ! ia32 } } } */
+/* { dg-options "-mavxvnniint8 -mavxvnniint16 -O2 -mavxvnni" } */
+/* { dg-final { scan-assembler-times "vpdpbusd" 1 } } */
+/* { dg-final { scan-assembler-times "vpdpbssd" 1 } } */
+/* { dg-final { scan-assembler-times "vpdpbuud" 1 } } */
+/* { dg-final { scan-assembler-times "vpdpwssd" 1 } } */
+/* { dg-final { scan-assembler-times "vpdpwuud" 1 } } */
+/* { dg-final { scan-assembler-times "vpdpwusd" 1 } } */
+
+int
+__attribute__((noinline))
+usdot_prodv8qi (unsigned char* p, char* q, int sum)
+{
+ for (int i = 0; i != 8; i++)
+ sum += p[i] * q[i];
+ return sum;
+}
+
+int
+udot_prodv8qi (unsigned char* p, unsigned char* q, int sum)
+{
+ for (int i = 0; i != 8; i++)
+ sum += p[i] * q[i];
+ return sum;
+}
+
+int
+sdot_prodv8qi (char* p, char* q, int sum)
+{
+ for (int i = 0; i != 8; i++)
+ sum += p[i] * q[i];
+ return sum;
+}
+
+int
+usdot_prodv4hi (unsigned short* p, short* q, int sum)
+{
+ for (int i = 0; i != 4; i++)
+ sum += p[i] * q[i];
+ return sum;
+}
+
+int
+sdot_prodv4hi (short* p, short* q, int sum)
+{
+ for (int i = 0; i != 4; i++)
+ sum += p[i] * q[i];
+ return sum;
+}
+
+int
+udot_prodv4hi (unsigned short* p, unsigned short* q, int sum)
+{
+ for (int i = 0; i != 4; i++)
+ sum += p[i] * q[i];
+ return sum;
+}