summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <vstinner@python.org>2020-03-18 02:04:33 (GMT)
committerGitHub <noreply@github.com>2020-03-18 02:04:33 (GMT)
commit29356e03d4f8800b04f799efe7a10e3ce8b16f61 (patch)
treeaab7efc54ee7ee204ca32aa73ec9c2134c0a41f3
parent23ef89db7ae46d160650263cc80479c2ed6693fb (diff)
downloadcpython-29356e03d4f8800b04f799efe7a10e3ce8b16f61.zip
cpython-29356e03d4f8800b04f799efe7a10e3ce8b16f61.tar.gz
cpython-29356e03d4f8800b04f799efe7a10e3ce8b16f61.tar.bz2
bpo-39877: Fix take_gil() for daemon threads (GH-19054)
bpo-39877, bpo-39984: If the thread must exit, don't access tstate to prevent a potential crash: tstate memory has been freed.
-rw-r--r--Python/ceval_gil.h8
1 files changed, 6 insertions, 2 deletions
diff --git a/Python/ceval_gil.h b/Python/ceval_gil.h
index 9c051ae..f8b06ac 100644
--- a/Python/ceval_gil.h
+++ b/Python/ceval_gil.h
@@ -281,13 +281,17 @@ _ready:
if (_Py_atomic_load_relaxed(&ceval->gil_drop_request)) {
RESET_GIL_DROP_REQUEST(ceval);
}
- if (tstate->async_exc != NULL) {
+
+ int must_exit = tstate_must_exit(tstate);
+
+ /* Don't access tstate if the thread must exit */
+ if (!must_exit && tstate->async_exc != NULL) {
_PyEval_SignalAsyncExc(ceval);
}
MUTEX_UNLOCK(gil->mutex);
- if (tstate_must_exit(tstate)) {
+ if (must_exit) {
/* bpo-36475: If Py_Finalize() has been called and tstate is not
the thread which called Py_Finalize(), exit immediately the
thread.