summaryrefslogtreecommitdiff
path: root/bitbake/lib/bb/utils.py
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2011-01-19 13:30:14 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2011-01-19 13:30:14 +0000
commitfd88588df029604689db9b0e30c55aad68392a5d (patch)
tree8a43cbb3835849397b35d295b5299142291ced6e /bitbake/lib/bb/utils.py
parent542cebbc3282a0b3acb68a5ef0d8c2a61b0ecc38 (diff)
downloadopenembedded-core-fd88588df029604689db9b0e30c55aad68392a5d.tar.gz
openembedded-core-fd88588df029604689db9b0e30c55aad68392a5d.tar.bz2
openembedded-core-fd88588df029604689db9b0e30c55aad68392a5d.zip
bitbake/utils.py: Teach unlockfile about shared mode lockfiles
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/lib/bb/utils.py')
-rw-r--r--bitbake/lib/bb/utils.py8
1 files changed, 7 insertions, 1 deletions
diff --git a/bitbake/lib/bb/utils.py b/bitbake/lib/bb/utils.py
index 5dc7e766f5..c6bbae87a4 100644
--- a/bitbake/lib/bb/utils.py
+++ b/bitbake/lib/bb/utils.py
@@ -445,7 +445,13 @@ def unlockfile(lf):
"""
Unlock a file locked using lockfile()
"""
- os.unlink(lf.name)
+ try:
+ # If we had a shared lock, we need to promote to exclusive before
+ # removing the lockfile. Attempt this, ignore failures.
+ fcntl.flock(lf.fileno(), fcntl.LOCK_EX|fcntl.LOCK_NB)
+ os.unlink(lf.name)
+ except IOError:
+ pass
fcntl.flock(lf.fileno(), fcntl.LOCK_UN)
lf.close()