summaryrefslogtreecommitdiffstats
path: root/Python
diff options
context:
space:
mode:
authorƁukasz Langa <lukasz@langa.pl>2017-05-23 05:23:05 (GMT)
committerGitHub <noreply@github.com>2017-05-23 05:23:05 (GMT)
commitd29feccec3ce3dcd9ab3100f8956171c70ec3027 (patch)
tree20d4b6ea09a7663a3bae3313f6ca96f109258d92 /Python
parent1398b1bc7d80df5bde17041e7ec0a3bdbf54b19e (diff)
downloadcpython-d29feccec3ce3dcd9ab3100f8956171c70ec3027.zip
cpython-d29feccec3ce3dcd9ab3100f8956171c70ec3027.tar.gz
cpython-d29feccec3ce3dcd9ab3100f8956171c70ec3027.tar.bz2
[3.6] bpo-30395 _PyGILState_Reinit deadlock fix (GH-1734) (#1740)
head_lock could be held by another thread when fork happened. We should reset it to avoid deadlock. (cherry picked from commit f82c951d1c5416f3550d544e50ff5662d3836e73)
Diffstat (limited to 'Python')
-rw-r--r--Python/pystate.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/Python/pystate.c b/Python/pystate.c
index 65c244e..ccb0092 100644
--- a/Python/pystate.c
+++ b/Python/pystate.c
@@ -743,6 +743,10 @@ _PyGILState_Fini(void)
void
_PyGILState_Reinit(void)
{
+#ifdef WITH_THREAD
+ head_mutex = NULL;
+ HEAD_INIT();
+#endif
PyThreadState *tstate = PyGILState_GetThisThreadState();
PyThread_delete_key(autoTLSkey);
if ((autoTLSkey = PyThread_create_key()) == -1)