summaryrefslogtreecommitdiff
path: root/Python/ceval.c
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2020-03-15 14:26:43 -0700
committerGitHub <noreply@github.com>2020-03-15 14:26:43 -0700
commit7f5302fed4ff0cc8042e639b29a0664a16bc2702 (patch)
tree8826b850ac54fbd81eb10c6b2b049daab8442bc6 /Python/ceval.c
parent890dcfe4035888f70207eaac05662d6e29606214 (diff)
downloadcpython-git-7f5302fed4ff0cc8042e639b29a0664a16bc2702.tar.gz
bpo-39360: Ensure all workers exit when finalizing a multiprocessing Pool (GH-19009)
When the pull is not used via the context manager or terminate() is called, there is a system in multiprocessing.util that handles finalization of all pools via an atexit handler (the Finalize) class. This class registers the _terminate_pool handler in the registry of finalizers of the module, and that registry is called on interpreter exit via _exit_function. The problem is that the "happy" path with the context manager or manual call to finalize() does some extra steps that _terminate_pool does not. The step that is not executed when the atexit() handler calls _terminate_pool is pinging the _change_notifier queue to unblock the maintenance threads. This commit moves the notification to the _terminate_pool function so is called from both code paths. Co-authored-by: Pablo Galindo <Pablogsal@gmail.com> (cherry picked from commit ac10e0c93218627d1a639db0b7b41714c5f6a883) Co-authored-by: Batuhan Taşkaya <47358913+isidentical@users.noreply.github.com>
Diffstat (limited to 'Python/ceval.c')
0 files changed, 0 insertions, 0 deletions