summaryrefslogtreecommitdiffstats
path: root/Modules
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2011-02-21 18:09:00 (GMT)
committerAntoine Pitrou <solipsis@pitrou.net>2011-02-21 18:09:00 (GMT)
commitf3d22755f929a27df310a3abe939d230cd1ce494 (patch)
treef990ba05c24b31981cbe20b054baf4db81c0abb9 /Modules
parentf5692b0476d0c09fc612046d7baca0331491d1d3 (diff)
downloadcpython-f3d22755f929a27df310a3abe939d230cd1ce494.zip
cpython-f3d22755f929a27df310a3abe939d230cd1ce494.tar.gz
cpython-f3d22755f929a27df310a3abe939d230cd1ce494.tar.bz2
Merged revisions 88460 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ........ r88460 | antoine.pitrou | 2011-02-21 19:03:13 +0100 (lun., 21 févr. 2011) | 4 lines Issue #10276: Fix the results of zlib.crc32() and zlib.adler32() on buffers larger than 4GB. Patch by Nadeem Vawda. ........
Diffstat (limited to 'Modules')
-rw-r--r--Modules/zlibmodule.c24
1 files changed, 22 insertions, 2 deletions
diff --git a/Modules/zlibmodule.c b/Modules/zlibmodule.c
index a03045e..e439c5b 100644
--- a/Modules/zlibmodule.c
+++ b/Modules/zlibmodule.c
@@ -945,8 +945,18 @@ PyZlib_adler32(PyObject *self, PyObject *args)
/* Releasing the GIL for very small buffers is inefficient
and may lower performance */
if (pbuf.len > 1024*5) {
+ void *buf = pbuf.buf;
+ Py_ssize_t len = pbuf.len;
+
Py_BEGIN_ALLOW_THREADS
- adler32val = adler32(adler32val, pbuf.buf, pbuf.len);
+ /* Avoid truncation of length for very large buffers. adler32() takes
+ length as an unsigned int, which may be narrower than Py_ssize_t. */
+ while (len > (Py_ssize_t)UINT_MAX) {
+ adler32val = adler32(adler32val, buf, UINT_MAX);
+ buf += UINT_MAX;
+ len -= UINT_MAX;
+ }
+ adler32val = adler32(adler32val, buf, len);
Py_END_ALLOW_THREADS
} else {
adler32val = adler32(adler32val, pbuf.buf, pbuf.len);
@@ -973,8 +983,18 @@ PyZlib_crc32(PyObject *self, PyObject *args)
/* Releasing the GIL for very small buffers is inefficient
and may lower performance */
if (pbuf.len > 1024*5) {
+ void *buf = pbuf.buf;
+ Py_ssize_t len = pbuf.len;
+
Py_BEGIN_ALLOW_THREADS
- signed_val = crc32(crc32val, pbuf.buf, pbuf.len);
+ /* Avoid truncation of length for very large buffers. crc32() takes
+ length as an unsigned int, which may be narrower than Py_ssize_t. */
+ while (len > (Py_ssize_t)UINT_MAX) {
+ crc32val = crc32(crc32val, buf, UINT_MAX);
+ buf += UINT_MAX;
+ len -= UINT_MAX;
+ }
+ signed_val = crc32(crc32val, buf, len);
Py_END_ALLOW_THREADS
} else {
signed_val = crc32(crc32val, pbuf.buf, pbuf.len);