1 /* { dg-do compile { target { powerpc*-*-* && lp64 } } } */
2 /* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */
3 /* { dg-require-effective-target powerpc_p8vector_ok } */
4 /* { dg-options "-mcpu=power8 -O3 -mvsx-timode" } */
9 #define TYPE vector __int128_t
13 do_addcuq (TYPE p
, TYPE q
)
15 return __builtin_vec_vaddcuq (p
, q
);
19 do_adduqm (TYPE p
, TYPE q
)
21 return __builtin_vec_add (p
, q
);
25 do_addeuqm (TYPE p
, TYPE q
, TYPE r
)
27 return __builtin_vec_vaddeuqm (p
, q
, r
);
31 do_addecuq (TYPE p
, TYPE q
, TYPE r
)
33 return __builtin_vec_vaddecuq (p
, q
, r
);
37 do_subeuqm (TYPE p
, TYPE q
, TYPE r
)
39 return __builtin_vec_vsubeuqm (p
, q
, r
);
43 do_subecuq (TYPE p
, TYPE q
, TYPE r
)
45 return __builtin_vec_vsubecuq (p
, q
, r
);
49 do_subcuq (TYPE p
, TYPE q
)
51 return __builtin_vec_vsubcuq (p
, q
);
55 do_subuqm (TYPE p
, TYPE q
)
57 return __builtin_vec_vsubuqm (p
, q
);
72 /* { dg-final { scan-assembler "vaddcuq" } } */
73 /* { dg-final { scan-assembler "vadduqm" } } */
74 /* { dg-final { scan-assembler "vaddecuq" } } */
75 /* { dg-final { scan-assembler "vaddeuqm" } } */
76 /* { dg-final { scan-assembler "vsubecuq" } } */
77 /* { dg-final { scan-assembler "vsubeuqm" } } */
78 /* { dg-final { scan-assembler "vsubcuq" } } */
79 /* { dg-final { scan-assembler "vsubuqm" } } */
80 /* { dg-final { scan-assembler-not "mtvsrd" } } */
81 /* { dg-final { scan-assembler-not "mfvsrd" } } */
82 /* { dg-final { scan-assembler-not "ori 2,2,0" } } */
83 /* { dg-final { scan-assembler-not "xxpermdi" } } */
84 /* { dg-final { scan-assembler-not "stxvd2x" } } */
85 /* { dg-final { scan-assembler-not "stxvw4x" } } */