The following works around SRA not being able to decompose an
aggregate copy of std::complex because with x87 math ld/st pairs
are not bit-preserving by adding -msse -mfpmath=sse. This avoids
spurious failures of the testcase.
Tested on x86_64-unknown-linux-gnu, pushed.
PR testsuite/123137
* g++.dg/vect/pr64410.cc: Add -mfpmath=sse -msse on x86.
---
gcc/testsuite/g++.dg/vect/pr64410.cc | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/gcc/testsuite/g++.dg/vect/pr64410.cc
b/gcc/testsuite/g++.dg/vect/pr64410.cc
index dd0256c2fe0..5bc92f74bd5 100644
--- a/gcc/testsuite/g++.dg/vect/pr64410.cc
+++ b/gcc/testsuite/g++.dg/vect/pr64410.cc
@@ -1,6 +1,9 @@
// { dg-do compile }
// { dg-require-effective-target vect_double }
// { dg-additional-options "-fexcess-precision=fast" }
+// We require decomposing a structure copy to double load/store pairs which
+// is not possible with x87 math.
+// { dg-additional-options "-msse -mfpmath=sse" { target { x86_64-*-* i?86-*-*
} } }
// { dg-skip-if "requires hosted libstdc++ for vector" { ! hostedlib } }
#include <vector>
@@ -51,4 +54,4 @@ main(int argc, char** argv)
return 0;
}
-// { dg-final { scan-tree-dump "pr64410.cc:46:29: optimized: loop vectorized"
"vect" } }
+// { dg-final { scan-tree-dump "pr64410.cc:49:29: optimized: loop vectorized"
"vect" } }
--
2.51.0