~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/fs/bcachefs/two_state_shared_lock.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0 */
  2 #ifndef _BCACHEFS_TWO_STATE_LOCK_H
  3 #define _BCACHEFS_TWO_STATE_LOCK_H
  4 
  5 #include <linux/atomic.h>
  6 #include <linux/sched.h>
  7 #include <linux/wait.h>
  8 
  9 #include "util.h"
 10 
 11 /*
 12  * Two-state lock - can be taken for add or block - both states are shared,
 13  * like read side of rwsem, but conflict with other state:
 14  */
 15 typedef struct {
 16         atomic_long_t           v;
 17         wait_queue_head_t       wait;
 18 } two_state_lock_t;
 19 
 20 static inline void two_state_lock_init(two_state_lock_t *lock)
 21 {
 22         atomic_long_set(&lock->v, 0);
 23         init_waitqueue_head(&lock->wait);
 24 }
 25 
 26 static inline void bch2_two_state_unlock(two_state_lock_t *lock, int s)
 27 {
 28         long i = s ? 1 : -1;
 29 
 30         EBUG_ON(atomic_long_read(&lock->v) == 0);
 31 
 32         if (atomic_long_sub_return_release(i, &lock->v) == 0)
 33                 wake_up_all(&lock->wait);
 34 }
 35 
 36 static inline bool bch2_two_state_trylock(two_state_lock_t *lock, int s)
 37 {
 38         long i = s ? 1 : -1;
 39         long old;
 40 
 41         old = atomic_long_read(&lock->v);
 42         do {
 43                 if (i > 0 ? old < 0 : old > 0)
 44                         return false;
 45         } while (!atomic_long_try_cmpxchg_acquire(&lock->v, &old, old + i));
 46 
 47         return true;
 48 }
 49 
 50 void __bch2_two_state_lock(two_state_lock_t *, int);
 51 
 52 static inline void bch2_two_state_lock(two_state_lock_t *lock, int s)
 53 {
 54         if (!bch2_two_state_trylock(lock, s))
 55                 __bch2_two_state_lock(lock, s);
 56 }
 57 
 58 #endif /* _BCACHEFS_TWO_STATE_LOCK_H */
 59 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php