1/* { dg-do compile { target { powerpc*-*-* } } } */
2/* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */
3/* { dg-require-effective-target powerpc_vsx_ok } */
4/* { dg-options "-O2 -mcpu=power7" } */
5/* { dg-final { scan-assembler "xvaddsp" } } */
6/* { dg-final { scan-assembler "xvsubsp" } } */
7/* { dg-final { scan-assembler "xvmulsp" } } */
8/* { dg-final { scan-assembler "xvmadd" } } */
9/* { dg-final { scan-assembler "xvmsub" } } */
10/* { dg-final { scan-assembler "xvnmadd" } } */
11/* { dg-final { scan-assembler "xvnmsub" } } */
12/* { dg-final { scan-assembler "xvdivsp" } } */
13/* { dg-final { scan-assembler "xvmaxsp" } } */
14/* { dg-final { scan-assembler "xvminsp" } } */
15/* { dg-final { scan-assembler "xvsqrtsp" } } */
16/* { dg-final { scan-assembler "xvabssp" } } */
17/* { dg-final { scan-assembler "xvnabssp" } } */
18/* { dg-final { scan-assembler "xvresp" } } */
19/* { dg-final { scan-assembler "xvrsqrtesp" } } */
20
21void use_builtins (__vector float *p, __vector float *q, __vector float *r, __vector float *s)
22{
23  p[0] = __builtin_vsx_xvaddsp (q[0], r[0]);
24  p[1] = __builtin_vsx_xvsubsp (q[1], r[1]);
25  p[2] = __builtin_vsx_xvmulsp (q[2], r[2]);
26  p[3] = __builtin_vsx_xvdivsp (q[3], r[3]);
27  p[4] = __builtin_vsx_xvmaxsp (q[4], r[4]);
28  p[5] = __builtin_vsx_xvminsp (q[5], r[5]);
29  p[6] = __builtin_vsx_xvabssp (q[6]);
30  p[7] = __builtin_vsx_xvnabssp (q[7]);
31  p[8] = __builtin_vsx_xvsqrtsp (q[8]);
32  p[9] = __builtin_vsx_xvmaddsp (q[9], r[9], s[9]);
33  p[10] = __builtin_vsx_xvmsubsp (q[10], r[10], s[10]);
34  p[11] = __builtin_vsx_xvnmaddsp (q[11], r[11], s[11]);
35  p[12] = __builtin_vsx_xvnmsubsp (q[12], r[12], s[12]);
36  p[13] = __builtin_vsx_xvresp (q[13]);
37  p[14] = __builtin_vsx_xvrsqrtesp (q[14]);
38}
39