mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
perf script: Add period data column
Adding period data column to be displayed in perf script. It's possible to get period values using -f option, like: $ perf script -f comm,tid,time,period,ip,sym,dso :26019 26019 52414.329088: 3707 ffffffff8105443a native_write_msr_safe ([kernel.kallsyms]) :26019 26019 52414.329088: 44 ffffffff8105443a native_write_msr_safe ([kernel.kallsyms]) :26019 26019 52414.329093: 1987 ffffffff8105443a native_write_msr_safe ([kernel.kallsyms]) :26019 26019 52414.329093: 6 ffffffff8105443a native_write_msr_safe ([kernel.kallsyms]) ls 26019 52414.329442: 537558 3407c0639c _dl_map_object_from_fd (/usr/lib64/ld-2.17.so) ls 26019 52414.329442: 2099 3407c0639c _dl_map_object_from_fd (/usr/lib64/ld-2.17.so) ls 26019 52414.330181: 1242100 34080917bb get_next_seq (/usr/lib64/libc-2.17.so) ls 26019 52414.330181: 3774 34080917bb get_next_seq (/usr/lib64/libc-2.17.so) ls 26019 52414.331427: 1083662 ffffffff810c7dc2 update_curr ([kernel.kallsyms]) ls 26019 52414.331427: 360 ffffffff810c7dc2 update_curr ([kernel.kallsyms]) Signed-off-by: Jiri Olsa <jolsa@kernel.org> Acked-by: David Ahern <dsahern@gmail.com> Cc: "Jen-Cheng(Tommy) Huang" <tommy24@gatech.edu> Cc: Andi Kleen <andi@firstfloor.org> Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com> Cc: David Ahern <dsahern@gmail.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: Jen-Cheng(Tommy) Huang <tommy24@gatech.edu> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Stephane Eranian <eranian@google.com> Link: http://lkml.kernel.org/r/1408977943-16594-9-git-send-email-jolsa@kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
f14d570785
commit
535aeaae7d
@ -115,7 +115,7 @@ OPTIONS
|
|||||||
-f::
|
-f::
|
||||||
--fields::
|
--fields::
|
||||||
Comma separated list of fields to print. Options are:
|
Comma separated list of fields to print. Options are:
|
||||||
comm, tid, pid, time, cpu, event, trace, ip, sym, dso, addr, symoff, srcline.
|
comm, tid, pid, time, cpu, event, trace, ip, sym, dso, addr, symoff, srcline, period.
|
||||||
Field list can be prepended with the type, trace, sw or hw,
|
Field list can be prepended with the type, trace, sw or hw,
|
||||||
to indicate to which event type the field list applies.
|
to indicate to which event type the field list applies.
|
||||||
e.g., -f sw:comm,tid,time,ip,sym and -f trace:time,cpu,trace
|
e.g., -f sw:comm,tid,time,ip,sym and -f trace:time,cpu,trace
|
||||||
|
@ -44,6 +44,7 @@ enum perf_output_field {
|
|||||||
PERF_OUTPUT_ADDR = 1U << 10,
|
PERF_OUTPUT_ADDR = 1U << 10,
|
||||||
PERF_OUTPUT_SYMOFFSET = 1U << 11,
|
PERF_OUTPUT_SYMOFFSET = 1U << 11,
|
||||||
PERF_OUTPUT_SRCLINE = 1U << 12,
|
PERF_OUTPUT_SRCLINE = 1U << 12,
|
||||||
|
PERF_OUTPUT_PERIOD = 1U << 13,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct output_option {
|
struct output_option {
|
||||||
@ -63,6 +64,7 @@ struct output_option {
|
|||||||
{.str = "addr", .field = PERF_OUTPUT_ADDR},
|
{.str = "addr", .field = PERF_OUTPUT_ADDR},
|
||||||
{.str = "symoff", .field = PERF_OUTPUT_SYMOFFSET},
|
{.str = "symoff", .field = PERF_OUTPUT_SYMOFFSET},
|
||||||
{.str = "srcline", .field = PERF_OUTPUT_SRCLINE},
|
{.str = "srcline", .field = PERF_OUTPUT_SRCLINE},
|
||||||
|
{.str = "period", .field = PERF_OUTPUT_PERIOD},
|
||||||
};
|
};
|
||||||
|
|
||||||
/* default set to maintain compatibility with current format */
|
/* default set to maintain compatibility with current format */
|
||||||
@ -229,6 +231,11 @@ static int perf_evsel__check_attr(struct perf_evsel *evsel,
|
|||||||
PERF_OUTPUT_CPU))
|
PERF_OUTPUT_CPU))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
|
if (PRINT_FIELD(PERIOD) &&
|
||||||
|
perf_evsel__check_stype(evsel, PERF_SAMPLE_PERIOD, "PERIOD",
|
||||||
|
PERF_OUTPUT_PERIOD))
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -448,6 +455,9 @@ static void process_event(union perf_event *event, struct perf_sample *sample,
|
|||||||
|
|
||||||
print_sample_start(sample, thread, evsel);
|
print_sample_start(sample, thread, evsel);
|
||||||
|
|
||||||
|
if (PRINT_FIELD(PERIOD))
|
||||||
|
printf("%10" PRIu64 " ", sample->period);
|
||||||
|
|
||||||
if (PRINT_FIELD(EVNAME)) {
|
if (PRINT_FIELD(EVNAME)) {
|
||||||
const char *evname = perf_evsel__name(evsel);
|
const char *evname = perf_evsel__name(evsel);
|
||||||
printf("%s: ", evname ? evname : "[unknown]");
|
printf("%s: ", evname ? evname : "[unknown]");
|
||||||
@ -1543,7 +1553,7 @@ int cmd_script(int argc, const char **argv, const char *prefix __maybe_unused)
|
|||||||
"comma separated output fields prepend with 'type:'. "
|
"comma separated output fields prepend with 'type:'. "
|
||||||
"Valid types: hw,sw,trace,raw. "
|
"Valid types: hw,sw,trace,raw. "
|
||||||
"Fields: comm,tid,pid,time,cpu,event,trace,ip,sym,dso,"
|
"Fields: comm,tid,pid,time,cpu,event,trace,ip,sym,dso,"
|
||||||
"addr,symoff", parse_output_fields),
|
"addr,symoff,period", parse_output_fields),
|
||||||
OPT_BOOLEAN('a', "all-cpus", &system_wide,
|
OPT_BOOLEAN('a', "all-cpus", &system_wide,
|
||||||
"system-wide collection from all CPUs"),
|
"system-wide collection from all CPUs"),
|
||||||
OPT_STRING('S', "symbols", &symbol_conf.sym_list_str, "symbol[,symbol...]",
|
OPT_STRING('S', "symbols", &symbol_conf.sym_list_str, "symbol[,symbol...]",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user