mirror of
https://github.com/torvalds/linux.git
synced 2024-11-15 16:41:58 +00:00
perf auxtrace: Add support for dumping AUX area samples
Add support for dumping AUX area samples i.e. via the perf script/report -D (--dump-raw-trace) option. Committer notes: Add __maybe_unused to the two args for auxtrace__dump_auxtrace_sample() for when we don't HAVE_AUXTRACE_SUPPORT. Signed-off-by: Adrian Hunter <adrian.hunter@intel.com> Cc: Jiri Olsa <jolsa@redhat.com> Link: http://lore.kernel.org/lkml/20191115124225.5247-10-adrian.hunter@intel.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
ba2675bf15
commit
b04b8dd1e4
@ -2417,6 +2417,16 @@ int auxtrace__process_event(struct perf_session *session, union perf_event *even
|
||||
return session->auxtrace->process_event(session, event, sample, tool);
|
||||
}
|
||||
|
||||
void auxtrace__dump_auxtrace_sample(struct perf_session *session,
|
||||
struct perf_sample *sample)
|
||||
{
|
||||
if (!session->auxtrace || !session->auxtrace->dump_auxtrace_sample ||
|
||||
auxtrace__dont_decode(session))
|
||||
return;
|
||||
|
||||
session->auxtrace->dump_auxtrace_sample(session, sample);
|
||||
}
|
||||
|
||||
int auxtrace__flush_events(struct perf_session *session, struct perf_tool *tool)
|
||||
{
|
||||
if (!session->auxtrace)
|
||||
|
@ -141,6 +141,7 @@ struct auxtrace_index {
|
||||
* struct auxtrace - session callbacks to allow AUX area data decoding.
|
||||
* @process_event: lets the decoder see all session events
|
||||
* @process_auxtrace_event: process a PERF_RECORD_AUXTRACE event
|
||||
* @dump_auxtrace_sample: dump AUX area sample data
|
||||
* @flush_events: process any remaining data
|
||||
* @free_events: free resources associated with event processing
|
||||
* @free: free resources associated with the session
|
||||
@ -153,6 +154,8 @@ struct auxtrace {
|
||||
int (*process_auxtrace_event)(struct perf_session *session,
|
||||
union perf_event *event,
|
||||
struct perf_tool *tool);
|
||||
void (*dump_auxtrace_sample)(struct perf_session *session,
|
||||
struct perf_sample *sample);
|
||||
int (*flush_events)(struct perf_session *session,
|
||||
struct perf_tool *tool);
|
||||
void (*free_events)(struct perf_session *session);
|
||||
@ -555,6 +558,8 @@ int auxtrace_parse_filters(struct evlist *evlist);
|
||||
|
||||
int auxtrace__process_event(struct perf_session *session, union perf_event *event,
|
||||
struct perf_sample *sample, struct perf_tool *tool);
|
||||
void auxtrace__dump_auxtrace_sample(struct perf_session *session,
|
||||
struct perf_sample *sample);
|
||||
int auxtrace__flush_events(struct perf_session *session, struct perf_tool *tool);
|
||||
void auxtrace__free_events(struct perf_session *session);
|
||||
void auxtrace__free(struct perf_session *session);
|
||||
@ -674,6 +679,12 @@ int auxtrace__process_event(struct perf_session *session __maybe_unused,
|
||||
return 0;
|
||||
}
|
||||
|
||||
static inline
|
||||
void auxtrace__dump_auxtrace_sample(struct perf_session *session __maybe_unused,
|
||||
struct perf_sample *sample __maybe_unused)
|
||||
{
|
||||
}
|
||||
|
||||
static inline
|
||||
int auxtrace__flush_events(struct perf_session *session __maybe_unused,
|
||||
struct perf_tool *tool __maybe_unused)
|
||||
|
@ -1496,8 +1496,13 @@ static int perf_session__deliver_event(struct perf_session *session,
|
||||
if (ret > 0)
|
||||
return 0;
|
||||
|
||||
return machines__deliver_event(&session->machines, session->evlist,
|
||||
event, &sample, tool, file_offset);
|
||||
ret = machines__deliver_event(&session->machines, session->evlist,
|
||||
event, &sample, tool, file_offset);
|
||||
|
||||
if (dump_trace && sample.aux_sample.size)
|
||||
auxtrace__dump_auxtrace_sample(session, &sample);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static s64 perf_session__process_user_event(struct perf_session *session,
|
||||
|
Loading…
Reference in New Issue
Block a user