Commit 179c498a authored by Steven Rostedt's avatar Steven Rostedt Committed by Steven Rostedt

function-graph: only allocate init tasks if it was not already done

When the function graph tracer is enabled, it calls the initialization
needed for the init tasks that would be called on all created tasks.

The problem is that this is called every time the function graph tracer
is enabled, and the ret_stack is allocated for the idle tasks each time.
Thus, the old ret_stack is lost and a memory leak is created.

This is also dangerous because if an interrupt happened on another CPU
with the init task and the ret_stack is replaced, we then lose all the
return pointers for the interrupt, and a crash would take place.

[ Impact: fix memory leak and possible crash due to race ]
Signed-off-by: default avatarSteven Rostedt <rostedt@goodmis.org>
parent 88fc86c2
...@@ -2643,8 +2643,10 @@ static int start_graph_tracing(void) ...@@ -2643,8 +2643,10 @@ static int start_graph_tracing(void)
return -ENOMEM; return -ENOMEM;
/* The cpu_boot init_task->ret_stack will never be freed */ /* The cpu_boot init_task->ret_stack will never be freed */
for_each_online_cpu(cpu) for_each_online_cpu(cpu) {
if (!idle_task(cpu)->ret_stack)
ftrace_graph_init_task(idle_task(cpu)); ftrace_graph_init_task(idle_task(cpu));
}
do { do {
ret = alloc_retstack_tasklist(ret_stack_list); ret = alloc_retstack_tasklist(ret_stack_list);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment