|
@@ -32,4 +32,23 @@ extern void percpu_free_rwsem(struct percpu_rw_semaphore *);
|
|
|
__percpu_init_rwsem(brw, #brw, &rwsem_key); \
|
|
|
})
|
|
|
|
|
|
+
|
|
|
+#define percpu_rwsem_is_held(sem) lockdep_is_held(&(sem)->rw_sem)
|
|
|
+
|
|
|
+static inline void percpu_rwsem_release(struct percpu_rw_semaphore *sem,
|
|
|
+ bool read, unsigned long ip)
|
|
|
+{
|
|
|
+ lock_release(&sem->rw_sem.dep_map, 1, ip);
|
|
|
+#ifdef CONFIG_RWSEM_SPIN_ON_OWNER
|
|
|
+ if (!read)
|
|
|
+ sem->rw_sem.owner = NULL;
|
|
|
+#endif
|
|
|
+}
|
|
|
+
|
|
|
+static inline void percpu_rwsem_acquire(struct percpu_rw_semaphore *sem,
|
|
|
+ bool read, unsigned long ip)
|
|
|
+{
|
|
|
+ lock_acquire(&sem->rw_sem.dep_map, 0, 1, read, 1, NULL, ip);
|
|
|
+}
|
|
|
+
|
|
|
#endif
|