aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorHans-Peter Nilsson <hp@bitrange.com>2002-09-20 03:04:15 +0000
committerHans-Peter Nilsson <hp@gcc.gnu.org>2002-09-20 03:04:15 +0000
commite7a35dcc29ba93c9cdcd93c0c3b08bcced20309e (patch)
treec56f242ad4d1746340f11178edfa0b9269b32b5c /gcc
parentf08b7eee210a6a29c05422b3071627af78846bd3 (diff)
downloadgcc-e7a35dcc29ba93c9cdcd93c0c3b08bcced20309e.zip
gcc-e7a35dcc29ba93c9cdcd93c0c3b08bcced20309e.tar.gz
gcc-e7a35dcc29ba93c9cdcd93c0c3b08bcced20309e.tar.bz2
* gcc.c-torture/execute/ieee/mzero3.c: New test.
From-SVN: r57331
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog2
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/ieee/mzero3.c51
2 files changed, 53 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 436926d..970342e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,7 @@
2002-09-20 Hans-Peter Nilsson <hp@bitrange.com>
+ * gcc.c-torture/execute/ieee/mzero3.c: New test.
+
* lib/scanasm.exp (scan-assembler-dem, scan-assembler-dem-not):
Adjust for c++filt moved to binutils. Remove spurious duplicate
setting of cxxfilt.
diff --git a/gcc/testsuite/gcc.c-torture/execute/ieee/mzero3.c b/gcc/testsuite/gcc.c-torture/execute/ieee/mzero3.c
new file mode 100644
index 0000000..fdfb8a1
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/execute/ieee/mzero3.c
@@ -0,0 +1,51 @@
+/* Copyright (C) 2002 Free Software Foundation.
+ by Hans-Peter Nilsson <hp@bitrange.com>, derived from mzero2.c
+
+ In the MMIX port, negdf2 was bogusly expanding -x into 0 - x. */
+
+double nzerod = -0.0;
+float nzerof = -0.0;
+double zerod = 0.0;
+float zerof = 0.0;
+
+void expectd (double, double);
+void expectf (float, float);
+double negd (double);
+float negf (float);
+
+main ()
+{
+ expectd (negd (zerod), nzerod);
+ expectf (negf (zerof), nzerof);
+ expectd (negd (nzerod), zerod);
+ expectf (negf (nzerof), zerof);
+ exit (0);
+}
+
+void
+expectd (double value, double expected)
+{
+ if (value != expected
+ || memcmp ((void *)&value, (void *) &expected, sizeof (double)) != 0)
+ abort ();
+}
+
+void
+expectf (float value, float expected)
+{
+ if (value != expected
+ || memcmp ((void *)&value, (void *) &expected, sizeof (float)) != 0)
+ abort ();
+}
+
+double
+negd (double v)
+{
+ return -v;
+}
+
+float
+negf (float v)
+{
+ return -v;
+}