bpo-35269: Fix a possible segfault involving a newly-created coroutine (GH-10585)
coro->cr_origin wasn't initialized if compute_cr_origin() failed in
PyCoro_New(), which would cause a crash during the coroutine's
deallocation.
https://bugs.python.org/issue35269
(cherry picked from commit 062a57bf4b
)
Co-authored-by: Zackery Spytz <zspytz@gmail.com>
This commit is contained in:
parent
e851049e0e
commit
ae02a929dd
|
@ -0,0 +1,2 @@
|
|||
Fix a possible segfault involving a newly-created coroutine. Patch by
|
||||
Zackery Spytz.
|
|
@ -1166,11 +1166,11 @@ PyCoro_New(PyFrameObject *f, PyObject *name, PyObject *qualname)
|
|||
((PyCoroObject *)coro)->cr_origin = NULL;
|
||||
} else {
|
||||
PyObject *cr_origin = compute_cr_origin(origin_depth);
|
||||
((PyCoroObject *)coro)->cr_origin = cr_origin;
|
||||
if (!cr_origin) {
|
||||
Py_DECREF(coro);
|
||||
return NULL;
|
||||
}
|
||||
((PyCoroObject *)coro)->cr_origin = cr_origin;
|
||||
}
|
||||
|
||||
return coro;
|
||||
|
|
Loading…
Reference in New Issue