Description
Feature or enhancement
Proposal:
This issue is extracted from #125561.
When interpretation_clear is changed, the PyThreadState_Clear
function needs to be called when HEAD_LOCK
is not held, but in fact we cannot be sure, but it existed before the change. In fact, PR solves the competition, but does not eliminate the risk of deadlock, so I give the following solution.
For PyThreadState_Clear
, I want to add a HEAD_ISLOCKED
macro to wrap PyMutex_IsLocked
. This allows a check to be made when UNLOCK is called. Otherwise, if HEAD_LOCK is not called in the context, an is unlock error will occur when HEAD_UNLOCK is called. But in fact, we cannot be sure whether HEAD_LOCK is called in the context, and HEAD_IS_LOCK can be used to check it.
changed
diff --git a/Python/pystate.c b/Python/pystate.c
index 6b4e1d470f8..dc67e50bc27 100644
--- a/Python/pystate.c
+++ b/Python/pystate.c
@@ -796,6 +796,7 @@ interpreter_clear(PyInterpreterState *interp, PyThreadState *tstate)
// See https://github.com/python/cpython/issues/102126
// Must be called without HEAD_LOCK held as it can deadlock
// if any finalizer tries to acquire that lock.
+ HEAD_UNLOCK(&_PyRuntime);
PyThreadState_Clear(p);
p = p->next;
}
The above code will show no locked when the context does not hold HEAD_LOCK, but this is not certain. So I want to add an if statement in front to unlock it when holding HEAD_LOCK. Ensure that there is no deadlock when calling PyThreadState_Clear
.
if (HEAD_ISLOCKED(&_PyRuntime)) {
HEAD_UNLOCK(&_PyRuntime);
}
PyThreadState_Clear(p);
Has this already been discussed elsewhere?
No response given
Links to previous discussion of this feature:
No response
Metadata
Metadata
Assignees
Projects
Status