aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2000-12-04 01:20:04 +0000
committerUlrich Drepper <drepper@redhat.com>2000-12-04 01:20:04 +0000
commit8cd806cfc8f8fe7b70cc30eb30579f5ee9503eab (patch)
tree2a9a44b768f7ad1bc38d938171f116c4fe5e26f0
parent76aecea11dc291f54b288480a5e9543eab02aae8 (diff)
downloadglibc-8cd806cfc8f8fe7b70cc30eb30579f5ee9503eab.tar
glibc-8cd806cfc8f8fe7b70cc30eb30579f5ee9503eab.tar.gz
glibc-8cd806cfc8f8fe7b70cc30eb30579f5ee9503eab.tar.bz2
glibc-8cd806cfc8f8fe7b70cc30eb30579f5ee9503eab.zip
Update.
* sysdeps/i386/ldbl2mpn.c (__mpn_extract_long_double): Handle the pseudo denormal representation of LDBL_MIN. * configure.in: Correct test for pserver CVS access.
-rw-r--r--ChangeLog5
-rw-r--r--sysdeps/i386/ldbl2mpn.c17
2 files changed, 19 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index a7f4ba4edd..92809c5cc5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
2000-12-03 Ulrich Drepper <drepper@redhat.com>
+ * sysdeps/i386/ldbl2mpn.c (__mpn_extract_long_double): Handle the
+ pseudo denormal representation of LDBL_MIN.
+
* iconvdata/SJIS.irreversible: Remove unnecessary entries.
* iconvdata/EUC-JP.irreversible: Remove unnecessary entries.
@@ -45,7 +48,7 @@
2000-12-01 Ulrich Drepper <drepper@redhat.com>
- * configure.in: Correct test for pserver CVS access.cc
+ * configure.in: Correct test for pserver CVS access.
2000-11-28 H.J. Lu <hjl@gnu.org>
diff --git a/sysdeps/i386/ldbl2mpn.c b/sysdeps/i386/ldbl2mpn.c
index 631fe2eab4..386cf198e2 100644
--- a/sysdeps/i386/ldbl2mpn.c
+++ b/sysdeps/i386/ldbl2mpn.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
+/* Copyright (C) 1995, 1996, 1997, 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
@@ -87,13 +87,26 @@ __mpn_extract_long_double (mp_ptr res_ptr, mp_size_t size,
}
*expt = LDBL_MIN_EXP - 1 - cnt;
}
- else
+ else if (res_ptr[0] != 0)
{
count_leading_zeros (cnt, res_ptr[0]);
res_ptr[N - 1] = res_ptr[0] << cnt;
res_ptr[0] = 0;
*expt = LDBL_MIN_EXP - 1 - BITS_PER_MP_LIMB - cnt;
}
+ else
+ {
+ /* This is the special case of the pseudo denormal number
+ with only the implicit leading bit set. The value is
+ in fact a normal number and so we have to treat this
+ case differently. */
+#if N == 2
+ res_ptr[N - 1] = 0x80000000ul;
+#else
+ res_ptr[0] = 0x8000000000000000ul;
+#endif
+ *expt = LDBL_MIN_EXP - 1;
+ }
}
}