[Python-checkins] cpython: Issue #25604: Fix minor bug in integer true division, which could

mark.dickinson python-checkins at python.org
Sun Aug 21 05:23:41 EDT 2016


https://hg.python.org/cpython/rev/b9e12ca6fdb6
changeset:   102824:b9e12ca6fdb6
user:        Mark Dickinson <dickinsm at gmail.com>
date:        Sun Aug 21 10:23:23 2016 +0100
summary:
  Issue #25604: Fix minor bug in integer true division, which could
have caused off-by-one-ulp results on certain platforms.

files:
  Misc/NEWS            |  4 ++++
  Objects/longobject.c |  4 ++--
  2 files changed, 6 insertions(+), 2 deletions(-)


diff --git a/Misc/NEWS b/Misc/NEWS
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -10,6 +10,10 @@
 Core and Builtins
 -----------------
 
+- Issue #25604: Fix a minor bug in integer true division; this bug could
+  potentially have caused off-by-one-ulp results on platforms with
+  unreliable ldexp implementations.
+
 - Issue #27662: Fix an overflow check in ``List_New``: the original code was
   checking against ``Py_SIZE_MAX`` instead of the correct upper bound of
   ``Py_SSIZE_T_MAX``. Patch by Xiang Zhang.
diff --git a/Objects/longobject.c b/Objects/longobject.c
--- a/Objects/longobject.c
+++ b/Objects/longobject.c
@@ -3893,9 +3893,9 @@
     /* Round by directly modifying the low digit of x. */
     mask = (digit)1 << (extra_bits - 1);
     low = x->ob_digit[0] | inexact;
-    if (low & mask && low & (3*mask-1))
+    if ((low & mask) && (low & (3U*mask-1U)))
         low += mask;
-    x->ob_digit[0] = low & ~(mask-1U);
+    x->ob_digit[0] = low & ~(2U*mask-1U);
 
     /* Convert x to a double dx; the conversion is exact. */
     dx = x->ob_digit[--x_size];

-- 
Repository URL: https://hg.python.org/cpython


More information about the Python-checkins mailing list