From: Robert Richter <robert.richter@amd.com>
To: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Peter Zijlstra <peterz@infradead.org>,
Ingo Molnar <mingo@elte.hu>,
Stephane Eranian <eranian@google.com>,
LKML <linux-kernel@vger.kernel.org>,
Lin Ming <ming.m.lin@intel.com>
Subject: [PATCH 1/4] perf tool: Parse general/raw events from sysfs
Date: Thu, 15 Dec 2011 18:23:41 +0100 [thread overview]
Message-ID: <1323969824-9711-2-git-send-email-robert.richter@amd.com> (raw)
In-Reply-To: <1323969824-9711-1-git-send-email-robert.richter@amd.com>
From: Lin Ming <ming.m.lin@intel.com>
PMU can export general events to sysfs, for example,
/sys/bus/event_source/devices/uncore/events
└── cycle
Then specify the event as <pmu>:<event>,
$ sudo perf stat -a -C 0 -e uncore:cycle
^C
Performance counter stats for 'CPU 0':
56,547,314 uncore:cycle
Raw event can be specified as <pmu>:rXXXX
$ sudo perf stat -a -C 0 -e uncore:r0101
^C
Performance counter stats for 'CPU 0':
8,504 uncore:r0101
Signed-off-by: Lin Ming <ming.m.lin@intel.com>
---
tools/perf/util/parse-events.c | 84 +++++++++++++++++++++++++++++++++++++++-
1 files changed, 82 insertions(+), 2 deletions(-)
diff --git a/tools/perf/util/parse-events.c b/tools/perf/util/parse-events.c
index 586ab3f..4ce9404 100644
--- a/tools/perf/util/parse-events.c
+++ b/tools/perf/util/parse-events.c
@@ -685,7 +685,7 @@ parse_symbolic_event(const char **strp, struct perf_event_attr *attr)
}
static enum event_result
-parse_raw_event(const char **strp, struct perf_event_attr *attr)
+parse_raw_config(const char **strp, struct perf_event_attr *attr)
{
const char *str = *strp;
u64 config;
@@ -700,7 +700,6 @@ parse_raw_event(const char **strp, struct perf_event_attr *attr)
return EVT_FAILED;
*strp = end;
- attr->type = PERF_TYPE_RAW;
attr->config = config;
return EVT_HANDLED;
}
@@ -708,6 +707,83 @@ parse_raw_event(const char **strp, struct perf_event_attr *attr)
}
static enum event_result
+parse_raw_event(const char **strp, struct perf_event_attr *attr)
+{
+ if (parse_raw_config(strp, attr) != EVT_HANDLED)
+ return EVT_FAILED;
+
+ attr->type = PERF_TYPE_RAW;
+ return EVT_HANDLED;
+}
+
+#define EVENT_SOURCE_DIR "/sys/bus/event_source/devices"
+
+static u64 read_sysfs_entry(const char *path)
+{
+ char buf[19];
+ int fd;
+
+ fd = open(path, O_RDONLY);
+ if (fd < 0)
+ return -1;
+
+ if (read(fd, buf, sizeof(buf)) < 0) {
+ close(fd);
+ return -1;
+ }
+
+ close(fd);
+ return atoll(buf);
+}
+
+static u64 get_pmu_type(const char *pmu_name)
+{
+ char evt_path[MAXPATHLEN];
+
+ snprintf(evt_path, MAXPATHLEN, "%s/%s/type", EVENT_SOURCE_DIR,
+ pmu_name);
+
+ return read_sysfs_entry(evt_path);
+}
+
+static u64 get_pmu_event_config(const char *pmu_name, const char *evt_name)
+{
+ char evt_path[MAXPATHLEN];
+
+ snprintf(evt_path, MAXPATHLEN, "%s/%s/events/%s", EVENT_SOURCE_DIR,
+ pmu_name, evt_name);
+
+ return read_sysfs_entry(evt_path);
+}
+
+static enum event_result
+parse_sysfs_event(const char **strp, struct perf_event_attr *attr)
+{
+ char *pmu_name, *evt_name;
+ u64 type, config;
+
+ pmu_name = strchr(*strp, ':');
+ if (!pmu_name)
+ return EVT_FAILED;
+ pmu_name = strndup(*strp, pmu_name - *strp);
+ type = get_pmu_type(pmu_name);
+ if ((int)type < 0)
+ return EVT_FAILED;
+ attr->type = type;
+
+ evt_name = strchr(*strp, ':') + 1;
+ config = get_pmu_event_config(pmu_name, evt_name);
+ *strp += strlen(pmu_name) + 1; /* + 1 for the ':' */
+
+ if ((int)config < 0)
+ return parse_raw_config(strp, attr);
+
+ attr->config = config;
+ *strp += strlen(evt_name);
+ return EVT_HANDLED;
+}
+
+static enum event_result
parse_numeric_event(const char **strp, struct perf_event_attr *attr)
{
const char *str = *strp;
@@ -788,6 +864,10 @@ parse_event_symbols(struct perf_evlist *evlist, const char **str,
{
enum event_result ret;
+ ret = parse_sysfs_event(str, attr);
+ if (ret != EVT_FAILED)
+ goto modifier;
+
ret = parse_tracepoint_event(evlist, str, attr);
if (ret != EVT_FAILED)
goto modifier;
--
1.7.7
next prev parent reply other threads:[~2011-12-15 17:24 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-12-15 17:23 [PATCH 0/4] perf tools: Add support for IBS Robert Richter
2011-12-15 17:23 ` Robert Richter [this message]
2011-12-21 16:52 ` [PATCH 1/4] perf tool: Parse general/raw events from sysfs Robert Richter
2012-01-02 11:07 ` Stephane Eranian
2011-12-15 17:23 ` [PATCH 2/4] perf tools: Add pmu mappings to header information Robert Richter
2011-12-15 17:23 ` [PATCH 3/4] perf script: Add generic perl handler to process events Robert Richter
2011-12-29 20:56 ` [tip:perf/core] " tip-bot for Robert Richter
2011-12-15 17:23 ` [PATCH 4/4] perf script: Add script to collect and display IBS samples Robert Richter
2011-12-15 19:19 ` David Ahern
2011-12-15 23:47 ` Robert Richter
2011-12-23 10:33 ` Ingo Molnar
2011-12-23 11:19 ` Robert Richter
2011-12-23 13:53 ` Ingo Molnar
2011-12-23 14:14 ` Peter Zijlstra
2011-12-23 14:40 ` Ingo Molnar
2011-12-23 16:17 ` Robert Richter
2011-12-23 16:39 ` Ingo Molnar
2011-12-23 16:50 ` Robert Richter
2011-12-30 9:55 ` Ingo Molnar
2012-02-02 11:21 ` Robert Richter
2012-03-08 12:19 ` Ingo Molnar
2012-03-09 11:41 ` Robert Richter
2012-03-21 18:13 ` Robert Richter
2012-03-22 7:51 ` Ingo Molnar
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1323969824-9711-2-git-send-email-robert.richter@amd.com \
--to=robert.richter@amd.com \
--cc=acme@redhat.com \
--cc=eranian@google.com \
--cc=linux-kernel@vger.kernel.org \
--cc=ming.m.lin@intel.com \
--cc=mingo@elte.hu \
--cc=peterz@infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.