1 /* { dg-do compile { target { powerpc*-*-* && lp64 } } } */
2 /* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */
3 /* { dg-require-effective-target powerpc_p8vector_ok } */
4 /* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power8" } } */
5 /* { dg-options "-O2 -mcpu=power8" } */
6 /* { dg-final { scan-assembler-times "fcfid \|xscvsxddp " 2 } } */
7 /* { dg-final { scan-assembler-times "fcfids \|xscvsxdsp " 2 } } */
8 /* { dg-final { scan-assembler-times "fctiwz \|xscvdpsxws " 2 } } */
9 /* { dg-final { scan-assembler-times "fctiwuz \|xscvdpuxws " 2 } } */
10 /* { dg-final { scan-assembler-times {\mmfvsrwz\M} 2 } } */
11 /* { dg-final { scan-assembler-times {\mmtvsrwz\M} 2 } } */
12 /* { dg-final { scan-assembler-times {\mvupkhsw\M} 2 } } */
13 /* { dg-final { scan-assembler-times {\mxxpermdi\M} 2 } } */
14 /* { dg-final { scan-assembler-not {\mmfvsrd\M} } } */
15 /* { dg-final { scan-assembler-not {\mmtvsrwa\M} } } */
16 /* { dg-final { scan-assembler-not {\mlwz\M} } } */
17 /* { dg-final { scan-assembler-not {\mlfiwax\M} } } */
18 /* { dg-final { scan-assembler-not {\mlfiwzx\M} } } */
19 /* { dg-final { scan-assembler-not {\mstw\M} } } */
20 /* { dg-final { scan-assembler-not {\mstfiwx\M} } } */
22 /* Make sure we don't have loads/stores to the GPR unit. */
24 round_double_int (double a
)
26 return (double)(int)a
;
30 round_float_int (float a
)
36 round_double_uint (double a
)
38 return (double)(unsigned int)a
;
42 round_float_uint (float a
)
44 return (float)(unsigned int)a
;