mirror of
https://github.com/python/cpython.git
synced 2026-01-26 21:03:34 +00:00
[3.14] gh-140257: fix data race on eval_breaker during finalization (GH-140265) (#140294)
gh-140257: fix data race on eval_breaker during finalization (GH-140265) (cherry picked from commit c8729c9909e150989050ce2a435d018955bea41d) Co-authored-by: Shamil <ashm.tech@proton.me>
This commit is contained in:
parent
c70f409da0
commit
3ca7ea1f8f
@ -0,0 +1,2 @@
|
||||
Fix data race between interpreter_clear() and take_gil() on eval_breaker
|
||||
during finalization with daemon threads.
|
||||
@ -860,10 +860,11 @@ interpreter_clear(PyInterpreterState *interp, PyThreadState *tstate)
|
||||
|
||||
Py_CLEAR(interp->audit_hooks);
|
||||
|
||||
// At this time, all the threads should be cleared so we don't need atomic
|
||||
// operations for instrumentation_version or eval_breaker.
|
||||
// gh-140257: Threads have already been cleared, but daemon threads may
|
||||
// still access eval_breaker atomically via take_gil() right before they
|
||||
// hang. Use an atomic store to prevent data races during finalization.
|
||||
interp->ceval.instrumentation_version = 0;
|
||||
tstate->eval_breaker = 0;
|
||||
_Py_atomic_store_uintptr(&tstate->eval_breaker, 0);
|
||||
|
||||
for (int i = 0; i < _PY_MONITORING_UNGROUPED_EVENTS; i++) {
|
||||
interp->monitors.tools[i] = 0;
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user