1 /* { dg-do compile } */
2 /* { dg-skip-if "" { powerpc*-*-darwin* } } */
3 /* { dg-options "-mdejagnu-cpu=power8 -mvsx -O3" } */
4 /* { dg-require-effective-target powerpc_vsx } */
5 /* { dg-require-effective-target int128 } */
10 #define TYPE vector __int128_t
14 do_addcuq (TYPE p
, TYPE q
)
16 return __builtin_vec_vaddcuq (p
, q
);
20 do_adduqm (TYPE p
, TYPE q
)
22 return __builtin_vec_add (p
, q
);
26 do_addeuqm (TYPE p
, TYPE q
, TYPE r
)
28 return __builtin_vec_vaddeuqm (p
, q
, r
);
32 do_addecuq (TYPE p
, TYPE q
, TYPE r
)
34 return __builtin_vec_vaddecuq (p
, q
, r
);
38 do_subeuqm (TYPE p
, TYPE q
, TYPE r
)
40 return __builtin_vec_vsubeuqm (p
, q
, r
);
44 do_subecuq (TYPE p
, TYPE q
, TYPE r
)
46 return __builtin_vec_vsubecuq (p
, q
, r
);
50 do_subcuq (TYPE p
, TYPE q
)
52 return __builtin_vec_vsubcuq (p
, q
);
56 do_subuqm (TYPE p
, TYPE q
)
58 return __builtin_vec_vsubuqm (p
, q
);
73 /* { dg-final { scan-assembler "vaddcuq" } } */
74 /* { dg-final { scan-assembler "vadduqm" } } */
75 /* { dg-final { scan-assembler "vaddecuq" } } */
76 /* { dg-final { scan-assembler "vaddeuqm" } } */
77 /* { dg-final { scan-assembler "vsubecuq" } } */
78 /* { dg-final { scan-assembler "vsubeuqm" } } */
79 /* { dg-final { scan-assembler "vsubcuq" } } */
80 /* { dg-final { scan-assembler "vsubuqm" } } */
81 /* { dg-final { scan-assembler-not "mtvsrd" } } */
82 /* { dg-final { scan-assembler-not "mfvsrd" } } */
83 /* { dg-final { scan-assembler-not "ori 2,2,0" } } */
84 /* { dg-final { scan-assembler-not "xxpermdi" } } */
85 /* { dg-final { scan-assembler-not "stxvd2x" } } */
86 /* { dg-final { scan-assembler-not "stxvw4x" } } */