Commit 609e85a7 authored by Alexander Z Lam's avatar Alexander Z Lam Committed by Steven Rostedt

tracing: Fix error handling to ensure instances can always be removed

Remove debugfs directories for tracing instances during creation if an error
occurs causing the trace_array for that instance to not be added to
ftrace_trace_arrays. If the directory continues to exist after the error, it
cannot be removed because the respective trace_array is not in
ftrace_trace_arrays.

Link: http://lkml.kernel.org/r/1373502874-1706-2-git-send-email-azl@google.com

Cc: stable@vger.kernel.org # 3.10
Cc: Vaibhav Nagarnaik <vnagarnaik@google.com>
Cc: David Sharp <dhsharp@google.com>
Cc: Alexander Z Lam <lambchop468@gmail.com>
Signed-off-by: default avatarAlexander Z Lam <azl@google.com>
Signed-off-by: default avatarSteven Rostedt <rostedt@goodmis.org>
parent a232e270
...@@ -5973,8 +5973,10 @@ static int new_instance_create(const char *name) ...@@ -5973,8 +5973,10 @@ static int new_instance_create(const char *name)
goto out_free_tr; goto out_free_tr;
ret = event_trace_add_tracer(tr->dir, tr); ret = event_trace_add_tracer(tr->dir, tr);
if (ret) if (ret) {
debugfs_remove_recursive(tr->dir);
goto out_free_tr; goto out_free_tr;
}
init_tracer_debugfs(tr, tr->dir); init_tracer_debugfs(tr, tr->dir);
......
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