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