[3.13] gh-125451: Fix deadlock in ProcessPoolExecutor shutdown (GH-125492) (GH-125598)
There was a deadlock when `ProcessPoolExecutor` shuts down at the same time that a queueing thread handles an error processing a task. Don't use `_shutdown_lock` to protect the `_ThreadWakeup` pipes -- use an internal lock instead. This fixes the ordering deadlock where the `ExecutorManagerThread` holds the `_shutdown_lock` and joins the queueing thread, while the queueing thread is attempting to acquire the `_shutdown_lock` while closing the `_ThreadWakeup`. (cherry picked from commit 760872efecb95017db8e38a8eda614bf23d2a22c) Co-authored-by: Sam Gross <colesbury@gmail.com>
M
Miss Islington (bot) committed
4fc4067796d223ed63240a2db425855ddbc3dd24
Parent: 3fda8a8
Committed by GitHub <noreply@github.com>
on 10/16/2024, 6:03:17 PM