diff options
author | Andi Kleen <ak@linux.intel.com> | 2014-11-12 21:05:22 -0500 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2014-12-01 18:00:31 -0500 |
commit | fa94c36c29ed8bb4749b5fd7ea51a593f673dcef (patch) | |
tree | c8e546dc28a20521f02d63e420bd858d98965b52 /tools | |
parent | 8b7bad58efb7e3aaff60f7c1fa4361fb8c23181d (diff) |
perf report: Add --branch-history option
Add a --branch-history option to perf report that changes all the
settings necessary for using the branches in callstacks.
This is just a short cut to make this nicer to use, it does not enable
any functionality by itself.
v2: Change sort order. Rename option to --branch-history to
be less confusing.
v3: Updates
v4: Fix conflict with newer perf base
v5: Port to latest tip
v6: Add more comments. Remove CCKEY_ADDRESS setting. Remove
unnecessary branch_mode setting. Use a boolean.
Signed-off-by: Andi Kleen <ak@linux.intel.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Link: http://lkml.kernel.org/r/1415844328-4884-5-git-send-email-andi@firstfloor.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools')
-rw-r--r-- | tools/perf/Documentation/perf-report.txt | 5 | ||||
-rw-r--r-- | tools/perf/builtin-report.c | 26 |
2 files changed, 27 insertions, 4 deletions
diff --git a/tools/perf/Documentation/perf-report.txt b/tools/perf/Documentation/perf-report.txt index 22706beffabc..dd7cccdde498 100644 --- a/tools/perf/Documentation/perf-report.txt +++ b/tools/perf/Documentation/perf-report.txt | |||
@@ -271,6 +271,11 @@ OPTIONS | |||
271 | branch stacks and it will automatically switch to the branch view mode, | 271 | branch stacks and it will automatically switch to the branch view mode, |
272 | unless --no-branch-stack is used. | 272 | unless --no-branch-stack is used. |
273 | 273 | ||
274 | --branch-history:: | ||
275 | Add the addresses of sampled taken branches to the callstack. | ||
276 | This allows to examine the path the program took to each sample. | ||
277 | The data collection must have used -b (or -j) and -g. | ||
278 | |||
274 | --objdump=<path>:: | 279 | --objdump=<path>:: |
275 | Path to objdump binary. | 280 | Path to objdump binary. |
276 | 281 | ||
diff --git a/tools/perf/builtin-report.c b/tools/perf/builtin-report.c index 410d44fac64f..fb272ff435c9 100644 --- a/tools/perf/builtin-report.c +++ b/tools/perf/builtin-report.c | |||
@@ -226,8 +226,9 @@ static int report__setup_sample_type(struct report *rep) | |||
226 | return -EINVAL; | 226 | return -EINVAL; |
227 | } | 227 | } |
228 | if (symbol_conf.use_callchain) { | 228 | if (symbol_conf.use_callchain) { |
229 | ui__error("Selected -g but no callchain data. Did " | 229 | ui__error("Selected -g or --branch-history but no " |
230 | "you call 'perf record' without -g?\n"); | 230 | "callchain data. Did\n" |
231 | "you call 'perf record' without -g?\n"); | ||
231 | return -1; | 232 | return -1; |
232 | } | 233 | } |
233 | } else if (!rep->dont_use_callchains && | 234 | } else if (!rep->dont_use_callchains && |
@@ -575,6 +576,7 @@ int cmd_report(int argc, const char **argv, const char *prefix __maybe_unused) | |||
575 | struct stat st; | 576 | struct stat st; |
576 | bool has_br_stack = false; | 577 | bool has_br_stack = false; |
577 | int branch_mode = -1; | 578 | int branch_mode = -1; |
579 | bool branch_call_mode = false; | ||
578 | char callchain_default_opt[] = "fractal,0.5,callee"; | 580 | char callchain_default_opt[] = "fractal,0.5,callee"; |
579 | const char * const report_usage[] = { | 581 | const char * const report_usage[] = { |
580 | "perf report [<options>]", | 582 | "perf report [<options>]", |
@@ -684,7 +686,10 @@ int cmd_report(int argc, const char **argv, const char *prefix __maybe_unused) | |||
684 | OPT_BOOLEAN(0, "group", &symbol_conf.event_group, | 686 | OPT_BOOLEAN(0, "group", &symbol_conf.event_group, |
685 | "Show event group information together"), | 687 | "Show event group information together"), |
686 | OPT_CALLBACK_NOOPT('b', "branch-stack", &branch_mode, "", | 688 | OPT_CALLBACK_NOOPT('b', "branch-stack", &branch_mode, "", |
687 | "use branch records for histogram filling", parse_branch_mode), | 689 | "use branch records for per branch histogram filling", |
690 | parse_branch_mode), | ||
691 | OPT_BOOLEAN(0, "branch-history", &branch_call_mode, | ||
692 | "add last branch records to call history"), | ||
688 | OPT_STRING(0, "objdump", &objdump_path, "path", | 693 | OPT_STRING(0, "objdump", &objdump_path, "path", |
689 | "objdump binary to use for disassembly and annotations"), | 694 | "objdump binary to use for disassembly and annotations"), |
690 | OPT_BOOLEAN(0, "demangle", &symbol_conf.demangle, | 695 | OPT_BOOLEAN(0, "demangle", &symbol_conf.demangle, |
@@ -745,10 +750,23 @@ repeat: | |||
745 | has_br_stack = perf_header__has_feat(&session->header, | 750 | has_br_stack = perf_header__has_feat(&session->header, |
746 | HEADER_BRANCH_STACK); | 751 | HEADER_BRANCH_STACK); |
747 | 752 | ||
748 | if ((branch_mode == -1 && has_br_stack) || branch_mode == 1) { | 753 | /* |
754 | * Branch mode is a tristate: | ||
755 | * -1 means default, so decide based on the file having branch data. | ||
756 | * 0/1 means the user chose a mode. | ||
757 | */ | ||
758 | if (((branch_mode == -1 && has_br_stack) || branch_mode == 1) && | ||
759 | branch_call_mode == -1) { | ||
749 | sort__mode = SORT_MODE__BRANCH; | 760 | sort__mode = SORT_MODE__BRANCH; |
750 | symbol_conf.cumulate_callchain = false; | 761 | symbol_conf.cumulate_callchain = false; |
751 | } | 762 | } |
763 | if (branch_call_mode) { | ||
764 | callchain_param.branch_callstack = 1; | ||
765 | symbol_conf.use_callchain = true; | ||
766 | callchain_register_param(&callchain_param); | ||
767 | if (sort_order == NULL) | ||
768 | sort_order = "srcline,symbol,dso"; | ||
769 | } | ||
752 | 770 | ||
753 | if (report.mem_mode) { | 771 | if (report.mem_mode) { |
754 | if (sort__mode == SORT_MODE__BRANCH) { | 772 | if (sort__mode == SORT_MODE__BRANCH) { |