Message ID | 173617940696.1366315.9993763922773507683.stgit@devnote2 (mailing list archive) |
---|---|
State | Superseded |
Headers | show |
Series | tracing/probes: Cleanup with guard and __free for kprobe and fprobe | expand |
On Tue, 7 Jan 2025 01:03:27 +0900 "Masami Hiramatsu (Google)" <mhiramat@kernel.org> wrote: > From: Masami Hiramatsu (Google) <mhiramat@kernel.org> > > Use __free() for the args allocated by argv_split() in dynevent. Lol, the same one has already done by Steve. https://lore.kernel.org/linux-trace-kernel/20241220103313.4a74ec8e@gandalf.local.home/ Let me drop it. > > Signed-off-by: Masami Hiramatsu (Google) <mhiramat@kernel.org> > --- > Changes in v3: > - Rename to __free(argv_free). > Changes in v2: > - Rebased on probes/for-next, which reverts previous dynevent guard patch. > --- > kernel/trace/trace_dynevent.c | 23 ++++++++--------------- > 1 file changed, 8 insertions(+), 15 deletions(-) > > diff --git a/kernel/trace/trace_dynevent.c b/kernel/trace/trace_dynevent.c > index 4376887e0d8a..78242ea6fb30 100644 > --- a/kernel/trace/trace_dynevent.c > +++ b/kernel/trace/trace_dynevent.c > @@ -74,24 +74,20 @@ int dyn_event_release(const char *raw_command, struct dyn_event_operations *type > struct dyn_event *pos, *n; > char *system = NULL, *event, *p; > int argc, ret = -ENOENT; > - char **argv; > + char **argv __free(argv_free) = NULL; > > argv = argv_split(GFP_KERNEL, raw_command, &argc); > if (!argv) > return -ENOMEM; > > if (argv[0][0] == '-') { > - if (argv[0][1] != ':') { > - ret = -EINVAL; > - goto out; > - } > + if (argv[0][1] != ':') > + return -EINVAL; > event = &argv[0][2]; > } else { > event = strchr(argv[0], ':'); > - if (!event) { > - ret = -EINVAL; > - goto out; > - } > + if (!event) > + return -EINVAL; > event++; > } > > @@ -101,10 +97,8 @@ int dyn_event_release(const char *raw_command, struct dyn_event_operations *type > event = p + 1; > *p = '\0'; > } > - if (!system && event[0] == '\0') { > - ret = -EINVAL; > - goto out; > - } > + if (!system && event[0] == '\0') > + return -EINVAL; > > mutex_lock(&event_mutex); > for_each_dyn_event_safe(pos, n) { > @@ -120,8 +114,7 @@ int dyn_event_release(const char *raw_command, struct dyn_event_operations *type > } > tracing_reset_all_online_cpus(); > mutex_unlock(&event_mutex); > -out: > - argv_free(argv); > + > return ret; > } > >
diff --git a/kernel/trace/trace_dynevent.c b/kernel/trace/trace_dynevent.c index 4376887e0d8a..78242ea6fb30 100644 --- a/kernel/trace/trace_dynevent.c +++ b/kernel/trace/trace_dynevent.c @@ -74,24 +74,20 @@ int dyn_event_release(const char *raw_command, struct dyn_event_operations *type struct dyn_event *pos, *n; char *system = NULL, *event, *p; int argc, ret = -ENOENT; - char **argv; + char **argv __free(argv_free) = NULL; argv = argv_split(GFP_KERNEL, raw_command, &argc); if (!argv) return -ENOMEM; if (argv[0][0] == '-') { - if (argv[0][1] != ':') { - ret = -EINVAL; - goto out; - } + if (argv[0][1] != ':') + return -EINVAL; event = &argv[0][2]; } else { event = strchr(argv[0], ':'); - if (!event) { - ret = -EINVAL; - goto out; - } + if (!event) + return -EINVAL; event++; } @@ -101,10 +97,8 @@ int dyn_event_release(const char *raw_command, struct dyn_event_operations *type event = p + 1; *p = '\0'; } - if (!system && event[0] == '\0') { - ret = -EINVAL; - goto out; - } + if (!system && event[0] == '\0') + return -EINVAL; mutex_lock(&event_mutex); for_each_dyn_event_safe(pos, n) { @@ -120,8 +114,7 @@ int dyn_event_release(const char *raw_command, struct dyn_event_operations *type } tracing_reset_all_online_cpus(); mutex_unlock(&event_mutex); -out: - argv_free(argv); + return ret; }