1 /* Verify that overloaded built-ins for vec_extract() with char
2 inputs produce the right code with a P9 (LE) target. */
4 /* { dg-do compile } */
5 /* { dg-require-effective-target powerpc_vsx_ok } */
6 /* { dg-options "-mdejagnu-cpu=power9 -mvsx -O2 " } */
8 /* { dg-final { scan-assembler-times {\mli\M} 3 { target lp64 } } } */
9 /* Endian sensitive, vextubrx or vextublx. */
10 /* { dg-final { scan-assembler-times "vextubrx|vextublx" 6 { target lp64 } } } */
11 /* { dg-final { scan-assembler-times "extsb" 2 } } */
13 /* { dg-final { scan-assembler-times "stxv" 6 { target ilp32 } } } */
14 /* { dg-final { scan-assembler-times "lbz" 6 { target ilp32 } } } */
20 testbc_var (vector
bool char vbc2
,signed int si
)
22 return vec_extract (vbc2
, si
);
26 testsc_var (vector
signed char vsc2
, signed int si
)
28 return vec_extract (vsc2
, si
);
32 testuc_var (vector
unsigned char vuc2
, signed int si
)
34 return vec_extract (vuc2
, si
);
38 testbc_cst (vector
bool char vbc2
)
40 return vec_extract (vbc2
, 12);
44 testsc_cst (vector
signed char vsc2
)
46 return vec_extract (vsc2
, 12);
50 testuc_cst (vector
unsigned char vuc2
)
52 return vec_extract (vuc2
, 12);