mirror of
https://github.com/python/cpython.git
synced 2025-09-26 10:19:53 +00:00
[3.12] gh-105967: Work around a macOS bug, limit zlib C library crc32 API calls to 1gig (GH-112615) (#112724)
gh-105967: Work around a macOS bug, limit zlib C library crc32 API calls to 1gig (GH-112615)
Work around a macOS bug, limit zlib crc32 calls to 1GiB.
Without this, `zlib.crc32` and `binascii.crc32` could produce incorrect
results on multi-gigabyte inputs depending on the macOS version's Apple
supplied zlib implementation.
(cherry picked from commit 4eddb4c9d9
)
Co-authored-by: Gregory P. Smith <greg@krypto.org>
This commit is contained in:
parent
8d21242bd1
commit
88ec2a4fef
3 changed files with 30 additions and 10 deletions
|
@ -780,12 +780,20 @@ binascii_crc32_impl(PyObject *module, Py_buffer *data, unsigned int crc)
|
|||
|
||||
Py_BEGIN_ALLOW_THREADS
|
||||
/* Avoid truncation of length for very large buffers. crc32() takes
|
||||
length as an unsigned int, which may be narrower than Py_ssize_t. */
|
||||
while ((size_t)len > UINT_MAX) {
|
||||
crc = crc32(crc, buf, UINT_MAX);
|
||||
buf += (size_t) UINT_MAX;
|
||||
len -= (size_t) UINT_MAX;
|
||||
length as an unsigned int, which may be narrower than Py_ssize_t.
|
||||
We further limit size due to bugs in Apple's macOS zlib.
|
||||
See https://github.com/python/cpython/issues/105967
|
||||
*/
|
||||
#define ZLIB_CRC_CHUNK_SIZE 0x40000000
|
||||
#if ZLIB_CRC_CHUNK_SIZE > INT_MAX
|
||||
# error "unsupported less than 32-bit platform?"
|
||||
#endif
|
||||
while ((size_t)len > ZLIB_CRC_CHUNK_SIZE) {
|
||||
crc = crc32(crc, buf, ZLIB_CRC_CHUNK_SIZE);
|
||||
buf += (size_t) ZLIB_CRC_CHUNK_SIZE;
|
||||
len -= (size_t) ZLIB_CRC_CHUNK_SIZE;
|
||||
}
|
||||
#undef ZLIB_CRC_CHUNK_SIZE
|
||||
crc = crc32(crc, buf, (unsigned int)len);
|
||||
Py_END_ALLOW_THREADS
|
||||
} else {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue