diff options
author | Adrian Hunter <adrian.hunter@intel.com> | 2014-07-23 15:19:57 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2014-07-23 16:00:46 -0400 |
commit | 6f917c70998d22bda6d06cb168665068c6066cd4 (patch) | |
tree | e95c8197436a12a45f7a02dd40cfcfa755d51a08 /tools/perf | |
parent | 2a03068c5cfa104768703cbefa2e23a6353f8de5 (diff) |
perf session: Add ability to 'skip' a non-piped event stream
A piped event stream may contain arbitary sized tracepoint information
following a PERF_RECORD_HEADER_TRACING_DATA event. The position in the
stream has to be 'skipped' to match the start of the next event.
Provide the same ability to a non-piped event stream to allow for
Instruction Trace data that may also be in a non-piped event stream.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung@gmail.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/r/1406143198-20732-1-git-send-email-adrian.hunter@intel.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf')
-rw-r--r-- | tools/perf/util/session.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index eac14ce0ae8d..f4399b2087c4 100644 --- a/tools/perf/util/session.c +++ b/tools/perf/util/session.c | |||
@@ -1284,6 +1284,7 @@ int __perf_session__process_events(struct perf_session *session, | |||
1284 | union perf_event *event; | 1284 | union perf_event *event; |
1285 | uint32_t size; | 1285 | uint32_t size; |
1286 | struct ui_progress prog; | 1286 | struct ui_progress prog; |
1287 | int skip; | ||
1287 | 1288 | ||
1288 | perf_tool__fill_defaults(tool); | 1289 | perf_tool__fill_defaults(tool); |
1289 | 1290 | ||
@@ -1344,7 +1345,8 @@ more: | |||
1344 | size = event->header.size; | 1345 | size = event->header.size; |
1345 | 1346 | ||
1346 | if (size < sizeof(struct perf_event_header) || | 1347 | if (size < sizeof(struct perf_event_header) || |
1347 | perf_session__process_event(session, event, tool, file_pos) < 0) { | 1348 | (skip = perf_session__process_event(session, event, tool, file_pos)) |
1349 | < 0) { | ||
1348 | pr_err("%#" PRIx64 " [%#x]: failed to process type: %d\n", | 1350 | pr_err("%#" PRIx64 " [%#x]: failed to process type: %d\n", |
1349 | file_offset + head, event->header.size, | 1351 | file_offset + head, event->header.size, |
1350 | event->header.type); | 1352 | event->header.type); |
@@ -1352,6 +1354,9 @@ more: | |||
1352 | goto out_err; | 1354 | goto out_err; |
1353 | } | 1355 | } |
1354 | 1356 | ||
1357 | if (skip) | ||
1358 | size += skip; | ||
1359 | |||
1355 | head += size; | 1360 | head += size; |
1356 | file_pos += size; | 1361 | file_pos += size; |
1357 | 1362 | ||