aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom de Vries <tom@codesourcery.com>2015-02-22 10:54:56 +0000
committerTom de Vries <vries@gcc.gnu.org>2015-02-22 10:54:56 +0000
commitffefa9288ab95b06b1dfed95e7235f4c09619a91 (patch)
tree83e7f367d165409d83678849565baefd9502f1a2
parent42924e4bc2eaa8f1dd8b7ac2a4498617c0a95ac4 (diff)
downloadgcc-ffefa9288ab95b06b1dfed95e7235f4c09619a91.zip
gcc-ffefa9288ab95b06b1dfed95e7235f4c09619a91.tar.gz
gcc-ffefa9288ab95b06b1dfed95e7235f4c09619a91.tar.bz2
Make pr30957-1.c pass rather xfail
2015-02-22 Tom de Vries <tom@codesourcery.com> * gcc.dg/pr30957-1.c: Make pr30957-1.c pass rather xfail. From-SVN: r220893
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.dg/pr30957-1.c22
2 files changed, 15 insertions, 11 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index e91532c..5ef35b9 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2015-02-22 Tom de Vries <tom@codesourcery.com>
+
+ * gcc.dg/pr30957-1.c: Make pr30957-1.c pass rather xfail.
+
2015-02-21 Arnaud Charlet <charlet@adacore.com>
PR ada/65156
diff --git a/gcc/testsuite/gcc.dg/pr30957-1.c b/gcc/testsuite/gcc.dg/pr30957-1.c
index 65b98fa..f34c6e5 100644
--- a/gcc/testsuite/gcc.dg/pr30957-1.c
+++ b/gcc/testsuite/gcc.dg/pr30957-1.c
@@ -1,12 +1,9 @@
-/* { dg-do run { xfail *-*-* } } */
-/* We don't (and don't want to) perform this optimisation on soft-float
- targets, where each addition is a library call. This test requires
- -fassociative-math for enabling the variable-expansion as well as
- -fsigned-zeros for honoring the sign of zero; but
- they can not co-exist; also under -funsafe-math-optimizations, so we
- expect it to fail. */
+/* { dg-do run } */
+/* We don't (and don't want to) perform this optimisation on soft-float targets,
+ where each addition is a library call. /
/* { dg-require-effective-target hard_float } */
-/* { dg-options "-O2 -funroll-loops -funsafe-math-optimizations -fvariable-expansion-in-unroller -fdump-rtl-loop2_unroll" } */
+/* -fassociative-math requires -fno-trapping-math and -fno-signed-zeros. */
+/* { dg-options "-O2 -funroll-loops -fassociative-math -fno-trapping-math -fno-signed-zeros -fvariable-expansion-in-unroller -fdump-rtl-loop2_unroll" } */
extern void abort (void);
extern void exit (int);
@@ -26,12 +23,15 @@ foo (float d, int n)
int
main ()
{
- if (__builtin_copysignf (1.0, foo (0.0 / -5.0, 10)) != -1.0)
+ /* When compiling standard compliant we expect foo to return -0.0. But the
+ variable expansion during unrolling optimization (for this testcase enabled
+ by non-compliant -fassociative-math) instantiates copy(s) of the
+ accumulator which it initializes with +0.0. Hence we expect that foo
+ returns +0.0. */
+ if (__builtin_copysignf (1.0, foo (0.0 / -5.0, 10)) != 1.0)
abort ();
exit (0);
}
/* { dg-final { scan-rtl-dump "Expanding Accumulator" "loop2_unroll" } } */
/* { dg-final { cleanup-rtl-dump "loop*" } } */
-
-