diff options
Diffstat (limited to 'gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_3_run.c')
-rw-r--r-- | gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_3_run.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_3_run.c b/gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_3_run.c index f845818fa4d..cbac3da9db2 100644 --- a/gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_3_run.c +++ b/gcc/testsuite/gcc.target/aarch64/sve_mask_struct_store_3_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_3.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 * 4; ++i) \ out[i] = i * 9 / 2; \ - NAME##_4 (out, in, mask, N); \ + NAME##_4 (out, in, mask, 42, N); \ for (int i = 0; i < N * 4; ++i) \ { \ - OUTTYPE if_true = in[i / 4]; \ + OUTTYPE if_true = (INTYPE) (in[i / 4] + 42); \ OUTTYPE if_false = i * 9 / 2; \ if (out[i] != (mask[i / 4] ? if_true : if_false)) \ __builtin_abort (); \ - x += 1; \ + asm volatile ("" ::: "memory"); \ } \ } -int +int __attribute__ ((optimize (1))) main (void) { TEST (test); |