Lines Matching refs:sem

70 static inline int rwsem_is_locked(struct rw_semaphore *sem)  in rwsem_is_locked()  argument
72 return atomic_long_read(&sem->count) != 0; in rwsem_is_locked()
104 extern void __init_rwsem(struct rw_semaphore *sem, const char *name,
107 #define init_rwsem(sem) \ argument
111 __init_rwsem((sem), #sem, &__key); \
120 static inline int rwsem_is_contended(struct rw_semaphore *sem) in rwsem_is_contended() argument
122 return !list_empty(&sem->wait_list); in rwsem_is_contended()
148 #define init_rwsem(sem) \ argument
152 __init_rwsem((sem), #sem, &__key); \
155 static __always_inline int rwsem_is_locked(struct rw_semaphore *sem) in rwsem_is_locked() argument
157 return rw_base_is_locked(&sem->rwbase); in rwsem_is_locked()
160 static __always_inline int rwsem_is_contended(struct rw_semaphore *sem) in rwsem_is_contended() argument
162 return rw_base_is_contended(&sem->rwbase); in rwsem_is_contended()
175 extern void down_read(struct rw_semaphore *sem);
176 extern int __must_check down_read_interruptible(struct rw_semaphore *sem);
177 extern int __must_check down_read_killable(struct rw_semaphore *sem);
182 extern int down_read_trylock(struct rw_semaphore *sem);
187 extern void down_write(struct rw_semaphore *sem);
188 extern int __must_check down_write_killable(struct rw_semaphore *sem);
193 extern int down_write_trylock(struct rw_semaphore *sem);
198 extern void up_read(struct rw_semaphore *sem);
203 extern void up_write(struct rw_semaphore *sem);
208 extern void downgrade_write(struct rw_semaphore *sem);
224 extern void down_read_nested(struct rw_semaphore *sem, int subclass);
225 extern int __must_check down_read_killable_nested(struct rw_semaphore *sem, int subclass);
226 extern void down_write_nested(struct rw_semaphore *sem, int subclass);
227 extern int down_write_killable_nested(struct rw_semaphore *sem, int subclass);
228 extern void _down_write_nest_lock(struct rw_semaphore *sem, struct lockdep_map *nest_lock);
230 # define down_write_nest_lock(sem, nest_lock) \ argument
233 _down_write_nest_lock(sem, &(nest_lock)->dep_map); \
242 extern void down_read_non_owner(struct rw_semaphore *sem);
243 extern void up_read_non_owner(struct rw_semaphore *sem);
245 # define down_read_nested(sem, subclass) down_read(sem) argument
246 # define down_read_killable_nested(sem, subclass) down_read_killable(sem) argument
247 # define down_write_nest_lock(sem, nest_lock) down_write(sem) argument
248 # define down_write_nested(sem, subclass) down_write(sem) argument
249 # define down_write_killable_nested(sem, subclass) down_write_killable(sem) argument
250 # define down_read_non_owner(sem) down_read(sem) argument
251 # define up_read_non_owner(sem) up_read(sem) argument