aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorYoshihiro YUNOMAE <yoshihiro.yunomae.ez@hitachi.com>2014-06-03 00:28:03 -0400
committerSteven Rostedt <rostedt@goodmis.org>2014-06-03 19:58:31 -0400
commit198376cd8877a612cc6494201b815c36d1e40391 (patch)
tree04f842baddd222fdaa5f0ca71b5c7a6b94a3496d /kernel
parent964f7b6b785651a75ef1cbad43a393ca52d4b4f7 (diff)
tracing: Eliminate double free on failure of allocation on boot up
If allocation of the max_buffer fails on boot up, the error path will free both per_cpu data structures from the buffers. With the new redesign of the code, those structures are freed if allocations failed. That is, the helper function that allocates the buffers will free the per cpu data on failure. No need to do it again. In fact, the second free will cause a bug as the code can not handle a double free. Link: http://lkml.kernel.org/p/20140603042803.27308.30956.stgit@yunodevel Signed-off-by: Yoshihiro YUNOMAE <yoshihiro.yunomae.ez@hitachi.com> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/trace/trace.c4
1 files changed, 0 insertions, 4 deletions
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index 626dbfde5d56..135af323608b 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -6671,10 +6671,6 @@ __init static int tracer_alloc_buffers(void)
6671out_free_temp_buffer: 6671out_free_temp_buffer:
6672 ring_buffer_free(temp_buffer); 6672 ring_buffer_free(temp_buffer);
6673out_free_cpumask: 6673out_free_cpumask:
6674 free_percpu(global_trace.trace_buffer.data);
6675#ifdef CONFIG_TRACER_MAX_TRACE
6676 free_percpu(global_trace.max_buffer.data);
6677#endif
6678 free_cpumask_var(global_trace.tracing_cpumask); 6674 free_cpumask_var(global_trace.tracing_cpumask);
6679out_free_buffer_mask: 6675out_free_buffer_mask:
6680 free_cpumask_var(tracing_buffer_mask); 6676 free_cpumask_var(tracing_buffer_mask);