aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoseph Myers <joseph@codesourcery.com>2014-03-04 14:16:25 +0000
committerJoseph Myers <joseph@codesourcery.com>2014-03-04 14:16:25 +0000
commit45adef3cf2057aa1f7e2b7479e5f1bcb7506140c (patch)
treef66231bbd415777b1b5de7a3f2181d332d0076d4
parentd4b17258bba38f206079fbae1e7255779db1b74c (diff)
downloadglibc-45adef3cf2057aa1f7e2b7479e5f1bcb7506140c.tar
glibc-45adef3cf2057aa1f7e2b7479e5f1bcb7506140c.tar.gz
glibc-45adef3cf2057aa1f7e2b7479e5f1bcb7506140c.tar.bz2
glibc-45adef3cf2057aa1f7e2b7479e5f1bcb7506140c.zip
Fix libm-test.inc:print_complex_max_error handling of some error cases.
When regenerating ulps incrementally with "make regen-ulps", the resulting diffs should only increase existing ulps, never decrease them. This allows successive uses of "make regen-ulps" on different hardware or with different compiler configurations to accumulate ulps that are sufficient for tests to pass in a variety of configurations. However, sometimes changes that decrease ulps are wrongly generated; thus, when applying <https://sourceware.org/ml/libc-alpha/2014-02/msg00605.html> I had to remove such changes manually. The problem is print_complex_max_error. If the ulps for either the real or the imaginary part of a function are out of range, this function prints the maximum ulps seen for both parts, which then replace those previously in libm-test-ulps. So if the ulps for one part are bigger than recorded before, but those for the other part are smaller, the diffs reduce existing ulps. This patch fixes the logic so that only increased ulps get printed. Tested x86_64 ("make math/tests", and "make regen-ulps" in a situation with ulps manually modified so one part would go up and the other down, to confirm the changes have the intended effect then). * math/libm-test.inc (print_complex_max_error): Check separately whether real and imaginary errors are within allowed range and pass 0 to print_complex_function_ulps instead of value within allowed range.
-rw-r--r--ChangeLog7
-rw-r--r--math/libm-test.inc23
2 files changed, 22 insertions, 8 deletions
diff --git a/ChangeLog b/ChangeLog
index cdb5b85830..a808e73b15 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+2014-03-04 Joseph Myers <joseph@codesourcery.com>
+
+ * math/libm-test.inc (print_complex_max_error): Check separately
+ whether real and imaginary errors are within allowed range and
+ pass 0 to print_complex_function_ulps instead of value within
+ allowed range.
+
2014-03-04 Siddhesh Poyarekar <siddhesh@redhat.com>
* libio/tst-ftell-active-handler.c (get_handles_fdopen): Fix
diff --git a/math/libm-test.inc b/math/libm-test.inc
index 371229238d..4cb239f12a 100644
--- a/math/libm-test.inc
+++ b/math/libm-test.inc
@@ -568,19 +568,26 @@ static void
print_complex_max_error (const char *func_name)
{
__complex__ FLOAT allowed = find_complex_function_ulps (func_name);
- int ok = 0;
+ int real_ok = 0, imag_ok = 0, ok;
- if ((real_max_error == 0 && imag_max_error == 0)
- || (real_max_error <= __real__ allowed
- && imag_max_error <= __imag__ allowed
- && !ignore_max_ulp))
+ if (real_max_error == 0
+ || (real_max_error <= __real__ allowed && !ignore_max_ulp))
{
- ok = 1;
+ real_ok = 1;
}
- if (!ok)
- print_complex_function_ulps (func_name, real_max_error, imag_max_error);
+ if (imag_max_error == 0
+ || (imag_max_error <= __imag__ allowed && !ignore_max_ulp))
+ {
+ imag_ok = 1;
+ }
+
+ ok = real_ok && imag_ok;
+ if (!ok)
+ print_complex_function_ulps (func_name,
+ real_ok ? 0 : real_max_error,
+ imag_ok ? 0 : imag_max_error);
if (print_screen_max_error (ok))
{