1 /* { dg-do compile } */
2 /* { dg-options "-O -mcpu=ultrasparc -mvis" } */
3 typedef int __v2si
__attribute__((vector_size(8)));
4 typedef int __v1si
__attribute__((vector_size(4)));
5 typedef short __v4hi
__attribute__((vector_size(8)));
6 typedef short __v2hi
__attribute__((vector_size(4)));
8 extern __v1si
foo_x (void);
9 extern __v1si
foo_y (void);
11 __v4hi
test_fpadd16 (__v4hi x
, __v4hi y
)
13 return __builtin_vis_fpadd16 (x
, y
);
16 __v2hi
test_fpadd16s (__v2hi x
, __v2hi y
)
18 return __builtin_vis_fpadd16s (x
, y
);
21 __v4hi
test_fpsub16 (__v4hi x
, __v4hi y
)
23 return __builtin_vis_fpsub16 (x
, y
);
26 __v2hi
test_fpsub16s (__v2hi x
, __v2hi y
)
28 return __builtin_vis_fpsub16s (x
, y
);
31 __v2si
test_fpadd32 (__v2si x
, __v2si y
)
33 return __builtin_vis_fpadd32 (x
, y
);
36 __v1si
test_fpadd32s (void)
38 return __builtin_vis_fpadd32s (foo_x (), foo_y ());
41 __v2si
test_fpsub32 (__v2si x
, __v2si y
)
43 return __builtin_vis_fpsub32 (x
, y
);
46 __v1si
test_fpsub32s (__v1si x
, __v1si y
)
48 return __builtin_vis_fpsub32s (foo_x (), foo_y ());
51 /* { dg-final { scan-assembler "fpadd16\t%" } } */
52 /* { dg-final { scan-assembler "fpadd16s\t%" } } */
53 /* { dg-final { scan-assembler "fpsub16\t%" } } */
54 /* { dg-final { scan-assembler "fpsub16s\t%" } } */
55 /* { dg-final { scan-assembler "fpadd32\t%" } } */
56 /* { dg-final { scan-assembler "fpadd32s\t%" } } */
57 /* { dg-final { scan-assembler "fpsub32\t%" } } */
58 /* { dg-final { scan-assembler "fpsub32s\t%" } } */