summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2011-01-15 11:37:11 (GMT)
committerAntoine Pitrou <solipsis@pitrou.net>2011-01-15 11:37:11 (GMT)
commit6a002c02dad9e33847f6f123be499c998e40cccf (patch)
tree690e62ef6d46c1a25b8aafeb56761a31be0c5b78
parentad30c4206af997f8c94c4e62a3e66abfa633442b (diff)
downloadcpython-6a002c02dad9e33847f6f123be499c998e40cccf.zip
cpython-6a002c02dad9e33847f6f123be499c998e40cccf.tar.gz
cpython-6a002c02dad9e33847f6f123be499c998e40cccf.tar.bz2
Fix the GIL with subinterpreters. Hopefully this will allow mod_wsgi to work with 3.2.
(we need some tests for this)
-rw-r--r--Python/ceval_gil.h11
1 files changed, 7 insertions, 4 deletions
diff --git a/Python/ceval_gil.h b/Python/ceval_gil.h
index 40e45f7..bf7a350 100644
--- a/Python/ceval_gil.h
+++ b/Python/ceval_gil.h
@@ -334,12 +334,15 @@ static void recreate_gil(void)
static void drop_gil(PyThreadState *tstate)
{
- /* NOTE: tstate is allowed to be NULL. */
if (!_Py_atomic_load_relaxed(&gil_locked))
Py_FatalError("drop_gil: GIL is not locked");
- if (tstate != NULL &&
- tstate != _Py_atomic_load_relaxed(&gil_last_holder))
- Py_FatalError("drop_gil: wrong thread state");
+ /* tstate is allowed to be NULL (early interpreter init) */
+ if (tstate != NULL) {
+ /* Sub-interpreter support: threads might have been switched
+ under our feet using PyThreadState_Swap(). Fix the GIL last
+ holder variable so that our heuristics work. */
+ _Py_atomic_store_relaxed(&gil_last_holder, tstate);
+ }
MUTEX_LOCK(gil_mutex);
_Py_ANNOTATE_RWLOCK_RELEASED(&gil_locked, /*is_write=*/1);