diff options
-rw-r--r-- | include/linux/ftrace.h | 1 | ||||
-rw-r--r-- | kernel/trace/ftrace.c | 15 |
2 files changed, 16 insertions, 0 deletions
diff --git a/include/linux/ftrace.h b/include/linux/ftrace.h index 3121b95443d9..f368d041e02d 100644 --- a/include/linux/ftrace.h +++ b/include/linux/ftrace.h | |||
@@ -89,6 +89,7 @@ void ftrace_enable_daemon(void); | |||
89 | 89 | ||
90 | /* totally disable ftrace - can not re-enable after this */ | 90 | /* totally disable ftrace - can not re-enable after this */ |
91 | void ftrace_kill(void); | 91 | void ftrace_kill(void); |
92 | void ftrace_kill_atomic(void); | ||
92 | 93 | ||
93 | static inline void tracer_disable(void) | 94 | static inline void tracer_disable(void) |
94 | { | 95 | { |
diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c index 0f271c45cd02..1359632668a4 100644 --- a/kernel/trace/ftrace.c +++ b/kernel/trace/ftrace.c | |||
@@ -1602,6 +1602,21 @@ core_initcall(ftrace_dynamic_init); | |||
1602 | #endif /* CONFIG_DYNAMIC_FTRACE */ | 1602 | #endif /* CONFIG_DYNAMIC_FTRACE */ |
1603 | 1603 | ||
1604 | /** | 1604 | /** |
1605 | * ftrace_kill_atomic - kill ftrace from critical sections | ||
1606 | * | ||
1607 | * This function should be used by panic code. It stops ftrace | ||
1608 | * but in a not so nice way. If you need to simply kill ftrace | ||
1609 | * from a non-atomic section, use ftrace_kill. | ||
1610 | */ | ||
1611 | void ftrace_kill_atomic(void) | ||
1612 | { | ||
1613 | ftrace_disabled = 1; | ||
1614 | ftrace_enabled = 0; | ||
1615 | ftraced_suspend = -1; | ||
1616 | clear_ftrace_function(); | ||
1617 | } | ||
1618 | |||
1619 | /** | ||
1605 | * ftrace_kill - totally shutdown ftrace | 1620 | * ftrace_kill - totally shutdown ftrace |
1606 | * | 1621 | * |
1607 | * This is a safety measure. If something was detected that seems | 1622 | * This is a safety measure. If something was detected that seems |