tracing: Fix memory leak in create_filter()

The create_filter() calls create_filter_start() which allocates a
"parse_error" descriptor, but fails to call create_filter_finish() that
frees it.

The op_stack and inverts in predicate_parse() were also not freed.

Found by kmemleak detector.

Cc: stable@vger.kernel.org
Fixes: 80765597 ("tracing: Rewrite filter logic to be simpler and faster")
Reviewed-by: default avatarTom Zanussi <tom.zanussi@linux.intel.com>
Signed-off-by: default avatarSteven Rostedt (VMware) <rostedt@goodmis.org>
parent 1aed58e6
...@@ -570,11 +570,13 @@ predicate_parse(const char *str, int nr_parens, int nr_preds, ...@@ -570,11 +570,13 @@ predicate_parse(const char *str, int nr_parens, int nr_preds,
} }
} }
kfree(op_stack);
kfree(inverts);
return prog; return prog;
out_free: out_free:
kfree(op_stack); kfree(op_stack);
kfree(prog_stack);
kfree(inverts); kfree(inverts);
kfree(prog_stack);
return ERR_PTR(ret); return ERR_PTR(ret);
} }
...@@ -1718,6 +1720,7 @@ static int create_filter(struct trace_event_call *call, ...@@ -1718,6 +1720,7 @@ static int create_filter(struct trace_event_call *call,
err = process_preds(call, filter_string, *filterp, pe); err = process_preds(call, filter_string, *filterp, pe);
if (err && set_str) if (err && set_str)
append_filter_err(pe, *filterp); append_filter_err(pe, *filterp);
create_filter_finish(pe);
return err; return err;
} }
......
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