summaryrefslogtreecommitdiff
path: root/Objects
diff options
context:
space:
mode:
authorMark Dickinson <dickinsm@gmail.com>2009-09-13 12:06:08 +0000
committerMark Dickinson <dickinsm@gmail.com>2009-09-13 12:06:08 +0000
commit659c7b1bedbd566de7a6e60de1a1e637ca52f0b0 (patch)
tree3546a0d9b8a557b506d2fa3e6d4f2e0566598684 /Objects
parentdc2b8ec3a0608c47d6906a316c33deb101fcc4e5 (diff)
downloadcpython-git-659c7b1bedbd566de7a6e60de1a1e637ca52f0b0.tar.gz
Merged revisions 74769 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r74769 | mark.dickinson | 2009-09-13 12:56:13 +0100 (Sun, 13 Sep 2009) | 3 lines Fix potential signed-overflow bug in _PyLong_Format; also fix a couple of whitespace issues. ........
Diffstat (limited to 'Objects')
-rw-r--r--Objects/longobject.c17
1 files changed, 10 insertions, 7 deletions
diff --git a/Objects/longobject.c b/Objects/longobject.c
index 34850f1b5c..f84b54e8d5 100644
--- a/Objects/longobject.c
+++ b/Objects/longobject.c
@@ -1659,7 +1659,7 @@ _PyLong_Format(PyObject *aa, int base)
{
register PyLongObject *a = (PyLongObject *)aa;
PyObject *str;
- Py_ssize_t i, j, sz;
+ Py_ssize_t i, sz;
Py_ssize_t size_a;
Py_UNICODE *p;
int bits;
@@ -1680,13 +1680,14 @@ _PyLong_Format(PyObject *aa, int base)
i >>= 1;
}
i = 5;
- j = size_a*PyLong_SHIFT + bits-1;
- sz = i + j / bits;
- if (j / PyLong_SHIFT < size_a || sz < i) {
+ /* ensure we don't get signed overflow in sz calculation */
+ if (size_a > (PY_SSIZE_T_MAX - i) / PyLong_SHIFT) {
PyErr_SetString(PyExc_OverflowError,
"int is too large to format");
return NULL;
}
+ sz = i + 1 + (size_a * PyLong_SHIFT - 1) / bits;
+ assert(sz >= 0);
str = PyUnicode_FromUnicode(NULL, sz);
if (str == NULL)
return NULL;
@@ -1719,7 +1720,7 @@ _PyLong_Format(PyObject *aa, int base)
accumbits -= basebits;
accum >>= basebits;
} while (i < size_a-1 ? accumbits >= basebits :
- accum > 0);
+ accum > 0);
}
}
else {
@@ -1734,7 +1735,8 @@ _PyLong_Format(PyObject *aa, int base)
int power = 1;
for (;;) {
twodigits newpow = powbase * (twodigits)base;
- if (newpow >> PyLong_SHIFT) /* doesn't fit in a digit */
+ if (newpow >> PyLong_SHIFT)
+ /* doesn't fit in a digit */
break;
powbase = (digit)newpow;
++power;
@@ -1805,7 +1807,8 @@ _PyLong_Format(PyObject *aa, int base)
do {
} while ((*q++ = *p++) != '\0');
q--;
- if (PyUnicode_Resize(&str, (Py_ssize_t) (q - PyUnicode_AS_UNICODE(str)))) {
+ if (PyUnicode_Resize(&str,(Py_ssize_t) (q -
+ PyUnicode_AS_UNICODE(str)))) {
Py_DECREF(str);
return NULL;
}