mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-18 22:14:16 +00:00 
			
		
		
		
	sh/function_graph: Simplify with function_graph_enter()
The function_graph_enter() function does the work of calling the function
graph hook function and the management of the shadow stack, simplifying the
work done in the architecture dependent prepare_ftrace_return().
Have superh use the new code, and remove the shadow stack management as well as
having to set up the trace structure.
This is needed to prepare for a fix of a design bug on how the curr_ret_stack
is used.
Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
Cc: Rich Felker <dalias@libc.org>
Cc: linux-sh@vger.kernel.org
Cc: stable@kernel.org
Fixes: 03274a3ffb ("tracing/fgraph: Adjust fgraph depth before calling trace return callback")
Reviewed-by: Masami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
			
			
This commit is contained in:
		
							parent
							
								
									18588e1487
								
							
						
					
					
						commit
						bc715ee4db
					
				
					 1 changed files with 2 additions and 14 deletions
				
			
		|  | @ -321,8 +321,7 @@ int ftrace_disable_ftrace_graph_caller(void) | |||
| void prepare_ftrace_return(unsigned long *parent, unsigned long self_addr) | ||||
| { | ||||
| 	unsigned long old; | ||||
| 	int faulted, err; | ||||
| 	struct ftrace_graph_ent trace; | ||||
| 	int faulted; | ||||
| 	unsigned long return_hooker = (unsigned long)&return_to_handler; | ||||
| 
 | ||||
| 	if (unlikely(ftrace_graph_is_dead())) | ||||
|  | @ -365,18 +364,7 @@ void prepare_ftrace_return(unsigned long *parent, unsigned long self_addr) | |||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	err = ftrace_push_return_trace(old, self_addr, &trace.depth, 0, NULL); | ||||
| 	if (err == -EBUSY) { | ||||
| 	if (function_graph_enter(old, self_addr, 0, NULL)) | ||||
| 		__raw_writel(old, parent); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	trace.func = self_addr; | ||||
| 
 | ||||
| 	/* Only trace if the calling function expects to */ | ||||
| 	if (!ftrace_graph_entry(&trace)) { | ||||
| 		current->curr_ret_stack--; | ||||
| 		__raw_writel(old, parent); | ||||
| 	} | ||||
| } | ||||
| #endif /* CONFIG_FUNCTION_GRAPH_TRACER */ | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Steven Rostedt (VMware)
						Steven Rostedt (VMware)