diff options
author | Peter Zijlstra <peterz@infradead.org> | 2013-10-31 13:18:19 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2013-11-06 03:23:59 -0500 |
commit | 1696a8bee390929fed05c6297164816ae2ced280 (patch) | |
tree | 59866e14aa5f8bf6f5ac0fa69211be6a5e05afd3 /kernel/locking/rtmutex-debug.h | |
parent | e25a64c4017e3a3cda17454b040737e410a12991 (diff) |
locking: Move the rtmutex code to kernel/locking/
Suggested-by: Ingo Molnar <mingo@kernel.org>
Signed-off-by: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/n/tip-p9ijt8div0hwldexwfm4nlhj@git.kernel.org
[ Fixed build failure in kernel/rcu/tree_plugin.h. ]
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'kernel/locking/rtmutex-debug.h')
-rw-r--r-- | kernel/locking/rtmutex-debug.h | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/kernel/locking/rtmutex-debug.h b/kernel/locking/rtmutex-debug.h new file mode 100644 index 000000000000..14193d596d78 --- /dev/null +++ b/kernel/locking/rtmutex-debug.h | |||
@@ -0,0 +1,33 @@ | |||
1 | /* | ||
2 | * RT-Mutexes: blocking mutual exclusion locks with PI support | ||
3 | * | ||
4 | * started by Ingo Molnar and Thomas Gleixner: | ||
5 | * | ||
6 | * Copyright (C) 2004-2006 Red Hat, Inc., Ingo Molnar <mingo@redhat.com> | ||
7 | * Copyright (C) 2006, Timesys Corp., Thomas Gleixner <tglx@timesys.com> | ||
8 | * | ||
9 | * This file contains macros used solely by rtmutex.c. Debug version. | ||
10 | */ | ||
11 | |||
12 | extern void | ||
13 | rt_mutex_deadlock_account_lock(struct rt_mutex *lock, struct task_struct *task); | ||
14 | extern void rt_mutex_deadlock_account_unlock(struct task_struct *task); | ||
15 | extern void debug_rt_mutex_init_waiter(struct rt_mutex_waiter *waiter); | ||
16 | extern void debug_rt_mutex_free_waiter(struct rt_mutex_waiter *waiter); | ||
17 | extern void debug_rt_mutex_init(struct rt_mutex *lock, const char *name); | ||
18 | extern void debug_rt_mutex_lock(struct rt_mutex *lock); | ||
19 | extern void debug_rt_mutex_unlock(struct rt_mutex *lock); | ||
20 | extern void debug_rt_mutex_proxy_lock(struct rt_mutex *lock, | ||
21 | struct task_struct *powner); | ||
22 | extern void debug_rt_mutex_proxy_unlock(struct rt_mutex *lock); | ||
23 | extern void debug_rt_mutex_deadlock(int detect, struct rt_mutex_waiter *waiter, | ||
24 | struct rt_mutex *lock); | ||
25 | extern void debug_rt_mutex_print_deadlock(struct rt_mutex_waiter *waiter); | ||
26 | # define debug_rt_mutex_reset_waiter(w) \ | ||
27 | do { (w)->deadlock_lock = NULL; } while (0) | ||
28 | |||
29 | static inline int debug_rt_mutex_detect_deadlock(struct rt_mutex_waiter *waiter, | ||
30 | int detect) | ||
31 | { | ||
32 | return (waiter != NULL); | ||
33 | } | ||