semaphore.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * Copyright (c) 2008 Intel Corporation
  3. * Author: Matthew Wilcox <willy@linux.intel.com>
  4. *
  5. * Distributed under the terms of the GNU GPL, version 2
  6. *
  7. * Please see kernel/semaphore.c for documentation of these functions
  8. */
  9. #ifndef __LINUX_SEMAPHORE_H
  10. #define __LINUX_SEMAPHORE_H
  11. #include <linux/list.h>
  12. #include <linux/spinlock.h>
  13. /* Please don't access any members of this structure directly */
  14. struct semaphore {
  15. spinlock_t lock;
  16. unsigned int count;
  17. struct list_head wait_list;
  18. };
  19. #define __SEMAPHORE_INITIALIZER(name, n) \
  20. { \
  21. .lock = __SPIN_LOCK_UNLOCKED((name).lock), \
  22. .count = n, \
  23. .wait_list = LIST_HEAD_INIT((name).wait_list), \
  24. }
  25. #define DEFINE_SEMAPHORE(name) \
  26. struct semaphore name = __SEMAPHORE_INITIALIZER(name, 1)
  27. #define DECLARE_MUTEX(name) \
  28. struct semaphore name = __SEMAPHORE_INITIALIZER(name, 1)
  29. static inline void sema_init(struct semaphore *sem, int val)
  30. {
  31. static struct lock_class_key __key;
  32. *sem = (struct semaphore) __SEMAPHORE_INITIALIZER(*sem, val);
  33. lockdep_init_map(&sem->lock.dep_map, "semaphore->lock", &__key, 0);
  34. }
  35. #define init_MUTEX(sem) sema_init(sem, 1)
  36. #define init_MUTEX_LOCKED(sem) sema_init(sem, 0)
  37. extern void down(struct semaphore *sem);
  38. extern int __must_check down_interruptible(struct semaphore *sem);
  39. extern int __must_check down_killable(struct semaphore *sem);
  40. extern int __must_check down_trylock(struct semaphore *sem);
  41. extern int __must_check down_timeout(struct semaphore *sem, long jiffies);
  42. extern void up(struct semaphore *sem);
  43. #endif /* __LINUX_SEMAPHORE_H */