PR tree-optimization/88531
        * gcc.target/i386/pr88531-1a.c: New test.
        * gcc.target/i386/pr88531-1b.c: Likewise.
        * gcc.target/i386/pr88531-1c.c: Likewise.
        * gcc.target/i386/pr88531-2a.c: Likewise.
        * gcc.target/i386/pr88531-2b.c: Likewise.
        * gcc.target/i386/pr88531-2c.c: Likewise.
---
 gcc/testsuite/gcc.target/i386/pr88531-1a.c | 19 +++++++++++++++++++
 gcc/testsuite/gcc.target/i386/pr88531-1b.c |  8 ++++++++
 gcc/testsuite/gcc.target/i386/pr88531-1c.c |  8 ++++++++
 gcc/testsuite/gcc.target/i386/pr88531-2a.c | 19 +++++++++++++++++++
 gcc/testsuite/gcc.target/i386/pr88531-2b.c |  6 ++++++
 gcc/testsuite/gcc.target/i386/pr88531-2c.c |  6 ++++++
 6 files changed, 66 insertions(+)
 create mode 100644 gcc/testsuite/gcc.target/i386/pr88531-1a.c
 create mode 100644 gcc/testsuite/gcc.target/i386/pr88531-1b.c
 create mode 100644 gcc/testsuite/gcc.target/i386/pr88531-1c.c
 create mode 100644 gcc/testsuite/gcc.target/i386/pr88531-2a.c
 create mode 100644 gcc/testsuite/gcc.target/i386/pr88531-2b.c
 create mode 100644 gcc/testsuite/gcc.target/i386/pr88531-2c.c

diff --git a/gcc/testsuite/gcc.target/i386/pr88531-1a.c 
b/gcc/testsuite/gcc.target/i386/pr88531-1a.c
new file mode 100644
index 00000000000..d1c29b2c990
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr88531-1a.c
@@ -0,0 +1,19 @@
+/* { dg-do compile { target lp64 } } */
+/* { dg-options "-O3 -march=x86-64 -mfpmath=sse" } */
+
+#include <stdint.h>
+
+#define loop_t uint32_t
+#define idx_t uint32_t
+
+void loop(double * const __restrict__ dst,
+          double const * const __restrict__ src,
+          idx_t const * const __restrict__ idx,
+          loop_t const begin,
+          loop_t const end)
+{
+  for (loop_t i = begin; i < end; ++i)
+    dst[i] = 42.0 * src[idx[i]];
+}
+
+/* { dg-final { scan-assembler-times "mulpd" 2 } } */
diff --git a/gcc/testsuite/gcc.target/i386/pr88531-1b.c 
b/gcc/testsuite/gcc.target/i386/pr88531-1b.c
new file mode 100644
index 00000000000..812c8a10fab
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr88531-1b.c
@@ -0,0 +1,8 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -march=skylake -mfpmath=sse" } */
+
+#include "pr88531-1a.c"
+
+/* { dg-final { scan-assembler-times "vgatherdpd" 4 { target { ! lp64 } } } } 
*/
+/* { dg-final { scan-assembler-times "vgatherqpd" 4 { target lp64 } } } */
+/* { dg-final { scan-assembler-times "vmulpd" 4 } } */
diff --git a/gcc/testsuite/gcc.target/i386/pr88531-1c.c 
b/gcc/testsuite/gcc.target/i386/pr88531-1c.c
new file mode 100644
index 00000000000..43fc5913ed3
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr88531-1c.c
@@ -0,0 +1,8 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -march=skylake-avx512 -mfpmath=sse" } */
+
+#include "pr88531-1a.c"
+
+/* { dg-final { scan-assembler-times "vgatherdpd" 4 { target { ! lp64 } } } } 
*/
+/* { dg-final { scan-assembler-times "vgatherqpd" 4 { target lp64 } } } */
+/* { dg-final { scan-assembler-times "vmulpd" 4 } } */
diff --git a/gcc/testsuite/gcc.target/i386/pr88531-2a.c 
b/gcc/testsuite/gcc.target/i386/pr88531-2a.c
new file mode 100644
index 00000000000..8ab2b1385eb
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr88531-2a.c
@@ -0,0 +1,19 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -march=x86-64 -mfpmath=sse" } */
+
+#include <stdint.h>
+
+#define loop_t uint32_t
+#define idx_t uint32_t
+
+void loop(float * const __restrict__ dst,
+          float const * const __restrict__ src,
+          idx_t const * const __restrict__ idx,
+          loop_t const begin,
+          loop_t const end)
+{
+  for (loop_t i = begin; i < end; ++i)
+    dst[i] = 42.0 * src[idx[i]];
+}
+
+/* { dg-final { scan-assembler-times "mulps" 1 } } */
diff --git a/gcc/testsuite/gcc.target/i386/pr88531-2b.c 
b/gcc/testsuite/gcc.target/i386/pr88531-2b.c
new file mode 100644
index 00000000000..011607c3d54
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr88531-2b.c
@@ -0,0 +1,6 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -march=skylake -mfpmath=sse" } */
+
+#include "pr88531-2a.c"
+
+/* { dg-final { scan-assembler-times "vmulps" 2 } } */
diff --git a/gcc/testsuite/gcc.target/i386/pr88531-2c.c 
b/gcc/testsuite/gcc.target/i386/pr88531-2c.c
new file mode 100644
index 00000000000..0f7ec3832f8
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr88531-2c.c
@@ -0,0 +1,6 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -march=skylake-avx512 -mfpmath=sse" } */
+
+#include "pr88531-2a.c"
+
+/* { dg-final { scan-assembler-times "vmulps" 2 } } */
-- 
2.31.1

Reply via email to