2018-03-08 Richard Biener <rguenther@suse.de>
[official-gcc.git] / gcc / testsuite / gcc.target / powerpc / ppc-round2.c
blob938d545602cf1952bab3828aa4a8f0d86980d071
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. */
23 double
24 round_double_int (double a)
26 return (double)(int)a;
29 float
30 round_float_int (float a)
32 return (float)(int)a;
35 double
36 round_double_uint (double a)
38 return (double)(unsigned int)a;
41 float
42 round_float_uint (float a)
44 return (float)(unsigned int)a;