diff options
Diffstat (limited to 'kernel/locking/mutex.h')
| -rw-r--r-- | kernel/locking/mutex.h | 48 | 
1 files changed, 35 insertions, 13 deletions
diff --git a/kernel/locking/mutex.h b/kernel/locking/mutex.h index f0c710b1d192..0b2a79c4013b 100644 --- a/kernel/locking/mutex.h +++ b/kernel/locking/mutex.h @@ -5,19 +5,41 @@   * started by Ingo Molnar:   *   *  Copyright (C) 2004, 2005, 2006 Red Hat, Inc., Ingo Molnar <[email protected]> - * - * This file contains mutex debugging related internal prototypes, for the - * !CONFIG_DEBUG_MUTEXES case. Most of them are NOPs:   */ -#define debug_mutex_wake_waiter(lock, waiter)		do { } while (0) -#define debug_mutex_free_waiter(waiter)			do { } while (0) -#define debug_mutex_add_waiter(lock, waiter, ti)	do { } while (0) -#define debug_mutex_remove_waiter(lock, waiter, ti)     do { } while (0) -#define debug_mutex_unlock(lock)			do { } while (0) -#define debug_mutex_init(lock, name, key)		do { } while (0) +/* + * This is the control structure for tasks blocked on mutex, which resides + * on the blocked task's kernel stack: + */ +struct mutex_waiter { +	struct list_head	list; +	struct task_struct	*task; +	struct ww_acquire_ctx	*ww_ctx; +#ifdef CONFIG_DEBUG_MUTEXES +	void			*magic; +#endif +}; -static inline void -debug_mutex_lock_common(struct mutex *lock, struct mutex_waiter *waiter) -{ -} +#ifdef CONFIG_DEBUG_MUTEXES +extern void debug_mutex_lock_common(struct mutex *lock, +				    struct mutex_waiter *waiter); +extern void debug_mutex_wake_waiter(struct mutex *lock, +				    struct mutex_waiter *waiter); +extern void debug_mutex_free_waiter(struct mutex_waiter *waiter); +extern void debug_mutex_add_waiter(struct mutex *lock, +				   struct mutex_waiter *waiter, +				   struct task_struct *task); +extern void debug_mutex_remove_waiter(struct mutex *lock, struct mutex_waiter *waiter, +				      struct task_struct *task); +extern void debug_mutex_unlock(struct mutex *lock); +extern void debug_mutex_init(struct mutex *lock, const char *name, +			     struct lock_class_key *key); +#else /* CONFIG_DEBUG_MUTEXES */ +# define debug_mutex_lock_common(lock, waiter)		do { } while (0) +# define debug_mutex_wake_waiter(lock, waiter)		do { } while (0) +# define debug_mutex_free_waiter(waiter)		do { } while (0) +# define debug_mutex_add_waiter(lock, waiter, ti)	do { } while (0) +# define debug_mutex_remove_waiter(lock, waiter, ti)	do { } while (0) +# define debug_mutex_unlock(lock)			do { } while (0) +# define debug_mutex_init(lock, name, key)		do { } while (0) +#endif /* !CONFIG_DEBUG_MUTEXES */  |