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

Reply via email to