summaryrefslogtreecommitdiff
path: root/Modules/binascii.c
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2015-04-20 09:31:51 +0300
committerSerhiy Storchaka <storchaka@gmail.com>2015-04-20 09:31:51 +0300
commite3037e114509913874a28746f5e05780919e909a (patch)
treedead0e6507d6c83d63d90750380b17c7fb566f5d /Modules/binascii.c
parentc74bb9d35060717eb8b658b89500ee18855c1080 (diff)
parent2ef7c478444f453a04ae63ecc3d3de07915ad2b0 (diff)
downloadcpython-git-e3037e114509913874a28746f5e05780919e909a.tar.gz
Issue #23728: binascii.crc_hqx() could return an integer outside of the range
0-0xffff for empty data.
Diffstat (limited to 'Modules/binascii.c')
-rw-r--r--Modules/binascii.c16
1 files changed, 8 insertions, 8 deletions
diff --git a/Modules/binascii.c b/Modules/binascii.c
index 4e4faa9546..ceee4f1bf5 100644
--- a/Modules/binascii.c
+++ b/Modules/binascii.c
@@ -908,31 +908,31 @@ binascii_rledecode_hqx_impl(PyModuleDef *module, Py_buffer *data)
/*[clinic input]
-binascii.crc_hqx -> int
+binascii.crc_hqx -> unsigned_int
data: Py_buffer
- crc: int
+ crc: unsigned_int(bitwise=True)
/
Compute hqx CRC incrementally.
[clinic start generated code]*/
-static int
-binascii_crc_hqx_impl(PyModuleDef *module, Py_buffer *data, int crc)
-/*[clinic end generated code: output=634dac18dfa863d7 input=68060931b2f51c8a]*/
+static unsigned int
+binascii_crc_hqx_impl(PyModuleDef *module, Py_buffer *data, unsigned int crc)
+/*[clinic end generated code: output=167c2dac62625717 input=add8c53712ccceda]*/
{
unsigned char *bin_data;
- unsigned int ucrc = (unsigned int)crc;
Py_ssize_t len;
+ crc &= 0xffff;
bin_data = data->buf;
len = data->len;
while(len-- > 0) {
- ucrc=((ucrc<<8)&0xff00)^crctab_hqx[((ucrc>>8)&0xff)^*bin_data++];
+ crc = ((crc<<8)&0xff00) ^ crctab_hqx[(crc>>8)^*bin_data++];
}
- return (int)ucrc;
+ return crc;
}
#ifndef USE_ZLIB_CRC32