4 typedef signed char sc
;
5 typedef unsigned char uc
;
6 typedef signed short ss
;
7 typedef unsigned short us
;
9 typedef unsigned int ui
;
10 typedef signed long long sll
;
11 typedef unsigned long long ull
;
13 #define FOR_EACH_TYPE(M) \
20 #define TEST_VALUE(I) ((I) * 11 / 2)
22 #define ADD_TEST(TYPE) \
23 TYPE a_##TYPE[N * 2]; \
24 void __attribute__((noinline, noclone)) \
25 test_##TYPE (int x, int y) \
27 for (int i = 0; i < N; ++i) \
28 a_##TYPE[x - i] += a_##TYPE[y - i]; \
31 #define DO_TEST(TYPE) \
32 for (int i = 0; i < DIST * 2; ++i) \
34 for (int j = 0; j < N + DIST * 2; ++j) \
35 a_##TYPE[j] = TEST_VALUE (j); \
36 test_##TYPE (i + N - 1, DIST + N - 1); \
37 _Pragma("GCC novector") \
38 for (int j = 0; j < N + DIST * 2; ++j) \
41 if (j < i || j >= i + N) \
42 expected = TEST_VALUE (j); \
44 expected = ((TYPE) TEST_VALUE (j) \
45 + (TYPE) TEST_VALUE (j + DIST - i)); \
47 expected = ((TYPE) TEST_VALUE (j) \
48 + a_##TYPE[j + DIST - i]); \
49 if (expected != a_##TYPE[j]) \
54 FOR_EACH_TYPE (ADD_TEST
)
59 FOR_EACH_TYPE (DO_TEST
)
63 /* { dg-final { scan-tree-dump {flags: *WAR\n} "vect" { target vect_int } } } */
64 /* { dg-final { scan-tree-dump "using an index-based WAR/WAW test" "vect" { target { vect_int && vect_perm } } } } */
65 /* { dg-final { scan-tree-dump-not "using an address-based" "vect" } } */