perf annotate: Fix hist decay
We were only decaying the entries for the offsets that were associated with an objdump line. That way, when we accrued the whole instruction addr range, more than 100% was appearing in some cases in the live annotation TUI. Fix it by not traversing the source code line at all, just iterate thru the complete addr range decaying each one. Reported-by: Mike Galbraith <mgalbraith@suse.de> Cc: David Ahern <dsahern@gmail.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> 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-hcae5oxa22syjrnalsxz7s6n@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
Родитель
4bea8b5cf8
Коммит
8b84a56811
|
@ -561,16 +561,12 @@ void symbol__annotate_decay_histogram(struct symbol *sym, int evidx)
|
||||||
{
|
{
|
||||||
struct annotation *notes = symbol__annotation(sym);
|
struct annotation *notes = symbol__annotation(sym);
|
||||||
struct sym_hist *h = annotation__histogram(notes, evidx);
|
struct sym_hist *h = annotation__histogram(notes, evidx);
|
||||||
struct objdump_line *pos;
|
int len = sym->end - sym->start, offset;
|
||||||
int len = sym->end - sym->start;
|
|
||||||
|
|
||||||
h->sum = 0;
|
h->sum = 0;
|
||||||
|
for (offset = 0; offset < len; ++offset) {
|
||||||
list_for_each_entry(pos, ¬es->src->source, node) {
|
h->addr[offset] = h->addr[offset] * 7 / 8;
|
||||||
if (pos->offset != -1 && pos->offset < len) {
|
h->sum += h->addr[offset];
|
||||||
h->addr[pos->offset] = h->addr[pos->offset] * 7 / 8;
|
|
||||||
h->sum += h->addr[pos->offset];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче