Commit 8829e56f authored by Arnaldo Carvalho de Melo's avatar Arnaldo Carvalho de Melo
Browse files

perf evswitch: Move switch logic to use in other tools

Now other tools that want switching can use an evswitch for that, just
set it up and add it to the PERF_RECORD_SAMPLE processing function.

Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Florian Weimer <fweimer@redhat.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: William Cohen <wcohen@redhat.com>
Link: https://lkml.kernel.org/n/tip-b1trj1q97qwfv251l66q3noj@git.kernel.org


Signed-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent d2360442
Loading
Loading
Loading
Loading
+2 −21
Original line number Diff line number Diff line
@@ -1807,28 +1807,9 @@ static void process_event(struct perf_script *script,
	if (!show_event(sample, evsel, thread, al))
		return;

	if (script->evswitch.on && script->evswitch.discarding) {
		if (script->evswitch.on != evsel)
	if (evswitch__discard(&script->evswitch, evsel))
		return;

		script->evswitch.discarding = false;

		if (!script->evswitch.show_on_off_events)
			return;

		goto print_it;
	}

	if (script->evswitch.off && !script->evswitch.discarding) {
		if (script->evswitch.off != evsel)
			goto print_it;

		script->evswitch.discarding = true;

		if (!script->evswitch.show_on_off_events)
			return;
	}
print_it:
	++es->samples;

	perf_sample__fprintf_start(sample, thread, evsel,
+1 −0
Original line number Diff line number Diff line
@@ -9,6 +9,7 @@ perf-y += event.o
perf-y += evlist.o
perf-y += evsel.o
perf-y += evsel_fprintf.o
perf-y += evswitch.o
perf-y += find_bit.o
perf-y += get_current_dir_name.o
perf-y += kallsyms.o
+31 −0
Original line number Diff line number Diff line
// SPDX-License-Identifier: GPL-2.0-only
// Copyright (C) 2019, Red Hat Inc, Arnaldo Carvalho de Melo <acme@redhat.com>

#include "evswitch.h"

bool evswitch__discard(struct evswitch *evswitch, struct evsel *evsel)
{
	if (evswitch->on && evswitch->discarding) {
		if (evswitch->on != evsel)
			return true;

		evswitch->discarding = false;

		if (!evswitch->show_on_off_events)
			return true;

		return false;
	}

	if (evswitch->off && !evswitch->discarding) {
		if (evswitch->off != evsel)
			return false;

		evswitch->discarding = true;

		if (!evswitch->show_on_off_events)
			return true;
	}

	return false;
}
+2 −0
Original line number Diff line number Diff line
@@ -13,4 +13,6 @@ struct evswitch {
	bool	     show_on_off_events;
};

bool evswitch__discard(struct evswitch *evswitch, struct evsel *evsel);

#endif /* __PERF_EVSWITCH_H */