summaryrefslogtreecommitdiffstats
path: root/Objects
diff options
context:
space:
mode:
authorAmmar Askar <ammar@ammaraskar.com>2020-06-10 23:31:22 (GMT)
committerGitHub <noreply@github.com>2020-06-10 23:31:22 (GMT)
commit3b3b83c965447a8329b34cb4befe6e9908880ee5 (patch)
tree612bf0d51451cc7fefd97c5a45549641e93a86ea /Objects
parent1642c0ef750f96664a98cadb09301d492098d2fb (diff)
downloadcpython-3b3b83c965447a8329b34cb4befe6e9908880ee5.zip
cpython-3b3b83c965447a8329b34cb4befe6e9908880ee5.tar.gz
cpython-3b3b83c965447a8329b34cb4befe6e9908880ee5.tar.bz2
Restrict co_code to be under INT_MAX in codeobject (GH-20628)
Diffstat (limited to 'Objects')
-rw-r--r--Objects/codeobject.c8
-rw-r--r--Objects/frameobject.c6
2 files changed, 11 insertions, 3 deletions
diff --git a/Objects/codeobject.c b/Objects/codeobject.c
index 7376359..cb4fb68 100644
--- a/Objects/codeobject.c
+++ b/Objects/codeobject.c
@@ -166,6 +166,14 @@ PyCode_NewWithPosOnlyArgs(int argcount, int posonlyargcount, int kwonlyargcount,
return NULL;
}
+ /* Make sure that code is indexable with an int, this is
+ a long running assumption in ceval.c and many parts of
+ the interpreter. */
+ if (PyBytes_GET_SIZE(code) > INT_MAX) {
+ PyErr_SetString(PyExc_OverflowError, "co_code larger than INT_MAX");
+ return NULL;
+ }
+
/* Check for any inner or outer closure references */
n_cellvars = PyTuple_GET_SIZE(cellvars);
if (!n_cellvars && !PyTuple_GET_SIZE(freevars)) {
diff --git a/Objects/frameobject.c b/Objects/frameobject.c
index 0dad42e..6e1cbcf 100644
--- a/Objects/frameobject.c
+++ b/Objects/frameobject.c
@@ -397,9 +397,9 @@ frame_setlineno(PyFrameObject *f, PyObject* p_new_lineno, void *Py_UNUSED(ignore
return -1;
}
- int len = Py_SAFE_DOWNCAST(
- PyBytes_GET_SIZE(f->f_code->co_code)/sizeof(_Py_CODEUNIT),
- Py_ssize_t, int);
+ /* PyCode_NewWithPosOnlyArgs limits co_code to be under INT_MAX so this
+ * should never overflow. */
+ int len = (int)(PyBytes_GET_SIZE(f->f_code->co_code) / sizeof(_Py_CODEUNIT));
int *lines = marklines(f->f_code, len);
if (lines == NULL) {
return -1;