perf thread: Make thread__find_map() return the map

It was returning the searched map just on the addr_location passed, with
the function itself returning void.

Make it return the map so that we can make the code more compact.

Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Wang Nan <wangnan0@huawei.com>
Link: https://lkml.kernel.org/n/tip-tzlrrzdeoof4i6ktyqv1t6ks@git.kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent cc5f02f2
...@@ -440,9 +440,7 @@ static int perf_event__inject_buildid(struct perf_tool *tool, ...@@ -440,9 +440,7 @@ static int perf_event__inject_buildid(struct perf_tool *tool,
goto repipe; goto repipe;
} }
thread__find_map(thread, sample->cpumode, sample->ip, &al); if (thread__find_map(thread, sample->cpumode, sample->ip, &al)) {
if (al.map != NULL) {
if (!al.map->dso->hit) { if (!al.map->dso->hit) {
al.map->dso->hit = 1; al.map->dso->hit = 1;
if (map__load(al.map) >= 0) { if (map__load(al.map) >= 0) {
......
...@@ -809,12 +809,12 @@ static int perf_sample__fprintf_brstackoff(struct perf_sample *sample, ...@@ -809,12 +809,12 @@ static int perf_sample__fprintf_brstackoff(struct perf_sample *sample,
from = br->entries[i].from; from = br->entries[i].from;
to = br->entries[i].to; to = br->entries[i].to;
thread__find_map(thread, sample->cpumode, from, &alf); if (thread__find_map(thread, sample->cpumode, from, &alf) &&
if (alf.map && !alf.map->dso->adjust_symbols) !alf.map->dso->adjust_symbols)
from = map__map_ip(alf.map, from); from = map__map_ip(alf.map, from);
thread__find_map(thread, sample->cpumode, to, &alt); if (thread__find_map(thread, sample->cpumode, to, &alt) &&
if (alt.map && !alt.map->dso->adjust_symbols) !alt.map->dso->adjust_symbols)
to = map__map_ip(alt.map, to); to = map__map_ip(alt.map, to);
printed += fprintf(fp, " 0x%"PRIx64, from); printed += fprintf(fp, " 0x%"PRIx64, from);
...@@ -877,8 +877,7 @@ static int grab_bb(u8 *buffer, u64 start, u64 end, ...@@ -877,8 +877,7 @@ static int grab_bb(u8 *buffer, u64 start, u64 end,
return 0; return 0;
} }
thread__find_map(thread, *cpumode, start, &al); if (!thread__find_map(thread, *cpumode, start, &al) || !al.map->dso) {
if (!al.map || !al.map->dso) {
pr_debug("\tcannot resolve %" PRIx64 "-%" PRIx64 "\n", start, end); pr_debug("\tcannot resolve %" PRIx64 "-%" PRIx64 "\n", start, end);
return 0; return 0;
} }
...@@ -928,8 +927,7 @@ static int ip__fprintf_sym(uint64_t addr, struct thread *thread, ...@@ -928,8 +927,7 @@ static int ip__fprintf_sym(uint64_t addr, struct thread *thread,
memset(&al, 0, sizeof(al)); memset(&al, 0, sizeof(al));
thread__find_map(thread, cpumode, addr, &al); if (!thread__find_map(thread, cpumode, addr, &al))
if (!al.map)
__thread__find_map(thread, cpumode, MAP__VARIABLE, addr, &al); __thread__find_map(thread, cpumode, MAP__VARIABLE, addr, &al);
if ((*lastsym) && al.addr >= (*lastsym)->start && al.addr < (*lastsym)->end) if ((*lastsym) && al.addr >= (*lastsym)->start && al.addr < (*lastsym)->end)
return 0; return 0;
......
...@@ -236,8 +236,7 @@ static int read_object_code(u64 addr, size_t len, u8 cpumode, ...@@ -236,8 +236,7 @@ static int read_object_code(u64 addr, size_t len, u8 cpumode,
pr_debug("Reading object code for memory address: %#"PRIx64"\n", addr); pr_debug("Reading object code for memory address: %#"PRIx64"\n", addr);
thread__find_map(thread, cpumode, addr, &al); if (!thread__find_map(thread, cpumode, addr, &al) || !al.map->dso) {
if (!al.map || !al.map->dso) {
if (cpumode == PERF_RECORD_MISC_HYPERVISOR) { if (cpumode == PERF_RECORD_MISC_HYPERVISOR) {
pr_debug("Hypervisor address can not be resolved - skipping\n"); pr_debug("Hypervisor address can not be resolved - skipping\n");
return 0; return 0;
......
...@@ -47,9 +47,7 @@ int build_id__mark_dso_hit(struct perf_tool *tool __maybe_unused, ...@@ -47,9 +47,7 @@ int build_id__mark_dso_hit(struct perf_tool *tool __maybe_unused,
return -1; return -1;
} }
thread__find_map(thread, sample->cpumode, sample->ip, &al); if (thread__find_map(thread, sample->cpumode, sample->ip, &al))
if (al.map != NULL)
al.map->dso->hit = 1; al.map->dso->hit = 1;
thread__put(thread); thread__put(thread);
......
...@@ -269,9 +269,7 @@ static u32 cs_etm__mem_access(struct cs_etm_queue *etmq, u64 address, ...@@ -269,9 +269,7 @@ static u32 cs_etm__mem_access(struct cs_etm_queue *etmq, u64 address,
thread = etmq->etm->unknown_thread; thread = etmq->etm->unknown_thread;
} }
thread__find_map(thread, cpumode, address, &al); if (!thread__find_map(thread, cpumode, address, &al) || !al.map->dso)
if (!al.map || !al.map->dso)
return 0; return 0;
if (al.map->dso->data.status == DSO_DATA_STATUS_ERROR && if (al.map->dso->data.status == DSO_DATA_STATUS_ERROR &&
......
...@@ -1489,8 +1489,8 @@ int perf_event__process(struct perf_tool *tool __maybe_unused, ...@@ -1489,8 +1489,8 @@ int perf_event__process(struct perf_tool *tool __maybe_unused,
return machine__process_event(machine, event, sample); return machine__process_event(machine, event, sample);
} }
void __thread__find_map(struct thread *thread, u8 cpumode, enum map_type type, struct map *__thread__find_map(struct thread *thread, u8 cpumode, enum map_type type,
u64 addr, struct addr_location *al) u64 addr, struct addr_location *al)
{ {
struct map_groups *mg = thread->mg; struct map_groups *mg = thread->mg;
struct machine *machine = mg->machine; struct machine *machine = mg->machine;
...@@ -1504,7 +1504,7 @@ void __thread__find_map(struct thread *thread, u8 cpumode, enum map_type type, ...@@ -1504,7 +1504,7 @@ void __thread__find_map(struct thread *thread, u8 cpumode, enum map_type type,
if (machine == NULL) { if (machine == NULL) {
al->map = NULL; al->map = NULL;
return; return NULL;
} }
if (cpumode == PERF_RECORD_MISC_KERNEL && perf_host) { if (cpumode == PERF_RECORD_MISC_KERNEL && perf_host) {
...@@ -1532,7 +1532,7 @@ void __thread__find_map(struct thread *thread, u8 cpumode, enum map_type type, ...@@ -1532,7 +1532,7 @@ void __thread__find_map(struct thread *thread, u8 cpumode, enum map_type type,
!perf_host) !perf_host)
al->filtered |= (1 << HIST_FILTER__HOST); al->filtered |= (1 << HIST_FILTER__HOST);
return; return NULL;
} }
try_again: try_again:
al->map = map_groups__find(mg, type, al->addr); al->map = map_groups__find(mg, type, al->addr);
...@@ -1562,14 +1562,15 @@ void __thread__find_map(struct thread *thread, u8 cpumode, enum map_type type, ...@@ -1562,14 +1562,15 @@ void __thread__find_map(struct thread *thread, u8 cpumode, enum map_type type,
map__load(al->map); map__load(al->map);
al->addr = al->map->map_ip(al->map, al->addr); al->addr = al->map->map_ip(al->map, al->addr);
} }
return al->map;
} }
void __thread__find_symbol(struct thread *thread, u8 cpumode, void __thread__find_symbol(struct thread *thread, u8 cpumode,
enum map_type type, u64 addr, enum map_type type, u64 addr,
struct addr_location *al) struct addr_location *al)
{ {
__thread__find_map(thread, cpumode, type, addr, al); if (__thread__find_map(thread, cpumode, type, addr, al))
if (al->map != NULL)
al->sym = map__find_symbol(al->map, al->addr); al->sym = map__find_symbol(al->map, al->addr);
else else
al->sym = NULL; al->sym = NULL;
...@@ -1668,8 +1669,7 @@ bool sample_addr_correlates_sym(struct perf_event_attr *attr) ...@@ -1668,8 +1669,7 @@ bool sample_addr_correlates_sym(struct perf_event_attr *attr)
void thread__resolve(struct thread *thread, struct addr_location *al, void thread__resolve(struct thread *thread, struct addr_location *al,
struct perf_sample *sample) struct perf_sample *sample)
{ {
thread__find_map(thread, sample->cpumode, sample->addr, al); if (!thread__find_map(thread, sample->cpumode, sample->addr, al)) {
if (!al->map) {
__thread__find_map(thread, sample->cpumode, MAP__VARIABLE, __thread__find_map(thread, sample->cpumode, MAP__VARIABLE,
sample->addr, al); sample->addr, al);
} }
......
...@@ -335,8 +335,7 @@ static int intel_bts_get_next_insn(struct intel_bts_queue *btsq, u64 ip) ...@@ -335,8 +335,7 @@ static int intel_bts_get_next_insn(struct intel_bts_queue *btsq, u64 ip)
if (!thread) if (!thread)
return -1; return -1;
thread__find_map(thread, cpumode, ip, &al); if (!thread__find_map(thread, cpumode, ip, &al) || !al.map->dso)
if (!al.map || !al.map->dso)
goto out_put; goto out_put;
len = dso__data_read_addr(al.map->dso, al.map, machine, ip, buf, len = dso__data_read_addr(al.map->dso, al.map, machine, ip, buf,
......
...@@ -442,8 +442,7 @@ static int intel_pt_walk_next_insn(struct intel_pt_insn *intel_pt_insn, ...@@ -442,8 +442,7 @@ static int intel_pt_walk_next_insn(struct intel_pt_insn *intel_pt_insn,
} }
while (1) { while (1) {
thread__find_map(thread, cpumode, *ip, &al); if (!thread__find_map(thread, cpumode, *ip, &al) || !al.map->dso)
if (!al.map || !al.map->dso)
return -EINVAL; return -EINVAL;
if (al.map->dso->data.status == DSO_DATA_STATUS_ERROR && if (al.map->dso->data.status == DSO_DATA_STATUS_ERROR &&
...@@ -596,8 +595,7 @@ static int __intel_pt_pgd_ip(uint64_t ip, void *data) ...@@ -596,8 +595,7 @@ static int __intel_pt_pgd_ip(uint64_t ip, void *data)
if (!thread) if (!thread)
return -EINVAL; return -EINVAL;
thread__find_map(thread, cpumode, ip, &al); if (!thread__find_map(thread, cpumode, ip, &al) || !al.map->dso)
if (!al.map || !al.map->dso)
return -EINVAL; return -EINVAL;
offset = al.map->map_ip(al.map, ip); offset = al.map->map_ip(al.map, ip);
......
...@@ -92,13 +92,13 @@ size_t thread__fprintf(struct thread *thread, FILE *fp); ...@@ -92,13 +92,13 @@ size_t thread__fprintf(struct thread *thread, FILE *fp);
struct thread *thread__main_thread(struct machine *machine, struct thread *thread); struct thread *thread__main_thread(struct machine *machine, struct thread *thread);
void __thread__find_map(struct thread *thread, u8 cpumode, enum map_type type, struct map *__thread__find_map(struct thread *thread, u8 cpumode, enum map_type type,
u64 addr, struct addr_location *al); u64 addr, struct addr_location *al);
static inline void thread__find_map(struct thread *thread, u8 cpumode, static inline struct map *thread__find_map(struct thread *thread, u8 cpumode,
u64 addr, struct addr_location *al) u64 addr, struct addr_location *al)
{ {
__thread__find_map(thread, cpumode, MAP__FUNCTION, addr, al); return __thread__find_map(thread, cpumode, MAP__FUNCTION, addr, al);
} }
void __thread__find_symbol(struct thread *thread, u8 cpumode, enum map_type type, void __thread__find_symbol(struct thread *thread, u8 cpumode, enum map_type type,
......
...@@ -104,8 +104,7 @@ static int access_dso_mem(struct unwind_info *ui, Dwarf_Addr addr, ...@@ -104,8 +104,7 @@ static int access_dso_mem(struct unwind_info *ui, Dwarf_Addr addr,
struct addr_location al; struct addr_location al;
ssize_t size; ssize_t size;
thread__find_map(ui->thread, PERF_RECORD_MISC_USER, addr, &al); if (!thread__find_map(ui->thread, PERF_RECORD_MISC_USER, addr, &al)) {
if (!al.map) {
/* /*
* We've seen cases (softice) where DWARF unwinder went * We've seen cases (softice) where DWARF unwinder went
* through non executable mmaps, which we need to lookup * through non executable mmaps, which we need to lookup
......
...@@ -367,8 +367,7 @@ static struct map *find_map(unw_word_t ip, struct unwind_info *ui) ...@@ -367,8 +367,7 @@ static struct map *find_map(unw_word_t ip, struct unwind_info *ui)
{ {
struct addr_location al; struct addr_location al;
thread__find_map(ui->thread, PERF_RECORD_MISC_USER, ip, &al); if (!thread__find_map(ui->thread, PERF_RECORD_MISC_USER, ip, &al)) {
if (!al.map) {
/* /*
* We've seen cases (softice) where DWARF unwinder went * We've seen cases (softice) where DWARF unwinder went
* through non executable mmaps, which we need to lookup * through non executable mmaps, which we need to lookup
......
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