summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_1_run.c
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_1_run.c')
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_1_run.c13
1 files changed, 6 insertions, 7 deletions
diff --git a/gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_1_run.c b/gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_1_run.c
index fd48a4c96f9..f472e1da01d 100644
--- a/gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_1_run.c
+++ b/gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_1_run.c
@@ -1,12 +1,10 @@
/* { dg-do run { target aarch64_sve_hw } } */
-/* { dg-options "-O2 -ftree-vectorize -fno-tree-dce -ffast-math -march=armv8-a+sve" } */
+/* { dg-options "-O2 -ftree-vectorize -ffast-math -march=armv8-a+sve" } */
#include "sve_mask_struct_store_1.c"
#define N 100
-volatile int x;
-
#undef TEST_LOOP
#define TEST_LOOP(NAME, OUTTYPE, INTYPE, MASKTYPE) \
{ \
@@ -17,21 +15,22 @@ volatile int x;
{ \
in[i] = i * 7 / 2; \
mask[i] = i % 5 <= i % 3; \
+ asm volatile ("" ::: "memory"); \
} \
for (int i = 0; i < N * 2; ++i) \
out[i] = i * 9 / 2; \
- NAME##_2 (out, in, mask, N); \
+ NAME##_2 (out, in, mask, 17, N); \
for (int i = 0; i < N * 2; ++i) \
{ \
- OUTTYPE if_true = in[i / 2]; \
+ OUTTYPE if_true = (INTYPE) (in[i / 2] + 17); \
OUTTYPE if_false = i * 9 / 2; \
if (out[i] != (mask[i / 2] ? if_true : if_false)) \
__builtin_abort (); \
- x += 1; \
+ asm volatile ("" ::: "memory"); \
} \
}
-int
+int __attribute__ ((optimize (1)))
main (void)
{
TEST (test);