blob: 18a5ce7879218edbc078b61124f091e840c31667 [file] [log] [blame]
/* { dg-do compile */
/* { dg-require-effective-target powerpc_vsx_ok } */
/* { dg-options "-O2 -mvsx" } */
/* PR 70423, Make sure we don't generate vmaddfp or vnmsubfp. These
instructions have different rounding modes than the VSX instructions
xvmaddsp and xvnmsubsp. These tests are written where the 3 inputs and
target are all separate registers. Because vmaddfp and vnmsubfp are no
longer generated the compiler will have to generate an xsmaddsp or xsnmsubsp
instruction followed by a move operation. */
#include <altivec.h>
vector float
do_add1 (vector float dummy, vector float a, vector float b, vector float c)
{
return (a * b) + c;
}
vector float
do_nsub1 (vector float dummy, vector float a, vector float b, vector float c)
{
return -((a * b) - c);
}
vector float
do_add2 (vector float dummy, vector float a, vector float b, vector float c)
{
return vec_madd (a, b, c);
}
vector float
do_nsub2 (vector float dummy, vector float a, vector float b, vector float c)
{
return vec_nmsub (a, b, c);
}
/* { dg-final { scan-assembler {\mxvmadd[am]sp\M} } } */
/* { dg-final { scan-assembler {\mxvnmsub[am]sp\M} } } */
/* { dg-final { scan-assembler-not {\mvmaddfp\M} } } */
/* { dg-final { scan-assembler-not {\mvnmsubfp\M} } } */