mutex-debug.h 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. /*
  2. * Mutexes: blocking mutual exclusion locks
  3. *
  4. * started by Ingo Molnar:
  5. *
  6. * Copyright (C) 2004, 2005, 2006 Red Hat, Inc., Ingo Molnar <mingo@redhat.com>
  7. *
  8. * This file contains mutex debugging related internal declarations,
  9. * prototypes and inline functions, for the CONFIG_DEBUG_MUTEXES case.
  10. * More details are in kernel/mutex-debug.c.
  11. */
  12. /*
  13. * This must be called with lock->wait_lock held.
  14. */
  15. extern void debug_mutex_lock_common(struct mutex *lock,
  16. struct mutex_waiter *waiter);
  17. extern void debug_mutex_wake_waiter(struct mutex *lock,
  18. struct mutex_waiter *waiter);
  19. extern void debug_mutex_free_waiter(struct mutex_waiter *waiter);
  20. extern void debug_mutex_add_waiter(struct mutex *lock,
  21. struct mutex_waiter *waiter,
  22. struct task_struct *task);
  23. extern void mutex_remove_waiter(struct mutex *lock, struct mutex_waiter *waiter,
  24. struct task_struct *task);
  25. extern void debug_mutex_unlock(struct mutex *lock);
  26. extern void debug_mutex_init(struct mutex *lock, const char *name,
  27. struct lock_class_key *key);
  28. #define spin_lock_mutex(lock, flags) \
  29. do { \
  30. struct mutex *l = container_of(lock, struct mutex, wait_lock); \
  31. \
  32. DEBUG_LOCKS_WARN_ON(in_interrupt()); \
  33. local_irq_save(flags); \
  34. arch_spin_lock(&(lock)->rlock.raw_lock);\
  35. DEBUG_LOCKS_WARN_ON(l->magic != l); \
  36. } while (0)
  37. #define spin_unlock_mutex(lock, flags) \
  38. do { \
  39. arch_spin_unlock(&(lock)->rlock.raw_lock); \
  40. local_irq_restore(flags); \
  41. preempt_check_resched(); \
  42. } while (0)