| /* { dg-do run { target aarch64_sve_hw } } */ |
| /* { dg-options "-O2 -ftree-vectorize" } */ |
| |
| #include "cond_abd_1.c" |
| |
| #define N 99 |
| |
| #define TEST_LOOP(TYPE) \ |
| { \ |
| TYPE r[N], a[N], b[N], c[N]; \ |
| for (int i = 0; i < N; ++i) \ |
| { \ |
| a[i] = (i & 1 ? i : 3 * i); \ |
| b[i] = (i >> 4) << (i & 15); \ |
| c[i] = ((i + 2) % 3) * (i + 1); \ |
| asm volatile ("" ::: "memory"); \ |
| } \ |
| test_##TYPE (r, a, b, c, N); \ |
| for (int i = 0; i < N; ++i) \ |
| { \ |
| TYPE expected = a[i] < 20 ? abd (b[i], c[i]) : b[i]; \ |
| if (r[i] != expected) \ |
| __builtin_abort (); \ |
| asm volatile ("" ::: "memory"); \ |
| } \ |
| } |
| |
| int |
| main (void) |
| { |
| TEST_ALL (TEST_LOOP) |
| return 0; |
| } |