diff options
Diffstat (limited to 'tools/perf/util/header.c')
| -rw-r--r-- | tools/perf/util/header.c | 41 | 
1 files changed, 28 insertions, 13 deletions
| diff --git a/tools/perf/util/header.c b/tools/perf/util/header.c index 26441d0e571b..ce69901176d8 100644 --- a/tools/perf/util/header.c +++ b/tools/perf/util/header.c @@ -199,9 +199,11 @@ static int write_buildid(char *name, size_t name_len, u8 *build_id,  	return write_padded(fd, name, name_len + 1, len);  } -static int __dsos__write_buildid_table(struct list_head *head, pid_t pid, -				u16 misc, int fd) +static int __dsos__write_buildid_table(struct list_head *head, +				       struct machine *machine, +				       pid_t pid, u16 misc, int fd)  { +	char nm[PATH_MAX];  	struct dso *pos;  	dsos__for_each_with_build_id(pos, head) { @@ -215,6 +217,10 @@ static int __dsos__write_buildid_table(struct list_head *head, pid_t pid,  		if (is_vdso_map(pos->short_name)) {  			name = (char *) VDSO__MAP_NAME;  			name_len = sizeof(VDSO__MAP_NAME) + 1; +		} else if (dso__is_kcore(pos)) { +			machine__mmap_name(machine, nm, sizeof(nm)); +			name = nm; +			name_len = strlen(nm) + 1;  		} else {  			name = pos->long_name;  			name_len = pos->long_name_len + 1; @@ -240,10 +246,10 @@ static int machine__write_buildid_table(struct machine *machine, int fd)  		umisc = PERF_RECORD_MISC_GUEST_USER;  	} -	err = __dsos__write_buildid_table(&machine->kernel_dsos, machine->pid, -					  kmisc, fd); +	err = __dsos__write_buildid_table(&machine->kernel_dsos, machine, +					  machine->pid, kmisc, fd);  	if (err == 0) -		err = __dsos__write_buildid_table(&machine->user_dsos, +		err = __dsos__write_buildid_table(&machine->user_dsos, machine,  						  machine->pid, umisc, fd);  	return err;  } @@ -375,23 +381,31 @@ out_free:  	return err;  } -static int dso__cache_build_id(struct dso *dso, const char *debugdir) +static int dso__cache_build_id(struct dso *dso, struct machine *machine, +			       const char *debugdir)  {  	bool is_kallsyms = dso->kernel && dso->long_name[0] != '/';  	bool is_vdso = is_vdso_map(dso->short_name); +	char *name = dso->long_name; +	char nm[PATH_MAX]; -	return build_id_cache__add_b(dso->build_id, sizeof(dso->build_id), -				     dso->long_name, debugdir, -				     is_kallsyms, is_vdso); +	if (dso__is_kcore(dso)) { +		is_kallsyms = true; +		machine__mmap_name(machine, nm, sizeof(nm)); +		name = nm; +	} +	return build_id_cache__add_b(dso->build_id, sizeof(dso->build_id), name, +				     debugdir, is_kallsyms, is_vdso);  } -static int __dsos__cache_build_ids(struct list_head *head, const char *debugdir) +static int __dsos__cache_build_ids(struct list_head *head, +				   struct machine *machine, const char *debugdir)  {  	struct dso *pos;  	int err = 0;  	dsos__for_each_with_build_id(pos, head) -		if (dso__cache_build_id(pos, debugdir)) +		if (dso__cache_build_id(pos, machine, debugdir))  			err = -1;  	return err; @@ -399,8 +413,9 @@ static int __dsos__cache_build_ids(struct list_head *head, const char *debugdir)  static int machine__cache_build_ids(struct machine *machine, const char *debugdir)  { -	int ret = __dsos__cache_build_ids(&machine->kernel_dsos, debugdir); -	ret |= __dsos__cache_build_ids(&machine->user_dsos, debugdir); +	int ret = __dsos__cache_build_ids(&machine->kernel_dsos, machine, +					  debugdir); +	ret |= __dsos__cache_build_ids(&machine->user_dsos, machine, debugdir);  	return ret;  } | 
