mirror of
https://github.com/team-infusion-developers/android_kernel_samsung_msm8976.git
synced 2024-11-01 10:33:27 +00:00
perf annotate: Make output more readable
This patch adds two new options to perf annotate: - --no-asm-raw : Do not display raw instruction encodings - --no-source : Do not interleave source code with assembly code We believe those options make the output of annotate more readable. Systematically displaying source can make it hard to follow code and especially optimized code. Raw encodings are not useful in most cases. Cc: Ingo Molnar <mingo@elte.hu> Cc: Peter Zijlstra <peterz@infradead.org> Link: http://lkml.kernel.org/r/20110517153207.GA9834@quad Signed-off-by: Stephane Eranian <eranian@google.com> [committer note: Use the 'no-' option inverting logic] Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
18e5a45db3
commit
3e6a2a7f3b
5 changed files with 21 additions and 2 deletions
|
@ -72,6 +72,14 @@ OPTIONS
|
||||||
CPUs are specified with -: 0-2. Default is to report samples on all
|
CPUs are specified with -: 0-2. Default is to report samples on all
|
||||||
CPUs.
|
CPUs.
|
||||||
|
|
||||||
|
--asm-raw::
|
||||||
|
Show raw instruction encoding of assembly instructions. They
|
||||||
|
are displayed by default, disable with --no-asm-raw.
|
||||||
|
|
||||||
|
--source::
|
||||||
|
Interleave source code with assembly code. Enabled by default,
|
||||||
|
disable with --no-source.
|
||||||
|
|
||||||
SEE ALSO
|
SEE ALSO
|
||||||
--------
|
--------
|
||||||
linkperf:perf-record[1], linkperf:perf-report[1]
|
linkperf:perf-record[1], linkperf:perf-report[1]
|
||||||
|
|
|
@ -267,6 +267,10 @@ static const struct option options[] = {
|
||||||
OPT_BOOLEAN('P', "full-paths", &full_paths,
|
OPT_BOOLEAN('P', "full-paths", &full_paths,
|
||||||
"Don't shorten the displayed pathnames"),
|
"Don't shorten the displayed pathnames"),
|
||||||
OPT_STRING('c', "cpu", &cpu_list, "cpu", "list of cpus to profile"),
|
OPT_STRING('c', "cpu", &cpu_list, "cpu", "list of cpus to profile"),
|
||||||
|
OPT_BOOLEAN('0', "source", &symbol_conf.annotate_src,
|
||||||
|
"Interleave source code with assembly code (default)"),
|
||||||
|
OPT_BOOLEAN('0', "asm-raw", &symbol_conf.annotate_asm_raw,
|
||||||
|
"Display raw encoding of assembly instructions (default)"),
|
||||||
OPT_END()
|
OPT_END()
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -324,9 +324,12 @@ fallback:
|
||||||
|
|
||||||
snprintf(command, sizeof(command),
|
snprintf(command, sizeof(command),
|
||||||
"objdump --start-address=0x%016" PRIx64
|
"objdump --start-address=0x%016" PRIx64
|
||||||
" --stop-address=0x%016" PRIx64 " -dS -C %s|grep -v %s|expand",
|
" --stop-address=0x%016" PRIx64
|
||||||
|
" -d %s %s -C %s|grep -v %s|expand",
|
||||||
map__rip_2objdump(map, sym->start),
|
map__rip_2objdump(map, sym->start),
|
||||||
map__rip_2objdump(map, sym->end),
|
map__rip_2objdump(map, sym->end),
|
||||||
|
symbol_conf.annotate_asm_raw ? "" : "--no-show-raw",
|
||||||
|
symbol_conf.annotate_src ? "-S" : "",
|
||||||
symfs_filename, filename);
|
symfs_filename, filename);
|
||||||
|
|
||||||
pr_debug("Executing: %s\n", command);
|
pr_debug("Executing: %s\n", command);
|
||||||
|
|
|
@ -46,6 +46,8 @@ struct symbol_conf symbol_conf = {
|
||||||
.exclude_other = true,
|
.exclude_other = true,
|
||||||
.use_modules = true,
|
.use_modules = true,
|
||||||
.try_vmlinux_path = true,
|
.try_vmlinux_path = true,
|
||||||
|
.annotate_asm_raw = true,
|
||||||
|
.annotate_src = true,
|
||||||
.symfs = "",
|
.symfs = "",
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -76,7 +76,9 @@ struct symbol_conf {
|
||||||
exclude_other,
|
exclude_other,
|
||||||
show_cpu_utilization,
|
show_cpu_utilization,
|
||||||
initialized,
|
initialized,
|
||||||
kptr_restrict;
|
kptr_restrict,
|
||||||
|
annotate_asm_raw,
|
||||||
|
annotate_src;
|
||||||
const char *vmlinux_name,
|
const char *vmlinux_name,
|
||||||
*kallsyms_name,
|
*kallsyms_name,
|
||||||
*source_prefix,
|
*source_prefix,
|
||||||
|
|
Loading…
Reference in a new issue