From 57f0f512b273f60d52568b8c6b77e17f5636edc0 Mon Sep 17 00:00:00 2001 From: André Fabian Silva Delgado Date: Wed, 5 Aug 2015 17:04:01 -0300 Subject: Initial import --- tools/perf/builtin-evlist.c | 69 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 tools/perf/builtin-evlist.c (limited to 'tools/perf/builtin-evlist.c') diff --git a/tools/perf/builtin-evlist.c b/tools/perf/builtin-evlist.c new file mode 100644 index 000000000..695ec5a50 --- /dev/null +++ b/tools/perf/builtin-evlist.c @@ -0,0 +1,69 @@ +/* + * Builtin evlist command: Show the list of event selectors present + * in a perf.data file. + */ +#include "builtin.h" + +#include "util/util.h" + +#include + +#include "perf.h" +#include "util/evlist.h" +#include "util/evsel.h" +#include "util/parse-events.h" +#include "util/parse-options.h" +#include "util/session.h" +#include "util/data.h" +#include "util/debug.h" + +static int __cmd_evlist(const char *file_name, struct perf_attr_details *details) +{ + struct perf_session *session; + struct perf_evsel *pos; + struct perf_data_file file = { + .path = file_name, + .mode = PERF_DATA_MODE_READ, + .force = details->force, + }; + + session = perf_session__new(&file, 0, NULL); + if (session == NULL) + return -1; + + evlist__for_each(session->evlist, pos) + perf_evsel__fprintf(pos, details, stdout); + + perf_session__delete(session); + return 0; +} + +int cmd_evlist(int argc, const char **argv, const char *prefix __maybe_unused) +{ + struct perf_attr_details details = { .verbose = false, }; + const struct option options[] = { + OPT_STRING('i', "input", &input_name, "file", "Input file name"), + OPT_BOOLEAN('F', "freq", &details.freq, "Show the sample frequency"), + OPT_BOOLEAN('v', "verbose", &details.verbose, + "Show all event attr details"), + OPT_BOOLEAN('g', "group", &details.event_group, + "Show event group information"), + OPT_BOOLEAN('f', "force", &details.force, "don't complain, do it"), + OPT_END() + }; + const char * const evlist_usage[] = { + "perf evlist []", + NULL + }; + + argc = parse_options(argc, argv, options, evlist_usage, 0); + if (argc) + usage_with_options(evlist_usage, options); + + if (details.event_group && (details.verbose || details.freq)) { + pr_err("--group option is not compatible with other options\n"); + usage_with_options(evlist_usage, options); + } + + return __cmd_evlist(input_name, &details); +} -- cgit v1.2.3-54-g00ecf