perf tools: Add map_groups to 'struct addr_location'

From there we can get al->mg->machine, so replace that field with the
more useful 'struct map_groups' that for now we're obtaining from
al->map->groups, and that is one thing getting into the way of maps
being fully shareable.

Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Link: https://lkml.kernel.org/n/tip-4qdducrm32tgrjupcp0kjh1e@git.kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 9d355b38
...@@ -1119,8 +1119,8 @@ int fill_callchain_info(struct addr_location *al, struct callchain_cursor_node * ...@@ -1119,8 +1119,8 @@ int fill_callchain_info(struct addr_location *al, struct callchain_cursor_node *
goto out; goto out;
} }
if (al->map->groups == &al->machine->kmaps) { if (al->mg == &al->mg->machine->kmaps) {
if (machine__is_host(al->machine)) { if (machine__is_host(al->mg->machine)) {
al->cpumode = PERF_RECORD_MISC_KERNEL; al->cpumode = PERF_RECORD_MISC_KERNEL;
al->level = 'k'; al->level = 'k';
} else { } else {
...@@ -1128,7 +1128,7 @@ int fill_callchain_info(struct addr_location *al, struct callchain_cursor_node * ...@@ -1128,7 +1128,7 @@ int fill_callchain_info(struct addr_location *al, struct callchain_cursor_node *
al->level = 'g'; al->level = 'g';
} }
} else { } else {
if (machine__is_host(al->machine)) { if (machine__is_host(al->mg->machine)) {
al->cpumode = PERF_RECORD_MISC_USER; al->cpumode = PERF_RECORD_MISC_USER;
al->level = '.'; al->level = '.';
} else if (perf_guest) { } else if (perf_guest) {
......
...@@ -181,7 +181,7 @@ static int db_ids_from_al(struct db_export *dbe, struct addr_location *al, ...@@ -181,7 +181,7 @@ static int db_ids_from_al(struct db_export *dbe, struct addr_location *al,
if (al->map) { if (al->map) {
struct dso *dso = al->map->dso; struct dso *dso = al->map->dso;
err = db_export__dso(dbe, dso, al->machine); err = db_export__dso(dbe, dso, al->mg->machine);
if (err) if (err)
return err; return err;
*dso_db_id = dso->db_id; *dso_db_id = dso->db_id;
...@@ -251,7 +251,7 @@ static struct call_path *call_path_from_sample(struct db_export *dbe, ...@@ -251,7 +251,7 @@ static struct call_path *call_path_from_sample(struct db_export *dbe,
*/ */
al.sym = node->sym; al.sym = node->sym;
al.map = node->map; al.map = node->map;
al.machine = machine; al.mg = thread->mg;
al.addr = node->ip; al.addr = node->ip;
if (al.map && !al.sym) if (al.map && !al.sym)
...@@ -360,13 +360,13 @@ int db_export__sample(struct db_export *dbe, union perf_event *event, ...@@ -360,13 +360,13 @@ int db_export__sample(struct db_export *dbe, union perf_event *event,
if (err) if (err)
return err; return err;
err = db_export__machine(dbe, al->machine); err = db_export__machine(dbe, al->mg->machine);
if (err) if (err)
return err; return err;
main_thread = thread__main_thread(al->machine, thread); main_thread = thread__main_thread(al->mg->machine, thread);
err = db_export__threads(dbe, thread, main_thread, al->machine, &comm); err = db_export__threads(dbe, thread, main_thread, al->mg->machine, &comm);
if (err) if (err)
goto out_put; goto out_put;
...@@ -380,7 +380,7 @@ int db_export__sample(struct db_export *dbe, union perf_event *event, ...@@ -380,7 +380,7 @@ int db_export__sample(struct db_export *dbe, union perf_event *event,
goto out_put; goto out_put;
if (dbe->cpr) { if (dbe->cpr) {
struct call_path *cp = call_path_from_sample(dbe, al->machine, struct call_path *cp = call_path_from_sample(dbe, al->mg->machine,
thread, sample, thread, sample,
evsel); evsel);
if (cp) { if (cp) {
......
...@@ -461,7 +461,7 @@ struct map *thread__find_map(struct thread *thread, u8 cpumode, u64 addr, ...@@ -461,7 +461,7 @@ struct map *thread__find_map(struct thread *thread, u8 cpumode, u64 addr,
struct machine *machine = mg->machine; struct machine *machine = mg->machine;
bool load_map = false; bool load_map = false;
al->machine = machine; al->mg = mg;
al->thread = thread; al->thread = thread;
al->addr = addr; al->addr = addr;
al->cpumode = cpumode; al->cpumode = cpumode;
...@@ -474,13 +474,13 @@ struct map *thread__find_map(struct thread *thread, u8 cpumode, u64 addr, ...@@ -474,13 +474,13 @@ struct map *thread__find_map(struct thread *thread, u8 cpumode, u64 addr,
if (cpumode == PERF_RECORD_MISC_KERNEL && perf_host) { if (cpumode == PERF_RECORD_MISC_KERNEL && perf_host) {
al->level = 'k'; al->level = 'k';
mg = &machine->kmaps; al->mg = mg = &machine->kmaps;
load_map = true; load_map = true;
} else if (cpumode == PERF_RECORD_MISC_USER && perf_host) { } else if (cpumode == PERF_RECORD_MISC_USER && perf_host) {
al->level = '.'; al->level = '.';
} else if (cpumode == PERF_RECORD_MISC_GUEST_KERNEL && perf_guest) { } else if (cpumode == PERF_RECORD_MISC_GUEST_KERNEL && perf_guest) {
al->level = 'g'; al->level = 'g';
mg = &machine->kmaps; al->mg = mg = &machine->kmaps;
load_map = true; load_map = true;
} else if (cpumode == PERF_RECORD_MISC_GUEST_USER && perf_guest) { } else if (cpumode == PERF_RECORD_MISC_GUEST_USER && perf_guest) {
al->level = 'u'; al->level = 'u';
......
...@@ -1127,7 +1127,7 @@ static void python_export_sample_table(struct db_export *dbe, ...@@ -1127,7 +1127,7 @@ static void python_export_sample_table(struct db_export *dbe,
tuple_set_u64(t, 0, es->db_id); tuple_set_u64(t, 0, es->db_id);
tuple_set_u64(t, 1, es->evsel->db_id); tuple_set_u64(t, 1, es->evsel->db_id);
tuple_set_u64(t, 2, es->al->machine->db_id); tuple_set_u64(t, 2, es->al->mg->machine->db_id);
tuple_set_u64(t, 3, es->al->thread->db_id); tuple_set_u64(t, 3, es->al->thread->db_id);
tuple_set_u64(t, 4, es->comm_db_id); tuple_set_u64(t, 4, es->comm_db_id);
tuple_set_u64(t, 5, es->dso_db_id); tuple_set_u64(t, 5, es->dso_db_id);
......
...@@ -107,8 +107,8 @@ struct ref_reloc_sym { ...@@ -107,8 +107,8 @@ struct ref_reloc_sym {
}; };
struct addr_location { struct addr_location {
struct machine *machine;
struct thread *thread; struct thread *thread;
struct map_groups *mg;
struct map *map; struct map *map;
struct symbol *sym; struct symbol *sym;
const char *srcline; const char *srcline;
......
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