mirror of
https://github.com/python/cpython.git
synced 2025-12-23 09:19:18 +00:00
Merge
This commit is contained in:
commit
a74252633f
2 changed files with 7 additions and 7 deletions
|
|
@ -1068,21 +1068,18 @@ def _after_fork():
|
|||
current = current_thread()
|
||||
with _active_limbo_lock:
|
||||
for thread in _active.values():
|
||||
# Any lock/condition variable may be currently locked or in an
|
||||
# invalid state, so we reinitialize them.
|
||||
thread._reset_internal_locks()
|
||||
if thread is current:
|
||||
# There is only one active thread. We reset the ident to
|
||||
# its new value since it can have changed.
|
||||
ident = _get_ident()
|
||||
thread._ident = ident
|
||||
# Any condition variables hanging off of the active thread may
|
||||
# be in an invalid state, so we reinitialize them.
|
||||
thread._reset_internal_locks()
|
||||
new_active[ident] = thread
|
||||
else:
|
||||
# All the others are already stopped.
|
||||
# We don't call _Thread__stop() because it tries to acquire
|
||||
# thread._Thread__block which could also have been held while
|
||||
# we forked.
|
||||
thread._stopped = True
|
||||
thread._stop()
|
||||
|
||||
_limbo.clear()
|
||||
_active.clear()
|
||||
|
|
|
|||
|
|
@ -100,6 +100,9 @@ Library
|
|||
- Issue #7502: Fix equality comparison for DocTestCase instances. Patch by
|
||||
Cédric Krier.
|
||||
|
||||
- Issue #11870: threading: Properly reinitialize threads internal locks and
|
||||
condition variables to avoid deadlocks in child processes.
|
||||
|
||||
- Issue #8035: urllib: Fix a bug where the client could remain stuck after a
|
||||
redirection or an error.
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue