1 /* { dg-do compile } */
2 /* { dg-options "-mvis3" } */
3 typedef int __v2si
__attribute__((vector_size(8)));
4 typedef short __v4hi
__attribute__((vector_size(8)));
6 __v4hi
test_fsll16 (__v4hi x
, __v4hi y
)
8 return __builtin_vis_fsll16 (x
, y
);
11 __v4hi
test_fslas16 (__v4hi x
, __v4hi y
)
13 return __builtin_vis_fslas16 (x
, y
);
16 __v4hi
test_fsrl16 (__v4hi x
, __v4hi y
)
18 return __builtin_vis_fsrl16 (x
, y
);
21 __v4hi
test_fsra16 (__v4hi x
, __v4hi y
)
23 return __builtin_vis_fsra16 (x
, y
);
26 __v2si
test_fsll32 (__v2si x
, __v2si y
)
28 return __builtin_vis_fsll32 (x
, y
);
31 __v2si
test_fslas32 (__v2si x
, __v2si y
)
33 return __builtin_vis_fslas32 (x
, y
);
36 __v2si
test_fsrl32 (__v2si x
, __v2si y
)
38 return __builtin_vis_fsrl32 (x
, y
);
41 __v2si
test_fsra32 (__v2si x
, __v2si y
)
43 return __builtin_vis_fsra32 (x
, y
);
46 /* { dg-final { scan-assembler "fsll16\t%" } } */
47 /* { dg-final { scan-assembler "fslas16\t%" } } */
48 /* { dg-final { scan-assembler "fsrl16\t%" } } */
49 /* { dg-final { scan-assembler "fsra16\t%" } } */
50 /* { dg-final { scan-assembler "fsll32\t%" } } */
51 /* { dg-final { scan-assembler "fslas32\t%" } } */
52 /* { dg-final { scan-assembler "fsrl32\t%" } } */
53 /* { dg-final { scan-assembler "fsra32\t%" } } */