Commit 35230d08 authored by Yury Selivanov's avatar Yury Selivanov Committed by GitHub

bpo-33623: Fix possible SIGSGV when asyncio.Future is created in __del__ (#7080)

parent 08c5aca9
Fix possible SIGSGV when asyncio.Future is created in __del__
...@@ -501,7 +501,13 @@ future_init(FutureObj *fut, PyObject *loop) ...@@ -501,7 +501,13 @@ future_init(FutureObj *fut, PyObject *loop)
if (is_true < 0) { if (is_true < 0) {
return -1; return -1;
} }
if (is_true) { if (is_true && !_Py_IsFinalizing()) {
/* Only try to capture the traceback if the interpreter is not being
finalized. The original motivation to add a `_Py_IsFinalizing()`
call was to prevent SIGSEGV when a Future is created in a __del__
method, which is called during the interpreter shutdown and the
traceback module is already unloaded.
*/
fut->fut_source_tb = _PyObject_CallNoArg(traceback_extract_stack); fut->fut_source_tb = _PyObject_CallNoArg(traceback_extract_stack);
if (fut->fut_source_tb == NULL) { if (fut->fut_source_tb == NULL) {
return -1; return -1;
......
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