1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
/* { dg-do compile } */
/* { dg-options "-O2 -ftree-vectorize -fno-tree-dce -ffast-math -march=armv8-a+sve" } */
#define TEST_LOOP(NAME, OUTTYPE, INTYPE, MASKTYPE) \
void \
NAME##_3 (OUTTYPE *__restrict dest, INTYPE *__restrict src, \
MASKTYPE *__restrict cond, int n) \
{ \
for (int i = 0; i < n; ++i) \
if (cond[i]) \
dest[i] = src[i * 3] + src[i * 3 + 1]; \
}
#define TEST2(NAME, OUTTYPE, INTYPE) \
TEST_LOOP (NAME##_i8, OUTTYPE, INTYPE, signed char) \
TEST_LOOP (NAME##_i16, OUTTYPE, INTYPE, unsigned short) \
TEST_LOOP (NAME##_f32, OUTTYPE, INTYPE, float) \
TEST_LOOP (NAME##_f64, OUTTYPE, INTYPE, double)
#define TEST1(NAME, OUTTYPE) \
TEST2 (NAME##_i8, OUTTYPE, signed char) \
TEST2 (NAME##_i16, OUTTYPE, unsigned short) \
TEST2 (NAME##_i32, OUTTYPE, int) \
TEST2 (NAME##_i64, OUTTYPE, unsigned long)
#define TEST(NAME) \
TEST1 (NAME##_i8, signed char) \
TEST1 (NAME##_i16, unsigned short) \
TEST1 (NAME##_i32, int) \
TEST1 (NAME##_i64, unsigned long) \
TEST2 (NAME##_f32_f32, float, float) \
TEST2 (NAME##_f64_f64, double, double)
TEST (test)
/* { dg-final { scan-assembler-not {\tld3b\t} } } */
/* { dg-final { scan-assembler-not {\tld3h\t} } } */
/* { dg-final { scan-assembler-not {\tld3w\t} } } */
/* { dg-final { scan-assembler-not {\tld3d\t} } } */
|