Commit 6c7d67ce authored by Sergey Fedoseev's avatar Sergey Fedoseev Committed by Miss Islington (bot)

bpo-1621: Avoid signed integer overflow in set_table_resize(). (GH-9059)

Address a C undefined behavior signed integer overflow issue in set object table resizing.  Our -fwrapv compiler flag and practical reasons why sets are unlikely to get this large should mean this was never an issue but it was incorrect code that generates code analysis warnings.

<!-- issue-number: [bpo-1621](https://www.bugs.python.org/issue1621) -->
https://bugs.python.org/issue1621
<!-- /issue-number -->
parent 4859ba0d
Do not assume signed integer overflow behavior (C undefined behavior) when
performing set hash table resizing.
...@@ -302,7 +302,6 @@ actually be smaller than the old one. ...@@ -302,7 +302,6 @@ actually be smaller than the old one.
static int static int
set_table_resize(PySetObject *so, Py_ssize_t minused) set_table_resize(PySetObject *so, Py_ssize_t minused)
{ {
Py_ssize_t newsize;
setentry *oldtable, *newtable, *entry; setentry *oldtable, *newtable, *entry;
Py_ssize_t oldmask = so->mask; Py_ssize_t oldmask = so->mask;
size_t newmask; size_t newmask;
...@@ -313,13 +312,9 @@ set_table_resize(PySetObject *so, Py_ssize_t minused) ...@@ -313,13 +312,9 @@ set_table_resize(PySetObject *so, Py_ssize_t minused)
/* Find the smallest table size > minused. */ /* Find the smallest table size > minused. */
/* XXX speed-up with intrinsics */ /* XXX speed-up with intrinsics */
for (newsize = PySet_MINSIZE; size_t newsize = PySet_MINSIZE;
newsize <= minused && newsize > 0; while (newsize <= (size_t)minused) {
newsize <<= 1) newsize <<= 1; // The largest possible value is PY_SSIZE_T_MAX + 1.
;
if (newsize <= 0) {
PyErr_NoMemory();
return -1;
} }
/* Get space for a new table. */ /* Get space for a new table. */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment