summaryrefslogtreecommitdiffstats
path: root/libexec
diff options
context:
space:
mode:
authordavidxu <davidxu@FreeBSD.org>2008-09-16 01:46:11 +0000
committerdavidxu <davidxu@FreeBSD.org>2008-09-16 01:46:11 +0000
commit612ed6bb13e3eba8b695dd42d0ece8ca60233703 (patch)
tree5ab66ac98cafb8b41c940604c8e79e1bd9507c84 /libexec
parent1e7ba9e4d7553e0894301015363d335775a7a65b (diff)
downloadFreeBSD-src-612ed6bb13e3eba8b695dd42d0ece8ca60233703.zip
FreeBSD-src-612ed6bb13e3eba8b695dd42d0ece8ca60233703.tar.gz
Allow multiple locks to be acquired by detecting corresponding
bit flag, otherwise if a thread acquired a lock, another thread or the current thread itself can no longer acquire another lock because thread_mask_set() return whole flag word, this results bit leaking in the word and misbehavior in later locking and unlocking.
Diffstat (limited to 'libexec')
-rw-r--r--libexec/rtld-elf/rtld_lock.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/libexec/rtld-elf/rtld_lock.c b/libexec/rtld-elf/rtld_lock.c
index c67f5fb..5bb891a 100644
--- a/libexec/rtld-elf/rtld_lock.c
+++ b/libexec/rtld-elf/rtld_lock.c
@@ -184,7 +184,7 @@ rtld_lock_t rtld_phdr_lock = &rtld_locks[2];
int
rlock_acquire(rtld_lock_t lock)
{
- if (thread_mask_set(lock->mask)) {
+ if (thread_mask_set(lock->mask) & lock->mask) {
dbg("rlock_acquire: recursed");
return (0);
}
@@ -195,7 +195,7 @@ rlock_acquire(rtld_lock_t lock)
int
wlock_acquire(rtld_lock_t lock)
{
- if (thread_mask_set(lock->mask)) {
+ if (thread_mask_set(lock->mask) & lock->mask) {
dbg("wlock_acquire: recursed");
return (0);
}
OpenPOWER on IntegriCloud