diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2012-04-20 14:40:20 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2012-04-20 14:40:20 -0400 |
commit | 51a0d455b5f44cb4680e0a89f99860b669e40d0f (patch) | |
tree | b6a1fcfaa5f51030221e6e4a117ce9f29386908a /tools/perf/ui | |
parent | d22328855666464731ee95d9e1e8d35dc7a39d8d (diff) |
perf annotate browser: Add visual cues on jump lines
Using up/down arrows just before the instruction, replacing the actual chars
with approximations to avoid mail encoding snafus:
avtab_search_node
0.00 | push %rbp
0.00 | mov %rsp,%rbp
0.00 | callq mcount
0.00 | movzwl 0x6(%rsi),%edx
0.00 | and $0x7fff,%dx
0.00 | test %rdi,%rdi
0.00 | v jne 20
0.00 | 17: xor %eax,%eax
0.00 | 19: leaveq
0.00 | retq
0.00 | nopl 0x0(%rax,%rax,1)
0.00 | 20: mov (%rdi),%rax
0.00 | test %rax,%rax
0.00 | ^ je 17
0.00 | movzwl (%rsi),%ecx
0.00 | movzwl 0x2(%rsi),%r9d
0.00 | movzwl 0x4(%rsi),%r8d
0.00 | movzwl %cx,%esi
0.00 | movzwl %r9w,%r10d
0.00 | shl $0x9,%esi
0.00 | lea (%rsi,%r10,4),%esi
0.00 | lea (%r8,%rsi,1),%esi
0.00 | and 0x10(%rdi),%si
0.00 | movzwl %si,%esi
0.00 | mov (%rax,%rsi,8),%rax
0.00 | test %rax,%rax
0.00 | ^ je 19
0.00 | nopw 0x0(%rax,%rax,1)
0.00 | 60: cmp %cx,(%rax)
0.00 | v jne 7e
0.00 | cmp %r9w,0x2(%rax)
0.00 | v jne 7e
0.00 | cmp %r8w,0x4(%rax)
0.00 | v jne 79
0.00 | test %dx,0x6(%rax)
0.00 | ^ jne 19
0.00 | 79: cmp %r8w,0x4(%rax)
93.04 | 7e:^ ja 17
2.53 | mov 0x10(%rax),%rax
4.43 | test %rax,%rax
0.00 | ^ jne 60
0.00 | leaveq
0.00 | retq
Next low hanging fruit is to use left arrow for retqs, then work on clearling
marking loops.
Requested-by: Linus Torvalds <torvalds@linux-foundation.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Namhyung Kim <namhyung@gmail.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-hkx848wdbs6n7bcp3ymr9yus@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/ui')
-rw-r--r-- | tools/perf/ui/browsers/annotate.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/tools/perf/ui/browsers/annotate.c b/tools/perf/ui/browsers/annotate.c index c2bbfc767d4f..63206ca4336b 100644 --- a/tools/perf/ui/browsers/annotate.c +++ b/tools/perf/ui/browsers/annotate.c | |||
@@ -113,9 +113,20 @@ static void annotate_browser__write(struct ui_browser *self, void *entry, int ro | |||
113 | if (change_color) | 113 | if (change_color) |
114 | ui_browser__set_color(self, color); | 114 | ui_browser__set_color(self, color); |
115 | if (dl->ins && dl->ins->ops->scnprintf) { | 115 | if (dl->ins && dl->ins->ops->scnprintf) { |
116 | if (ins__is_jump(dl->ins)) { | ||
117 | bool fwd = dl->ops.target > (u64)dl->offset; | ||
118 | |||
119 | SLsmg_set_char_set(1); | ||
120 | SLsmg_write_char(fwd ? SLSMG_DARROW_CHAR : | ||
121 | SLSMG_UARROW_CHAR); | ||
122 | SLsmg_set_char_set(0); | ||
123 | SLsmg_write_char(' '); | ||
124 | } else { | ||
125 | slsmg_write_nstring(" ", 2); | ||
126 | } | ||
127 | |||
116 | dl->ins->ops->scnprintf(dl->ins, bf, sizeof(bf), &dl->ops, | 128 | dl->ins->ops->scnprintf(dl->ins, bf, sizeof(bf), &dl->ops, |
117 | !ab->use_offset); | 129 | !ab->use_offset); |
118 | slsmg_write_nstring(" ", 2); | ||
119 | printed += 2; | 130 | printed += 2; |
120 | } else | 131 | } else |
121 | scnprintf(bf, sizeof(bf), " %-6.6s %s", dl->name, dl->ops.raw); | 132 | scnprintf(bf, sizeof(bf), " %-6.6s %s", dl->name, dl->ops.raw); |