Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Ingo Molnar | e7eebaf | 2006-06-27 02:54:55 -0700 | [diff] [blame] | 2 | /* |
| 3 | * RT-Mutexes: blocking mutual exclusion locks with PI support |
| 4 | * |
| 5 | * started by Ingo Molnar and Thomas Gleixner: |
| 6 | * |
| 7 | * Copyright (C) 2004-2006 Red Hat, Inc., Ingo Molnar <mingo@redhat.com> |
| 8 | * Copyright (C) 2006, Timesys Corp., Thomas Gleixner <tglx@timesys.com> |
| 9 | * |
| 10 | * This file contains macros used solely by rtmutex.c. Debug version. |
| 11 | */ |
| 12 | |
Ingo Molnar | e7eebaf | 2006-06-27 02:54:55 -0700 | [diff] [blame] | 13 | extern void debug_rt_mutex_init_waiter(struct rt_mutex_waiter *waiter); |
| 14 | extern void debug_rt_mutex_free_waiter(struct rt_mutex_waiter *waiter); |
Peter Zijlstra | f569478 | 2016-09-19 12:15:37 +0200 | [diff] [blame] | 15 | extern void debug_rt_mutex_init(struct rt_mutex *lock, const char *name, struct lock_class_key *key); |
Ingo Molnar | 9a11b49a | 2006-07-03 00:24:33 -0700 | [diff] [blame] | 16 | extern void debug_rt_mutex_lock(struct rt_mutex *lock); |
Ingo Molnar | e7eebaf | 2006-06-27 02:54:55 -0700 | [diff] [blame] | 17 | extern void debug_rt_mutex_unlock(struct rt_mutex *lock); |
| 18 | extern void debug_rt_mutex_proxy_lock(struct rt_mutex *lock, |
Ingo Molnar | 9a11b49a | 2006-07-03 00:24:33 -0700 | [diff] [blame] | 19 | struct task_struct *powner); |
Ingo Molnar | e7eebaf | 2006-06-27 02:54:55 -0700 | [diff] [blame] | 20 | extern void debug_rt_mutex_proxy_unlock(struct rt_mutex *lock); |
Thomas Gleixner | 8930ed8 | 2014-05-22 03:25:47 +0000 | [diff] [blame] | 21 | extern void debug_rt_mutex_deadlock(enum rtmutex_chainwalk chwalk, |
| 22 | struct rt_mutex_waiter *waiter, |
Ingo Molnar | e7eebaf | 2006-06-27 02:54:55 -0700 | [diff] [blame] | 23 | struct rt_mutex *lock); |
| 24 | extern void debug_rt_mutex_print_deadlock(struct rt_mutex_waiter *waiter); |
| 25 | # define debug_rt_mutex_reset_waiter(w) \ |
| 26 | do { (w)->deadlock_lock = NULL; } while (0) |
| 27 | |
Thomas Gleixner | 8930ed8 | 2014-05-22 03:25:47 +0000 | [diff] [blame] | 28 | static inline bool debug_rt_mutex_detect_deadlock(struct rt_mutex_waiter *waiter, |
| 29 | enum rtmutex_chainwalk walk) |
Ingo Molnar | e7eebaf | 2006-06-27 02:54:55 -0700 | [diff] [blame] | 30 | { |
| 31 | return (waiter != NULL); |
| 32 | } |
Thomas Gleixner | 3d5c934 | 2014-06-05 12:34:23 +0200 | [diff] [blame] | 33 | |
| 34 | static inline void rt_mutex_print_deadlock(struct rt_mutex_waiter *w) |
| 35 | { |
| 36 | debug_rt_mutex_print_deadlock(w); |
| 37 | } |