diff options
Diffstat (limited to 'tools/perf/util/annotate.c')
| -rw-r--r-- | tools/perf/util/annotate.c | 22 | 
1 files changed, 9 insertions, 13 deletions
| diff --git a/tools/perf/util/annotate.c b/tools/perf/util/annotate.c index e5a462f1d07..08c6d138a65 100644 --- a/tools/perf/util/annotate.c +++ b/tools/perf/util/annotate.c @@ -28,8 +28,8 @@ int symbol__annotate_init(struct map *map __used, struct symbol *sym)  int symbol__alloc_hist(struct symbol *sym)  {  	struct annotation *notes = symbol__annotation(sym); -	size_t sizeof_sym_hist = (sizeof(struct sym_hist) + -				  (sym->end - sym->start) * sizeof(u64)); +	const size_t size = sym->end - sym->start + 1; +	size_t sizeof_sym_hist = (sizeof(struct sym_hist) + size * sizeof(u64));  	notes->src = zalloc(sizeof(*notes->src) + symbol_conf.nr_events * sizeof_sym_hist);  	if (notes->src == NULL) @@ -64,8 +64,8 @@ int symbol__inc_addr_samples(struct symbol *sym, struct map *map,  	pr_debug3("%s: addr=%#" PRIx64 "\n", __func__, map->unmap_ip(map, addr)); -	if (addr >= sym->end) -		return 0; +	if (addr < sym->start || addr > sym->end) +		return -ERANGE;  	offset = addr - sym->start;  	h = annotation__histogram(notes, evidx); @@ -408,7 +408,7 @@ static int symbol__get_source_line(struct symbol *sym, struct map *map,  	if (!notes->src->lines)  		return -1; -	start = map->unmap_ip(map, sym->start); +	start = map__rip_2objdump(map, sym->start);  	for (i = 0; i < len; i++) {  		char *path = NULL; @@ -561,16 +561,12 @@ void symbol__annotate_decay_histogram(struct symbol *sym, int evidx)  {  	struct annotation *notes = symbol__annotation(sym);  	struct sym_hist *h = annotation__histogram(notes, evidx); -	struct objdump_line *pos; -	int len = sym->end - sym->start; +	int len = sym->end - sym->start, offset;  	h->sum = 0; - -	list_for_each_entry(pos, ¬es->src->source, node) { -		if (pos->offset != -1 && pos->offset < len) { -			h->addr[pos->offset] = h->addr[pos->offset] * 7 / 8; -			h->sum += h->addr[pos->offset]; -		} +	for (offset = 0; offset < len; ++offset) { +		h->addr[offset] = h->addr[offset] * 7 / 8; +		h->sum += h->addr[offset];  	}  } | 
