Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 182395
b: refs/heads/master
c: dc8d6ab
h: refs/heads/master
i:
  182393: 10ea751
  182391: 047b706
v: v3
  • Loading branch information
Arnaldo Carvalho de Melo authored and Ingo Molnar committed Jan 20, 2010
1 parent 1afa943 commit eba4fff
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 27 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: f162f87ad6e98e8bfb2362955da46bed7b2514be
refs/heads/master: dc8d6ab2b61a2d92b5d7438565ccd20b29724cb2
67 changes: 41 additions & 26 deletions trunk/tools/perf/util/symbol.c
Original file line number Diff line number Diff line change
Expand Up @@ -1572,7 +1572,7 @@ static int dso__load_vmlinux(struct dso *self, struct map *map,
return -1;

dso__set_loaded(self, map->type);
err = dso__load_sym(self, map, session, self->long_name, fd, filter, 1, 0);
err = dso__load_sym(self, map, session, vmlinux, fd, filter, 1, 0);
close(fd);

return err;
Expand All @@ -1584,6 +1584,26 @@ static int dso__load_kernel_sym(struct dso *self, struct map *map,
int err;
const char *kallsyms_filename = NULL;
char *kallsyms_allocated_filename = NULL;
/*
* Step 1: if the user specified a vmlinux filename, use it and only
* it, reporting errors to the user if it cannot be used.
*
* For instance, try to analyse an ARM perf.data file _without_ a
* build-id, or if the user specifies the wrong path to the right
* vmlinux file, obviously we can't fallback to another vmlinux (a
* x86_86 one, on the machine where analysis is being performed, say),
* or worse, /proc/kallsyms.
*
* If the specified file _has_ a build-id and there is a build-id
* section in the perf.data file, we will still do the expected
* validation in dso__load_vmlinux and will bail out if they don't
* match.
*/
if (symbol_conf.vmlinux_name != NULL) {
err = dso__load_vmlinux(self, map, session,
symbol_conf.vmlinux_name, filter);
goto out_try_fixup;
}

if (vmlinux_path != NULL) {
int i;
Expand Down Expand Up @@ -1618,46 +1638,41 @@ static int dso__load_kernel_sym(struct dso *self, struct map *map,
goto do_kallsyms;
}
}

/*
* Now look if we have it on the build-id cache in
* $HOME/.debug/[kernel.kallsyms].
*/
build_id__sprintf(self->build_id, sizeof(self->build_id),
sbuild_id);

if (asprintf(&kallsyms_allocated_filename,
"%s/.debug/[kernel.kallsyms]/%s",
getenv("HOME"), sbuild_id) != -1) {
if (access(kallsyms_filename, F_OK)) {
kallsyms_filename = kallsyms_allocated_filename;
goto do_kallsyms;
}
getenv("HOME"), sbuild_id) == -1)
return -1;

if (access(kallsyms_filename, F_OK)) {
free(kallsyms_allocated_filename);
kallsyms_allocated_filename = NULL;
return -1;
}

goto do_vmlinux;
}

if (self->long_name[0] == '[') {
kallsyms_filename = kallsyms_allocated_filename;
} else {
/*
* Last resort, if we don't have a build-id and couldn't find
* any vmlinux file, try the running kernel kallsyms table.
*/
kallsyms_filename = "/proc/kallsyms";
goto do_kallsyms;
}

do_vmlinux:
err = dso__load_vmlinux(self, map, session, self->long_name, filter);
if (err <= 0) {
if (self->has_build_id)
return -1;

pr_info("The file %s cannot be used, "
"trying to use /proc/kallsyms...", self->long_name);
do_kallsyms:
err = dso__load_kallsyms(self, kallsyms_filename, map, session, filter);
if (err > 0 && kallsyms_filename == NULL)
dso__set_long_name(self, strdup("[kernel.kallsyms]"));
free(kallsyms_allocated_filename);
}
err = dso__load_kallsyms(self, kallsyms_filename, map, session, filter);
free(kallsyms_allocated_filename);

out_try_fixup:
if (err > 0) {
out_fixup:
if (kallsyms_filename == NULL)
dso__set_long_name(self, strdup("[kernel.kallsyms]"));
map__fixup_start(map);
map__fixup_end(map);
}
Expand Down

0 comments on commit eba4fff

Please sign in to comment.