diff options
author | Keith Owens <kaos@sgi.com> | 2005-12-10 04:24:28 +0100 |
---|---|---|
committer | Tony Luck <tony.luck@intel.com> | 2005-12-12 17:54:18 +0100 |
commit | bf7ececa9b68f4720f1ce344f442435660bcdae7 (patch) | |
tree | 7caff55f6ce8cfee2547ad0c93ad893c8f9583cb | |
parent | [IA64] Fix missing parameter for local_add/sub (diff) | |
download | linux-bf7ececa9b68f4720f1ce344f442435660bcdae7.tar.xz linux-bf7ececa9b68f4720f1ce344f442435660bcdae7.zip |
[IA64] Define an ia64 version of __raw_read_trylock
IA64 is using the generic version of __raw_read_trylock, which always
waits for the lock to be free instead of returning when the lock is in
use. Define an ia64 version of __raw_read_trylock which behaves
correctly, and drop the generic one.
Signed-off-by: Keith Owens <kaos@sgi.com>
Signed-off-by: Tony Luck <tony.luck@intel.com>
-rw-r--r-- | include/asm-ia64/spinlock.h | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/include/asm-ia64/spinlock.h b/include/asm-ia64/spinlock.h index 5b78611411c3..0c91a76c5ea3 100644 --- a/include/asm-ia64/spinlock.h +++ b/include/asm-ia64/spinlock.h @@ -201,6 +201,16 @@ static inline void __raw_write_unlock(raw_rwlock_t *x) #endif /* !ASM_SUPPORTED */ -#define __raw_read_trylock(lock) generic__raw_read_trylock(lock) +static inline int __raw_read_trylock(raw_rwlock_t *x) +{ + union { + raw_rwlock_t lock; + __u32 word; + } old, new; + old.lock = new.lock = *x; + old.lock.write_lock = new.lock.write_lock = 0; + ++new.lock.read_counter; + return (u32)ia64_cmpxchg4_acq((__u32 *)(x), new.word, old.word) == old.word; +} #endif /* _ASM_IA64_SPINLOCK_H */ |