Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

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

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
Loading
Loading
Loading
Loading
+6 −33
Original line number Diff line number Diff line
@@ -420,17 +420,7 @@ EXPORT_SYMBOL_GPL(init_preds);

static void filter_free_subsystem_preds(struct event_subsystem *system)
{
	struct event_filter *filter = system->filter;
	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) {
		if (!call->define_fields)
@@ -607,26 +597,9 @@ static int filter_add_subsystem_pred(struct filter_parse_state *ps,
				     struct filter_pred *pred,
				     char *filter_string)
{
	struct event_filter *filter = system->filter;
	struct ftrace_event_call *call;
	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) {

		if (!call->define_fields)
@@ -1029,12 +1002,12 @@ static int replace_preds(struct event_subsystem *system,

		if (elt->op == OP_AND || elt->op == OP_OR) {
			pred = create_logical_pred(elt->op);
			if (call) {
			if (call)
				err = filter_add_pred(ps, call, pred);
				filter_free_pred(pred);
			} else
			else
				err = filter_add_subsystem_pred(ps, system,
							pred, filter_string);
			filter_free_pred(pred);
			if (err)
				return err;

@@ -1048,12 +1021,12 @@ static int replace_preds(struct event_subsystem *system,
		}

		pred = create_pred(elt->op, operand1, operand2);
		if (call) {
		if (call)
			err = filter_add_pred(ps, call, pred);
			filter_free_pred(pred);
		} else
		else
			err = filter_add_subsystem_pred(ps, system, pred,
							filter_string);
		filter_free_pred(pred);
		if (err)
			return err;