diff options
author | Victor Stinner <vstinner@python.org> | 2020-03-19 16:40:12 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-03-19 16:40:12 (GMT) |
commit | 5a3a71dddbe80edc75a3a74ce3b7978cf8635901 (patch) | |
tree | 952adf6d4c06bc9d8af4fcca28a7e652050d25af /Python/ceval_gil.h | |
parent | 77248a28896d39cae0a7e084965b9ffc2624b7f4 (diff) | |
download | cpython-5a3a71dddbe80edc75a3a74ce3b7978cf8635901.zip cpython-5a3a71dddbe80edc75a3a74ce3b7978cf8635901.tar.gz cpython-5a3a71dddbe80edc75a3a74ce3b7978cf8635901.tar.bz2 |
bpo-40010: Optimize signal handling in multithreaded applications (GH-19067)
If a thread different than the main thread gets a signal, the
bytecode evaluation loop is no longer interrupted at each bytecode
instruction to check for pending signals which cannot be handled.
Only the main thread of the main interpreter can handle signals.
Previously, the bytecode evaluation loop was interrupted at each
instruction until the main thread handles signals.
Changes:
* COMPUTE_EVAL_BREAKER() and SIGNAL_PENDING_SIGNALS() no longer set
eval_breaker to 1 if the current thread cannot handle signals.
* take_gil() now always recomputes eval_breaker.
Diffstat (limited to 'Python/ceval_gil.h')
-rw-r--r-- | Python/ceval_gil.h | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/Python/ceval_gil.h b/Python/ceval_gil.h index b359e3c..da2a1d6 100644 --- a/Python/ceval_gil.h +++ b/Python/ceval_gil.h @@ -280,9 +280,18 @@ _ready: COND_SIGNAL(gil->switch_cond); MUTEX_UNLOCK(gil->switch_mutex); #endif + if (_Py_atomic_load_relaxed(&ceval->gil_drop_request)) { RESET_GIL_DROP_REQUEST(ceval, ceval2); } + else { + /* bpo-40010: eval_breaker should be recomputed to be set to 1 if there + a pending signal: signal received by another thread which cannot + handle signals. + + Note: RESET_GIL_DROP_REQUEST() calls COMPUTE_EVAL_BREAKER(). */ + COMPUTE_EVAL_BREAKER(ceval, ceval2); + } int must_exit = tstate_must_exit(tstate); |