summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexey Izbyshev <izbyshev@ispras.ru>2019-02-12 19:06:43 +0300
committerEric Snow <ericsnowcurrently@gmail.com>2019-02-12 09:06:43 -0700
commit16f842da3c862d76a1177bd8ef9579703c24fa5a (patch)
tree476f517535ce737c62d0d4dcc19a404cc136839f
parentb01786c8812c4cc24dd561b5941025bdd6f444c0 (diff)
downloadcpython-git-16f842da3c862d76a1177bd8ef9579703c24fa5a.tar.gz
bpo-35972: _xxsubinterpreters: Fix potential integer truncation on 32-bit in channel_send() (gh-11822)
-rw-r--r--Lib/test/test__xxsubinterpreters.py14
-rw-r--r--Python/pystate.c8
2 files changed, 19 insertions, 3 deletions
diff --git a/Lib/test/test__xxsubinterpreters.py b/Lib/test/test__xxsubinterpreters.py
index 26032d6c85..1eece96592 100644
--- a/Lib/test/test__xxsubinterpreters.py
+++ b/Lib/test/test__xxsubinterpreters.py
@@ -393,7 +393,19 @@ class ShareableTypeTests(unittest.TestCase):
for i in range(-1, 258))
def test_int(self):
- self._assert_values(range(-1, 258))
+ self._assert_values(itertools.chain(range(-1, 258),
+ [sys.maxsize, -sys.maxsize - 1]))
+
+ def test_non_shareable_int(self):
+ ints = [
+ sys.maxsize + 1,
+ -sys.maxsize - 2,
+ 2**1000,
+ ]
+ for i in ints:
+ with self.subTest(i):
+ with self.assertRaises(OverflowError):
+ interpreters.channel_send(self.cid, i)
##################################
diff --git a/Python/pystate.c b/Python/pystate.c
index 4dc3b81e4c..f0b2a6729f 100644
--- a/Python/pystate.c
+++ b/Python/pystate.c
@@ -1467,13 +1467,17 @@ _str_shared(PyObject *obj, _PyCrossInterpreterData *data)
static PyObject *
_new_long_object(_PyCrossInterpreterData *data)
{
- return PyLong_FromLongLong((intptr_t)(data->data));
+ return PyLong_FromSsize_t((Py_ssize_t)(data->data));
}
static int
_long_shared(PyObject *obj, _PyCrossInterpreterData *data)
{
- int64_t value = PyLong_AsLongLong(obj);
+ /* Note that this means the size of shareable ints is bounded by
+ * sys.maxsize. Hence on 32-bit architectures that is half the
+ * size of maximum shareable ints on 64-bit.
+ */
+ Py_ssize_t value = PyLong_AsSsize_t(obj);
if (value == -1 && PyErr_Occurred()) {
if (PyErr_ExceptionMatches(PyExc_OverflowError)) {
PyErr_SetString(PyExc_OverflowError, "try sending as bytes");