diff options
| author | Maxime Ripard <maxime@cerno.tech> | 2020-02-17 10:34:34 +0100 | 
|---|---|---|
| committer | Maxime Ripard <maxime@cerno.tech> | 2020-02-17 10:34:34 +0100 | 
| commit | 28f2aff1caa4997f58ca31179cad1b4a84a62827 (patch) | |
| tree | 69fb4b0a752f3660ce022a4313f8c7b276bbcceb /tools/perf/util/machine.c | |
| parent | 3e8a3844fefbaad911c596f02dd48c39188ffa81 (diff) | |
| parent | 11a48a5a18c63fd7621bb050228cebf13566e4d8 (diff) | |
Merge v5.6-rc2 into drm-misc-next
Lyude needs some patches in 5.6-rc2 and we didn't bring drm-misc-next
forward yet, so it looks like a good occasion.
Signed-off-by: Maxime Ripard <maxime@cerno.tech>
Diffstat (limited to 'tools/perf/util/machine.c')
| -rw-r--r-- | tools/perf/util/machine.c | 27 | 
1 files changed, 13 insertions, 14 deletions
| diff --git a/tools/perf/util/machine.c b/tools/perf/util/machine.c index 416d174d223c..fb5c2cd44d30 100644 --- a/tools/perf/util/machine.c +++ b/tools/perf/util/machine.c @@ -686,6 +686,7 @@ static struct dso *machine__findnew_module_dso(struct machine *machine,  		dso__set_module_info(dso, m, machine);  		dso__set_long_name(dso, strdup(filename), true); +		dso->kernel = DSO_TYPE_KERNEL;  	}  	dso__get(dso); @@ -726,9 +727,17 @@ static int machine__process_ksymbol_register(struct machine *machine,  	struct map *map = maps__find(&machine->kmaps, event->ksymbol.addr);  	if (!map) { -		map = dso__new_map(event->ksymbol.name); -		if (!map) +		struct dso *dso = dso__new(event->ksymbol.name); + +		if (dso) { +			dso->kernel = DSO_TYPE_KERNEL; +			map = map__new2(0, dso); +		} + +		if (!dso || !map) { +			dso__put(dso);  			return -ENOMEM; +		}  		map->start = event->ksymbol.addr;  		map->end = map->start + event->ksymbol.len; @@ -972,7 +981,6 @@ int machine__create_extra_kernel_map(struct machine *machine,  	kmap = map__kmap(map); -	kmap->kmaps = &machine->kmaps;  	strlcpy(kmap->name, xm->name, KMAP_NAME_LEN);  	maps__insert(&machine->kmaps, map); @@ -1082,9 +1090,6 @@ int __weak machine__create_extra_kernel_maps(struct machine *machine __maybe_unu  static int  __machine__create_kernel_maps(struct machine *machine, struct dso *kernel)  { -	struct kmap *kmap; -	struct map *map; -  	/* In case of renewal the kernel map, destroy previous one */  	machine__destroy_kernel_maps(machine); @@ -1093,14 +1098,7 @@ __machine__create_kernel_maps(struct machine *machine, struct dso *kernel)  		return -1;  	machine->vmlinux_map->map_ip = machine->vmlinux_map->unmap_ip = identity__map_ip; -	map = machine__kernel_map(machine); -	kmap = map__kmap(map); -	if (!kmap) -		return -1; - -	kmap->kmaps = &machine->kmaps; -	maps__insert(&machine->kmaps, map); - +	maps__insert(&machine->kmaps, machine->vmlinux_map);  	return 0;  } @@ -2446,6 +2444,7 @@ static int append_inlines(struct callchain_cursor *cursor, struct map_symbol *ms  	list_for_each_entry(ilist, &inline_node->val, list) {  		struct map_symbol ilist_ms = { +			.maps = ms->maps,  			.map = map,  			.sym = ilist->symbol,  		}; | 
