From: Lai Jiangshan Date: Wed, 25 Nov 2009 08:32:21 +0000 (+0800) Subject: trace_kprobes: Fix memory leak X-Git-Tag: upstream/snapshot3+hdmi~16109^2~167 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=abab9d37d2a826fcf588c5f30152dbe05c40111c;p=platform%2Fadaptation%2Frenesas_rcar%2Frenesas_kernel.git trace_kprobes: Fix memory leak tp->nr_args is not set before we "goto error", it causes memory leak for free_trace_probe() use tp->nr_args to free memory of args. Signed-off-by: Lai Jiangshan Acked-by: Masami Hiramatsu Cc: Steven Rostedt Cc: Frederic Weisbecker LKML-Reference: <4B0CEB95.2060107@cn.fujitsu.com> Signed-off-by: Ingo Molnar --- diff --git a/kernel/trace/trace_kprobe.c b/kernel/trace/trace_kprobe.c index 79ce6a2..82e8583 100644 --- a/kernel/trace/trace_kprobe.c +++ b/kernel/trace/trace_kprobe.c @@ -704,10 +704,12 @@ static int create_trace_probe(int argc, char **argv) ret = parse_probe_arg(arg, &tp->args[i].fetch, is_return); if (ret) { pr_info("Parse error at argument%d. (%d)\n", i, ret); + kfree(tp->args[i].name); goto error; } + + tp->nr_args++; } - tp->nr_args = i; ret = register_trace_probe(tp); if (ret)