diff options
Diffstat (limited to 'include/linux/preempt.h')
| -rw-r--r-- | include/linux/preempt.h | 34 |
1 files changed, 33 insertions, 1 deletions
diff --git a/include/linux/preempt.h b/include/linux/preempt.h index 23f0c54175cd..72b1a10a59b6 100644 --- a/include/linux/preempt.h +++ b/include/linux/preempt.h | |||
| @@ -10,7 +10,7 @@ | |||
| 10 | #include <linux/linkage.h> | 10 | #include <linux/linkage.h> |
| 11 | #include <linux/list.h> | 11 | #include <linux/list.h> |
| 12 | 12 | ||
| 13 | #ifdef CONFIG_DEBUG_PREEMPT | 13 | #if defined(CONFIG_DEBUG_PREEMPT) || defined(CONFIG_PREEMPT_TRACER) |
| 14 | extern void add_preempt_count(int val); | 14 | extern void add_preempt_count(int val); |
| 15 | extern void sub_preempt_count(int val); | 15 | extern void sub_preempt_count(int val); |
| 16 | #else | 16 | #else |
| @@ -52,6 +52,34 @@ do { \ | |||
| 52 | preempt_check_resched(); \ | 52 | preempt_check_resched(); \ |
| 53 | } while (0) | 53 | } while (0) |
| 54 | 54 | ||
| 55 | /* For debugging and tracer internals only! */ | ||
| 56 | #define add_preempt_count_notrace(val) \ | ||
| 57 | do { preempt_count() += (val); } while (0) | ||
| 58 | #define sub_preempt_count_notrace(val) \ | ||
| 59 | do { preempt_count() -= (val); } while (0) | ||
| 60 | #define inc_preempt_count_notrace() add_preempt_count_notrace(1) | ||
| 61 | #define dec_preempt_count_notrace() sub_preempt_count_notrace(1) | ||
| 62 | |||
| 63 | #define preempt_disable_notrace() \ | ||
| 64 | do { \ | ||
| 65 | inc_preempt_count_notrace(); \ | ||
| 66 | barrier(); \ | ||
| 67 | } while (0) | ||
| 68 | |||
| 69 | #define preempt_enable_no_resched_notrace() \ | ||
| 70 | do { \ | ||
| 71 | barrier(); \ | ||
| 72 | dec_preempt_count_notrace(); \ | ||
| 73 | } while (0) | ||
| 74 | |||
| 75 | /* preempt_check_resched is OK to trace */ | ||
| 76 | #define preempt_enable_notrace() \ | ||
| 77 | do { \ | ||
| 78 | preempt_enable_no_resched_notrace(); \ | ||
| 79 | barrier(); \ | ||
| 80 | preempt_check_resched(); \ | ||
| 81 | } while (0) | ||
| 82 | |||
| 55 | #else | 83 | #else |
| 56 | 84 | ||
| 57 | #define preempt_disable() do { } while (0) | 85 | #define preempt_disable() do { } while (0) |
| @@ -59,6 +87,10 @@ do { \ | |||
| 59 | #define preempt_enable() do { } while (0) | 87 | #define preempt_enable() do { } while (0) |
| 60 | #define preempt_check_resched() do { } while (0) | 88 | #define preempt_check_resched() do { } while (0) |
| 61 | 89 | ||
| 90 | #define preempt_disable_notrace() do { } while (0) | ||
| 91 | #define preempt_enable_no_resched_notrace() do { } while (0) | ||
| 92 | #define preempt_enable_notrace() do { } while (0) | ||
| 93 | |||
| 62 | #endif | 94 | #endif |
| 63 | 95 | ||
| 64 | #ifdef CONFIG_PREEMPT_NOTIFIERS | 96 | #ifdef CONFIG_PREEMPT_NOTIFIERS |
