diff options
| author | Josh Triplett <josht@us.ibm.com> | 2006-09-29 02:00:59 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-09-29 09:18:19 -0700 | 
| commit | 9f50b93f066f8dc339de9b0eb78a22a75e6c8f8f (patch) | |
| tree | 9977ea31409d3ac73b9b47b9d0c5d3f0c7cbea87 | |
| parent | 92e9a8507ba81ff9e25bd9c5030ff8586269eefb (diff) | |
| download | olio-linux-3.10-9f50b93f066f8dc339de9b0eb78a22a75e6c8f8f.tar.xz olio-linux-3.10-9f50b93f066f8dc339de9b0eb78a22a75e6c8f8f.zip  | |
[PATCH] Make spinlock/rwlock annotations more accurate by using parameters, not types
The lock annotations used on spinlocks and rwlocks currently use
__{acquires,releases}(spinlock_t) and __{acquires,releases}(rwlock_t),
respectively.  This loses the information of which lock actually got
acquired or released, and assumes a different type for the parameter of
__acquires and __releases than the rest of the kernel.  While the current
implementations of __acquires and __releases throw away their argument,
this will not always remain the case.  Change this to use the lock
parameter instead, to preserve this information and increase consistency in
usage of __acquires and __releases.
Signed-off-by: Josh Triplett <josh@freedesktop.org>
Cc: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
| -rw-r--r-- | include/linux/spinlock_api_smp.h | 50 | 
1 files changed, 25 insertions, 25 deletions
diff --git a/include/linux/spinlock_api_smp.h b/include/linux/spinlock_api_smp.h index b2c4f829946..8828b8155e9 100644 --- a/include/linux/spinlock_api_smp.h +++ b/include/linux/spinlock_api_smp.h @@ -19,41 +19,41 @@ int in_lock_functions(unsigned long addr);  #define assert_spin_locked(x)	BUG_ON(!spin_is_locked(x)) -void __lockfunc _spin_lock(spinlock_t *lock)		__acquires(spinlock_t); +void __lockfunc _spin_lock(spinlock_t *lock)		__acquires(lock);  void __lockfunc _spin_lock_nested(spinlock_t *lock, int subclass) -							__acquires(spinlock_t); -void __lockfunc _read_lock(rwlock_t *lock)		__acquires(rwlock_t); -void __lockfunc _write_lock(rwlock_t *lock)		__acquires(rwlock_t); -void __lockfunc _spin_lock_bh(spinlock_t *lock)		__acquires(spinlock_t); -void __lockfunc _read_lock_bh(rwlock_t *lock)		__acquires(rwlock_t); -void __lockfunc _write_lock_bh(rwlock_t *lock)		__acquires(rwlock_t); -void __lockfunc _spin_lock_irq(spinlock_t *lock)	__acquires(spinlock_t); -void __lockfunc _read_lock_irq(rwlock_t *lock)		__acquires(rwlock_t); -void __lockfunc _write_lock_irq(rwlock_t *lock)		__acquires(rwlock_t); +							__acquires(lock); +void __lockfunc _read_lock(rwlock_t *lock)		__acquires(lock); +void __lockfunc _write_lock(rwlock_t *lock)		__acquires(lock); +void __lockfunc _spin_lock_bh(spinlock_t *lock)		__acquires(lock); +void __lockfunc _read_lock_bh(rwlock_t *lock)		__acquires(lock); +void __lockfunc _write_lock_bh(rwlock_t *lock)		__acquires(lock); +void __lockfunc _spin_lock_irq(spinlock_t *lock)	__acquires(lock); +void __lockfunc _read_lock_irq(rwlock_t *lock)		__acquires(lock); +void __lockfunc _write_lock_irq(rwlock_t *lock)		__acquires(lock);  unsigned long __lockfunc _spin_lock_irqsave(spinlock_t *lock) -							__acquires(spinlock_t); +							__acquires(lock);  unsigned long __lockfunc _read_lock_irqsave(rwlock_t *lock) -							__acquires(rwlock_t); +							__acquires(lock);  unsigned long __lockfunc _write_lock_irqsave(rwlock_t *lock) -							__acquires(rwlock_t); +							__acquires(lock);  int __lockfunc _spin_trylock(spinlock_t *lock);  int __lockfunc _read_trylock(rwlock_t *lock);  int __lockfunc _write_trylock(rwlock_t *lock);  int __lockfunc _spin_trylock_bh(spinlock_t *lock); -void __lockfunc _spin_unlock(spinlock_t *lock)		__releases(spinlock_t); -void __lockfunc _read_unlock(rwlock_t *lock)		__releases(rwlock_t); -void __lockfunc _write_unlock(rwlock_t *lock)		__releases(rwlock_t); -void __lockfunc _spin_unlock_bh(spinlock_t *lock)	__releases(spinlock_t); -void __lockfunc _read_unlock_bh(rwlock_t *lock)		__releases(rwlock_t); -void __lockfunc _write_unlock_bh(rwlock_t *lock)	__releases(rwlock_t); -void __lockfunc _spin_unlock_irq(spinlock_t *lock)	__releases(spinlock_t); -void __lockfunc _read_unlock_irq(rwlock_t *lock)	__releases(rwlock_t); -void __lockfunc _write_unlock_irq(rwlock_t *lock)	__releases(rwlock_t); +void __lockfunc _spin_unlock(spinlock_t *lock)		__releases(lock); +void __lockfunc _read_unlock(rwlock_t *lock)		__releases(lock); +void __lockfunc _write_unlock(rwlock_t *lock)		__releases(lock); +void __lockfunc _spin_unlock_bh(spinlock_t *lock)	__releases(lock); +void __lockfunc _read_unlock_bh(rwlock_t *lock)		__releases(lock); +void __lockfunc _write_unlock_bh(rwlock_t *lock)	__releases(lock); +void __lockfunc _spin_unlock_irq(spinlock_t *lock)	__releases(lock); +void __lockfunc _read_unlock_irq(rwlock_t *lock)	__releases(lock); +void __lockfunc _write_unlock_irq(rwlock_t *lock)	__releases(lock);  void __lockfunc _spin_unlock_irqrestore(spinlock_t *lock, unsigned long flags) -							__releases(spinlock_t); +							__releases(lock);  void __lockfunc _read_unlock_irqrestore(rwlock_t *lock, unsigned long flags) -							__releases(rwlock_t); +							__releases(lock);  void __lockfunc _write_unlock_irqrestore(rwlock_t *lock, unsigned long flags) -							__releases(rwlock_t); +							__releases(lock);  #endif /* __LINUX_SPINLOCK_API_SMP_H */  |