Commit c5cb1836 authored by Xiao Guangrong's avatar Xiao Guangrong Committed by Ingo Molnar

tracing/filter: Remove preds from struct event_subsystem

No need to save preds to event_subsystem, because it's not used.
Signed-off-by: default avatarXiao Guangrong <xiaoguangrong@cn.fujitsu.com>
Acked-by: default avatarTom Zanussi <tzanussi@gmail.com>
Reviewed-by: default avatarLi Zefan <lizf@cn.fujitsu.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Steven Rostedt <rostedt@goodmis.org>
LKML-Reference: <4A55A83C.1030005@cn.fujitsu.com>
Signed-off-by: default avatarIngo Molnar <mingo@elte.hu>
parent ddc1637a
...@@ -420,17 +420,7 @@ EXPORT_SYMBOL_GPL(init_preds); ...@@ -420,17 +420,7 @@ EXPORT_SYMBOL_GPL(init_preds);
static void filter_free_subsystem_preds(struct event_subsystem *system) static void filter_free_subsystem_preds(struct event_subsystem *system)
{ {
struct event_filter *filter = system->filter;
struct ftrace_event_call *call; struct ftrace_event_call *call;
int i;
if (filter->n_preds) {
for (i = 0; i < filter->n_preds; i++)
filter_free_pred(filter->preds[i]);
kfree(filter->preds);
filter->preds = NULL;
filter->n_preds = 0;
}
list_for_each_entry(call, &ftrace_events, list) { list_for_each_entry(call, &ftrace_events, list) {
if (!call->define_fields) if (!call->define_fields)
...@@ -607,26 +597,9 @@ static int filter_add_subsystem_pred(struct filter_parse_state *ps, ...@@ -607,26 +597,9 @@ static int filter_add_subsystem_pred(struct filter_parse_state *ps,
struct filter_pred *pred, struct filter_pred *pred,
char *filter_string) char *filter_string)
{ {
struct event_filter *filter = system->filter;
struct ftrace_event_call *call; struct ftrace_event_call *call;
int err = 0; int err = 0;
if (!filter->preds) {
filter->preds = kzalloc(MAX_FILTER_PRED * sizeof(pred),
GFP_KERNEL);
if (!filter->preds)
return -ENOMEM;
}
if (filter->n_preds == MAX_FILTER_PRED) {
parse_error(ps, FILT_ERR_TOO_MANY_PREDS, 0);
return -ENOSPC;
}
filter->preds[filter->n_preds] = pred;
filter->n_preds++;
list_for_each_entry(call, &ftrace_events, list) { list_for_each_entry(call, &ftrace_events, list) {
if (!call->define_fields) if (!call->define_fields)
...@@ -1029,12 +1002,12 @@ static int replace_preds(struct event_subsystem *system, ...@@ -1029,12 +1002,12 @@ static int replace_preds(struct event_subsystem *system,
if (elt->op == OP_AND || elt->op == OP_OR) { if (elt->op == OP_AND || elt->op == OP_OR) {
pred = create_logical_pred(elt->op); pred = create_logical_pred(elt->op);
if (call) { if (call)
err = filter_add_pred(ps, call, pred); err = filter_add_pred(ps, call, pred);
filter_free_pred(pred); else
} else
err = filter_add_subsystem_pred(ps, system, err = filter_add_subsystem_pred(ps, system,
pred, filter_string); pred, filter_string);
filter_free_pred(pred);
if (err) if (err)
return err; return err;
...@@ -1048,12 +1021,12 @@ static int replace_preds(struct event_subsystem *system, ...@@ -1048,12 +1021,12 @@ static int replace_preds(struct event_subsystem *system,
} }
pred = create_pred(elt->op, operand1, operand2); pred = create_pred(elt->op, operand1, operand2);
if (call) { if (call)
err = filter_add_pred(ps, call, pred); err = filter_add_pred(ps, call, pred);
filter_free_pred(pred); else
} else
err = filter_add_subsystem_pred(ps, system, pred, err = filter_add_subsystem_pred(ps, system, pred,
filter_string); filter_string);
filter_free_pred(pred);
if (err) if (err)
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