mirror of
https://github.com/torvalds/linux.git
synced 2024-11-13 15:41:39 +00:00
perf tools: Add stat events fprintf functions
Introducing the following functions to display the stat events for raw dump. perf_event__fprintf_stat perf_event__fprintf_stat_round perf_event__fprintf_stat_config Signed-off-by: Jiri Olsa <jolsa@kernel.org> Tested-by: Kan Liang <kan.liang@intel.com> Cc: David Ahern <dsahern@gmail.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Link: http://lkml.kernel.org/r/1445784728-21732-20-git-send-email-jolsa@kernel.org [ s/stat/st/g and s/round/rd/g parameters to fix 'already defined' build error with older distros (e.g. RHEL6.7) ] Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
d4c2259195
commit
e08a4564e2
@ -364,3 +364,42 @@ int perf_event__process_stat_event(struct perf_tool *tool __maybe_unused,
|
|||||||
counter->supported = true;
|
counter->supported = true;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_t perf_event__fprintf_stat(union perf_event *event, FILE *fp)
|
||||||
|
{
|
||||||
|
struct stat_event *st = (struct stat_event *) event;
|
||||||
|
size_t ret;
|
||||||
|
|
||||||
|
ret = fprintf(fp, "\n... id %" PRIu64 ", cpu %d, thread %d\n",
|
||||||
|
st->id, st->cpu, st->thread);
|
||||||
|
ret += fprintf(fp, "... value %" PRIu64 ", enabled %" PRIu64 ", running %" PRIu64 "\n",
|
||||||
|
st->val, st->ena, st->run);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t perf_event__fprintf_stat_round(union perf_event *event, FILE *fp)
|
||||||
|
{
|
||||||
|
struct stat_round_event *rd = (struct stat_round_event *)event;
|
||||||
|
size_t ret;
|
||||||
|
|
||||||
|
ret = fprintf(fp, "\n... time %" PRIu64 ", type %s\n", rd->time,
|
||||||
|
rd->type == PERF_STAT_ROUND_TYPE__FINAL ? "FINAL" : "INTERVAL");
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t perf_event__fprintf_stat_config(union perf_event *event, FILE *fp)
|
||||||
|
{
|
||||||
|
struct perf_stat_config sc;
|
||||||
|
size_t ret;
|
||||||
|
|
||||||
|
perf_event__read_stat_config(&sc, &event->stat_config);
|
||||||
|
|
||||||
|
ret = fprintf(fp, "\n");
|
||||||
|
ret += fprintf(fp, "... aggr_mode %d\n", sc.aggr_mode);
|
||||||
|
ret += fprintf(fp, "... scale %d\n", sc.scale);
|
||||||
|
ret += fprintf(fp, "... interval %u\n", sc.interval);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
@ -96,4 +96,8 @@ struct perf_session;
|
|||||||
int perf_event__process_stat_event(struct perf_tool *tool,
|
int perf_event__process_stat_event(struct perf_tool *tool,
|
||||||
union perf_event *event,
|
union perf_event *event,
|
||||||
struct perf_session *session);
|
struct perf_session *session);
|
||||||
|
|
||||||
|
size_t perf_event__fprintf_stat(union perf_event *event, FILE *fp);
|
||||||
|
size_t perf_event__fprintf_stat_round(union perf_event *event, FILE *fp);
|
||||||
|
size_t perf_event__fprintf_stat_config(union perf_event *event, FILE *fp);
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user