diff options
Diffstat (limited to 'kernel/trace/trace.c')
| -rw-r--r-- | kernel/trace/trace.c | 19 | 
1 files changed, 18 insertions, 1 deletions
| diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 2bee793749d8..88bb99b96150 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c @@ -1803,7 +1803,17 @@ void trace_buffer_unlock_commit_regs(struct trace_array *tr,  {  	__buffer_unlock_commit(buffer, event); -	ftrace_trace_stack(tr, buffer, flags, 0, pc, regs); +	/* +	 * If regs is not set, then skip the following callers: +	 *   trace_buffer_unlock_commit_regs +	 *   event_trigger_unlock_commit +	 *   trace_event_buffer_commit +	 *   trace_event_raw_event_sched_switch +	 * Note, we can still get here via blktrace, wakeup tracer +	 * and mmiotrace, but that's ok if they lose a function or +	 * two. They are that meaningful. +	 */ +	ftrace_trace_stack(tr, buffer, flags, regs ? 0 : 4, pc, regs);  	ftrace_trace_userstack(buffer, flags, pc);  }  EXPORT_SYMBOL_GPL(trace_buffer_unlock_commit_regs); @@ -1862,6 +1872,13 @@ static void __ftrace_trace_stack(struct ring_buffer *buffer,  	trace.skip		= skip;  	/* +	 * Add two, for this function and the call to save_stack_trace() +	 * If regs is set, then these functions will not be in the way. +	 */ +	if (!regs) +		trace.skip += 2; + +	/*  	 * Since events can happen in NMIs there's no safe way to  	 * use the per cpu ftrace_stacks. We reserve it and if an interrupt  	 * or NMI comes in, it will just have to use the default | 
