tracing/eprobe: Fix to release eprobe when failed to add dyn_event

Fix eprobe event to unregister event call and release eprobe when it fails
to add dynamic event correctly.

Link: https://lore.kernel.org/all/173289886698.73724.1959899350183686006.stgit@devnote2/

Fixes: 7491e2c442 ("tracing: Add a probe that attaches to trace events")
Signed-off-by: Masami Hiramatsu (Google) <mhiramat@kernel.org>
This commit is contained in:
Masami Hiramatsu (Google) 2024-11-30 01:47:47 +09:00
parent 40384c840e
commit 494b332064

View File

@ -963,6 +963,11 @@ static int __trace_eprobe_create(int argc, const char *argv[])
goto error; goto error;
} }
ret = dyn_event_add(&ep->devent, &ep->tp.event->call); ret = dyn_event_add(&ep->devent, &ep->tp.event->call);
if (ret < 0) {
trace_probe_unregister_event_call(&ep->tp);
mutex_unlock(&event_mutex);
goto error;
}
mutex_unlock(&event_mutex); mutex_unlock(&event_mutex);
return ret; return ret;
parse_error: parse_error: