提交 4e6ea144 编写于 作者: S Steven Rostedt

ftrace, x86: rename in_nmi variable

Impact: clean up

The in_nmi variable in x86 arch ftrace.c is a misnomer.
Andrew Morton pointed out that the in_nmi variable is incremented
by all CPUS. It can be set when another CPU is running an NMI.

Since this is actually intentional, the fix is to rename it to
what it really is: "nmi_running"
Signed-off-by: NSteven Rostedt <srostedt@redhat.com>
上级 d8b891a2
...@@ -82,7 +82,7 @@ static unsigned char *ftrace_call_replace(unsigned long ip, unsigned long addr) ...@@ -82,7 +82,7 @@ static unsigned char *ftrace_call_replace(unsigned long ip, unsigned long addr)
* are the same as what exists. * are the same as what exists.
*/ */
static atomic_t in_nmi = ATOMIC_INIT(0); static atomic_t nmi_running = ATOMIC_INIT(0);
static int mod_code_status; /* holds return value of text write */ static int mod_code_status; /* holds return value of text write */
static int mod_code_write; /* set when NMI should do the write */ static int mod_code_write; /* set when NMI should do the write */
static void *mod_code_ip; /* holds the IP to write to */ static void *mod_code_ip; /* holds the IP to write to */
...@@ -115,8 +115,8 @@ static void ftrace_mod_code(void) ...@@ -115,8 +115,8 @@ static void ftrace_mod_code(void)
void arch_ftrace_nmi_enter(void) void arch_ftrace_nmi_enter(void)
{ {
atomic_inc(&in_nmi); atomic_inc(&nmi_running);
/* Must have in_nmi seen before reading write flag */ /* Must have nmi_running seen before reading write flag */
smp_mb(); smp_mb();
if (mod_code_write) { if (mod_code_write) {
ftrace_mod_code(); ftrace_mod_code();
...@@ -126,19 +126,19 @@ void arch_ftrace_nmi_enter(void) ...@@ -126,19 +126,19 @@ void arch_ftrace_nmi_enter(void)
void arch_ftrace_nmi_exit(void) void arch_ftrace_nmi_exit(void)
{ {
/* Finish all executions before clearing in_nmi */ /* Finish all executions before clearing nmi_running */
smp_wmb(); smp_wmb();
atomic_dec(&in_nmi); atomic_dec(&nmi_running);
} }
static void wait_for_nmi(void) static void wait_for_nmi(void)
{ {
if (!atomic_read(&in_nmi)) if (!atomic_read(&nmi_running))
return; return;
do { do {
cpu_relax(); cpu_relax();
} while(atomic_read(&in_nmi)); } while (atomic_read(&nmi_running));
nmi_wait_count++; nmi_wait_count++;
} }
...@@ -374,16 +374,16 @@ int ftrace_disable_ftrace_graph_caller(void) ...@@ -374,16 +374,16 @@ int ftrace_disable_ftrace_graph_caller(void)
* this page for dynamic ftrace. They have been * this page for dynamic ftrace. They have been
* simplified to ignore all traces in NMI context. * simplified to ignore all traces in NMI context.
*/ */
static atomic_t in_nmi; static atomic_t nmi_running;
void arch_ftrace_nmi_enter(void) void arch_ftrace_nmi_enter(void)
{ {
atomic_inc(&in_nmi); atomic_inc(&nmi_running);
} }
void arch_ftrace_nmi_exit(void) void arch_ftrace_nmi_exit(void)
{ {
atomic_dec(&in_nmi); atomic_dec(&nmi_running);
} }
#endif /* !CONFIG_DYNAMIC_FTRACE */ #endif /* !CONFIG_DYNAMIC_FTRACE */
...@@ -475,7 +475,7 @@ void prepare_ftrace_return(unsigned long *parent, unsigned long self_addr) ...@@ -475,7 +475,7 @@ void prepare_ftrace_return(unsigned long *parent, unsigned long self_addr)
&return_to_handler; &return_to_handler;
/* Nmi's are currently unsupported */ /* Nmi's are currently unsupported */
if (unlikely(atomic_read(&in_nmi))) if (unlikely(atomic_read(&nmi_running)))
return; return;
if (unlikely(atomic_read(&current->tracing_graph_pause))) if (unlikely(atomic_read(&current->tracing_graph_pause)))
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册