aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorAndi Kleen <ak@linux.intel.com>2014-11-12 21:05:22 -0500
committerArnaldo Carvalho de Melo <acme@redhat.com>2014-12-01 18:00:31 -0500
commitfa94c36c29ed8bb4749b5fd7ea51a593f673dcef (patch)
treec8e546dc28a20521f02d63e420bd858d98965b52 /tools
parent8b7bad58efb7e3aaff60f7c1fa4361fb8c23181d (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.txt5
-rw-r--r--tools/perf/builtin-report.c26
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) {