Commit 7bcbcd58 authored by Jiri Olsa's avatar Jiri Olsa Committed by Arnaldo Carvalho de Melo

perf annotate browser: Change selection to struct annotation_line

Use struct annotation_line as a browser::selection.

We want to be able to use the annotate_browser for all sorts of source
data, so it needs to be able to work over the generic struct
annotation_line.
Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
Cc: Andi Kleen <andi@firstfloor.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/20171106105617.GC20858@kravaSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent daf25d43
...@@ -50,7 +50,7 @@ struct annotate_browser { ...@@ -50,7 +50,7 @@ struct annotate_browser {
struct ui_browser b; struct ui_browser b;
struct rb_root entries; struct rb_root entries;
struct rb_node *curr_hot; struct rb_node *curr_hot;
struct disasm_line *selection; struct annotation_line *selection;
struct disasm_line **offsets; struct disasm_line **offsets;
struct arch *arch; struct arch *arch;
int nr_events; int nr_events;
...@@ -265,7 +265,7 @@ static void annotate_browser__write(struct ui_browser *browser, void *entry, int ...@@ -265,7 +265,7 @@ static void annotate_browser__write(struct ui_browser *browser, void *entry, int
} }
if (current_entry) if (current_entry)
ab->selection = dl; ab->selection = &dl->al;
} }
static bool disasm_line__is_valid_jump(struct disasm_line *dl, struct symbol *sym) static bool disasm_line__is_valid_jump(struct disasm_line *dl, struct symbol *sym)
...@@ -301,7 +301,8 @@ static bool is_fused(struct annotate_browser *ab, struct disasm_line *cursor) ...@@ -301,7 +301,8 @@ static bool is_fused(struct annotate_browser *ab, struct disasm_line *cursor)
static void annotate_browser__draw_current_jump(struct ui_browser *browser) static void annotate_browser__draw_current_jump(struct ui_browser *browser)
{ {
struct annotate_browser *ab = container_of(browser, struct annotate_browser, b); struct annotate_browser *ab = container_of(browser, struct annotate_browser, b);
struct disasm_line *cursor = ab->selection, *target; struct disasm_line *cursor = disasm_line(ab->selection);
struct disasm_line *target;
struct browser_line *btarget, *bcursor; struct browser_line *btarget, *bcursor;
unsigned int from, to; unsigned int from, to;
struct map_symbol *ms = ab->b.priv; struct map_symbol *ms = ab->b.priv;
...@@ -526,7 +527,7 @@ static bool annotate_browser__callq(struct annotate_browser *browser, ...@@ -526,7 +527,7 @@ static bool annotate_browser__callq(struct annotate_browser *browser,
struct hist_browser_timer *hbt) struct hist_browser_timer *hbt)
{ {
struct map_symbol *ms = browser->b.priv; struct map_symbol *ms = browser->b.priv;
struct disasm_line *dl = browser->selection; struct disasm_line *dl = disasm_line(browser->selection);
struct annotation *notes; struct annotation *notes;
struct addr_map_symbol target = { struct addr_map_symbol target = {
.map = ms->map, .map = ms->map,
...@@ -584,7 +585,7 @@ struct disasm_line *annotate_browser__find_offset(struct annotate_browser *brows ...@@ -584,7 +585,7 @@ struct disasm_line *annotate_browser__find_offset(struct annotate_browser *brows
static bool annotate_browser__jump(struct annotate_browser *browser) static bool annotate_browser__jump(struct annotate_browser *browser)
{ {
struct disasm_line *dl = browser->selection; struct disasm_line *dl = disasm_line(browser->selection);
u64 offset; u64 offset;
s64 idx; s64 idx;
...@@ -610,7 +611,7 @@ struct disasm_line *annotate_browser__find_string(struct annotate_browser *brows ...@@ -610,7 +611,7 @@ struct disasm_line *annotate_browser__find_string(struct annotate_browser *brows
struct map_symbol *ms = browser->b.priv; struct map_symbol *ms = browser->b.priv;
struct symbol *sym = ms->sym; struct symbol *sym = ms->sym;
struct annotation *notes = symbol__annotation(sym); struct annotation *notes = symbol__annotation(sym);
struct disasm_line *pos = browser->selection; struct disasm_line *pos = disasm_line(browser->selection);
*idx = browser->b.index; *idx = browser->b.index;
list_for_each_entry_continue(pos, &notes->src->source, al.node) { list_for_each_entry_continue(pos, &notes->src->source, al.node) {
...@@ -649,7 +650,7 @@ struct disasm_line *annotate_browser__find_string_reverse(struct annotate_browse ...@@ -649,7 +650,7 @@ struct disasm_line *annotate_browser__find_string_reverse(struct annotate_browse
struct map_symbol *ms = browser->b.priv; struct map_symbol *ms = browser->b.priv;
struct symbol *sym = ms->sym; struct symbol *sym = ms->sym;
struct annotation *notes = symbol__annotation(sym); struct annotation *notes = symbol__annotation(sym);
struct disasm_line *pos = browser->selection; struct disasm_line *pos = disasm_line(browser->selection);
*idx = browser->b.index; *idx = browser->b.index;
list_for_each_entry_continue_reverse(pos, &notes->src->source, al.node) { list_for_each_entry_continue_reverse(pos, &notes->src->source, al.node) {
...@@ -882,13 +883,16 @@ static int annotate_browser__run(struct annotate_browser *browser, ...@@ -882,13 +883,16 @@ static int annotate_browser__run(struct annotate_browser *browser,
continue; continue;
case K_ENTER: case K_ENTER:
case K_RIGHT: case K_RIGHT:
{
struct disasm_line *dl = disasm_line(browser->selection);
if (browser->selection == NULL) if (browser->selection == NULL)
ui_helpline__puts("Huh? No selection. Report to linux-kernel@vger.kernel.org"); ui_helpline__puts("Huh? No selection. Report to linux-kernel@vger.kernel.org");
else if (browser->selection->al.offset == -1) else if (browser->selection->offset == -1)
ui_helpline__puts("Actions are only available for assembly lines."); ui_helpline__puts("Actions are only available for assembly lines.");
else if (!browser->selection->ins.ops) else if (!dl->ins.ops)
goto show_sup_ins; goto show_sup_ins;
else if (ins__is_ret(&browser->selection->ins)) else if (ins__is_ret(&dl->ins))
goto out; goto out;
else if (!(annotate_browser__jump(browser) || else if (!(annotate_browser__jump(browser) ||
annotate_browser__callq(browser, evsel, hbt))) { annotate_browser__callq(browser, evsel, hbt))) {
...@@ -896,6 +900,7 @@ static int annotate_browser__run(struct annotate_browser *browser, ...@@ -896,6 +900,7 @@ static int annotate_browser__run(struct annotate_browser *browser,
ui_helpline__puts("Actions are only available for function call/return & jump/branch instructions."); ui_helpline__puts("Actions are only available for function call/return & jump/branch instructions.");
} }
continue; continue;
}
case 't': case 't':
if (annotate_browser__opts.show_total_period) { if (annotate_browser__opts.show_total_period) {
annotate_browser__opts.show_total_period = false; annotate_browser__opts.show_total_period = false;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment