summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrett Cannon <brett@python.org>2012-11-16 02:39:36 (GMT)
committerBrett Cannon <brett@python.org>2012-11-16 02:39:36 (GMT)
commite4710cfcedbecbd3bfa154c2586415ab5b6e28bc (patch)
tree0e8da2fa36596ed887e78771d765ddedc615b1ea
parent1e1e8aa5074ae43c757764f3ba3bce1efc765346 (diff)
downloadcpython-e4710cfcedbecbd3bfa154c2586415ab5b6e28bc.zip
cpython-e4710cfcedbecbd3bfa154c2586415ab5b6e28bc.tar.gz
cpython-e4710cfcedbecbd3bfa154c2586415ab5b6e28bc.tar.bz2
Issue #15894: Document why we don't worry about re-acquiring the
global import lock after forking.
-rw-r--r--Python/import.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/Python/import.c b/Python/import.c
index 2f71b97..6882b57 100644
--- a/Python/import.c
+++ b/Python/import.c
@@ -202,8 +202,11 @@ _PyImport_ReInitLock(void)
if (import_lock_level > 1) {
/* Forked as a side effect of import */
long me = PyThread_get_thread_ident();
- PyThread_acquire_lock(import_lock, 0);
- /* XXX: can the previous line fail? */
+ /* The following could fail if the lock is already held, but forking as
+ a side-effect of an import is a) rare, b) nuts, and c) difficult to
+ do thanks to the lock only being held when doing individual module
+ locks per import. */
+ PyThread_acquire_lock(import_lock, NOWAIT_LOCK);
import_lock_thread = me;
import_lock_level--;
} else {