changeset: 73695:aa6ce09d2350 parent: 73693:439ac346b20b parent: 73694:ba90839c4993 user: Charles-François Natali date: Tue Nov 22 19:51:14 2011 +0100 files: Python/pystate.c description: Issue #13156: _PyGILState_Reinit(): Re-associate the auto thread state with the TLS key only if the thread that called fork() had an associated auto thread state (this might not be the case for example for a thread created outside of Python calling into a subinterpreter). diff -r 439ac346b20b -r aa6ce09d2350 Python/pystate.c --- a/Python/pystate.c Tue Nov 22 18:55:22 2011 +0100 +++ b/Python/pystate.c Tue Nov 22 19:51:14 2011 +0100 @@ -592,9 +592,9 @@ autoInterpreterState = NULL; } -/* Reset the TLS key - called by PyOS_AfterFork. +/* Reset the TLS key - called by PyOS_AfterFork(). * This should not be necessary, but some - buggy - pthread implementations - * don't flush TLS on fork, see issue #10517. + * don't reset TLS upon fork(), see issue #10517. */ void _PyGILState_Reinit(void) @@ -604,8 +604,9 @@ if ((autoTLSkey = PyThread_create_key()) == -1) Py_FatalError("Could not allocate TLS entry"); - /* re-associate the current thread state with the new key */ - if (PyThread_set_key_value(autoTLSkey, (void *)tstate) < 0) + /* If the thread had an associated auto thread state, reassociate it with + * the new key. */ + if (tstate && PyThread_set_key_value(autoTLSkey, (void *)tstate) < 0) Py_FatalError("Couldn't create autoTLSkey mapping"); }