mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 c86ad14d30
			
		
	
	
		c86ad14d30
		
	
	
	
	
		
			
			Pull locking updates from Ingo Molnar:
 "The locking tree was busier in this cycle than the usual pattern - a
  couple of major projects happened to coincide.
  The main changes are:
   - implement the atomic_fetch_{add,sub,and,or,xor}() API natively
     across all SMP architectures (Peter Zijlstra)
   - add atomic_fetch_{inc/dec}() as well, using the generic primitives
     (Davidlohr Bueso)
   - optimize various aspects of rwsems (Jason Low, Davidlohr Bueso,
     Waiman Long)
   - optimize smp_cond_load_acquire() on arm64 and implement LSE based
     atomic{,64}_fetch_{add,sub,and,andnot,or,xor}{,_relaxed,_acquire,_release}()
     on arm64 (Will Deacon)
   - introduce smp_acquire__after_ctrl_dep() and fix various barrier
     mis-uses and bugs (Peter Zijlstra)
   - after discovering ancient spin_unlock_wait() barrier bugs in its
     implementation and usage, strengthen its semantics and update/fix
     usage sites (Peter Zijlstra)
   - optimize mutex_trylock() fastpath (Peter Zijlstra)
   - ... misc fixes and cleanups"
* 'locking-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (67 commits)
  locking/atomic: Introduce inc/dec variants for the atomic_fetch_$op() API
  locking/barriers, arch/arm64: Implement LDXR+WFE based smp_cond_load_acquire()
  locking/static_keys: Fix non static symbol Sparse warning
  locking/qspinlock: Use __this_cpu_dec() instead of full-blown this_cpu_dec()
  locking/atomic, arch/tile: Fix tilepro build
  locking/atomic, arch/m68k: Remove comment
  locking/atomic, arch/arc: Fix build
  locking/Documentation: Clarify limited control-dependency scope
  locking/atomic, arch/rwsem: Employ atomic_long_fetch_add()
  locking/atomic, arch/qrwlock: Employ atomic_fetch_add_acquire()
  locking/atomic, arch/mips: Convert to _relaxed atomics
  locking/atomic, arch/alpha: Convert to _relaxed atomics
  locking/atomic: Remove the deprecated atomic_{set,clear}_mask() functions
  locking/atomic: Remove linux/atomic.h:atomic_fetch_or()
  locking/atomic: Implement atomic{,64,_long}_fetch_{add,sub,and,andnot,or,xor}{,_relaxed,_acquire,_release}()
  locking/atomic: Fix atomic64_relaxed() bits
  locking/atomic, arch/xtensa: Implement atomic_fetch_{add,sub,and,or,xor}()
  locking/atomic, arch/x86: Implement atomic{,64}_fetch_{add,sub,and,or,xor}()
  locking/atomic, arch/tile: Implement atomic{,64}_fetch_{add,sub,and,or,xor}()
  locking/atomic, arch/sparc: Implement atomic{,64}_fetch_{add,sub,and,or,xor}()
  ...
		
	
			
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Mutexes: blocking mutual exclusion locks
 | |
|  *
 | |
|  * started by Ingo Molnar:
 | |
|  *
 | |
|  *  Copyright (C) 2004, 2005, 2006 Red Hat, Inc., Ingo Molnar <mingo@redhat.com>
 | |
|  *
 | |
|  * This file contains mutex debugging related internal prototypes, for the
 | |
|  * !CONFIG_DEBUG_MUTEXES case. Most of them are NOPs:
 | |
|  */
 | |
| 
 | |
| #define spin_lock_mutex(lock, flags) \
 | |
| 		do { spin_lock(lock); (void)(flags); } while (0)
 | |
| #define spin_unlock_mutex(lock, flags) \
 | |
| 		do { spin_unlock(lock); (void)(flags); } while (0)
 | |
| #define mutex_remove_waiter(lock, waiter, task) \
 | |
| 		__list_del((waiter)->list.prev, (waiter)->list.next)
 | |
| 
 | |
| #ifdef CONFIG_MUTEX_SPIN_ON_OWNER
 | |
| /*
 | |
|  * The mutex owner can get read and written to locklessly.
 | |
|  * We should use WRITE_ONCE when writing the owner value to
 | |
|  * avoid store tearing, otherwise, a thread could potentially
 | |
|  * read a partially written and incomplete owner value.
 | |
|  */
 | |
| static inline void mutex_set_owner(struct mutex *lock)
 | |
| {
 | |
| 	WRITE_ONCE(lock->owner, current);
 | |
| }
 | |
| 
 | |
| static inline void mutex_clear_owner(struct mutex *lock)
 | |
| {
 | |
| 	WRITE_ONCE(lock->owner, NULL);
 | |
| }
 | |
| #else
 | |
| static inline void mutex_set_owner(struct mutex *lock)
 | |
| {
 | |
| }
 | |
| 
 | |
| static inline void mutex_clear_owner(struct mutex *lock)
 | |
| {
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #define debug_mutex_wake_waiter(lock, waiter)		do { } while (0)
 | |
| #define debug_mutex_free_waiter(waiter)			do { } while (0)
 | |
| #define debug_mutex_add_waiter(lock, waiter, ti)	do { } while (0)
 | |
| #define debug_mutex_unlock(lock)			do { } while (0)
 | |
| #define debug_mutex_init(lock, name, key)		do { } while (0)
 | |
| 
 | |
| static inline void
 | |
| debug_mutex_lock_common(struct mutex *lock, struct mutex_waiter *waiter)
 | |
| {
 | |
| }
 |