diff options
author | Taeung Song <treeze.taeung@gmail.com> | 2017-03-27 03:10:36 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2017-03-27 13:58:20 -0400 |
commit | 6ebd2547dd24daf95a21b2bc59931de8502afcc3 (patch) | |
tree | e98731e942523a48a48b7220481a2826466eb009 /tools/perf/util/annotate.c | |
parent | 5dfa210e407d0fedf746958bff206995bd46570d (diff) |
perf annotate: Fix a bug following symbolic link of a build-id file
It is wrong way to read link name from a build-id file. Because a
build-id file is not anymore a symbolic link but build-id directory of
it is symbolic link, so fix it.
For example, if build-id file name gotten from
dso__build_id_filename() is as below,
/root/.debug/.build-id/4f/75c7d197c951659d1c1b8b5fd49bcdf8f3f8b1/elf
To correctly read link name of build-id, use the build-id dir path that
is a symbolic link, instead of the above build-id file name like below.
/root/.debug/.build-id/4f/75c7d197c951659d1c1b8b5fd49bcdf8f3f8b1
Signed-off-by: Taeung Song <treeze.taeung@gmail.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Masami Hiramatsu <mhiramat@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Wang Nan <wangnan0@huawei.com>
Link: http://lkml.kernel.org/r/1490598638-13947-2-git-send-email-treeze.taeung@gmail.com
Fixes: 01412261d994 ("perf buildid-cache: Use path/to/bin/buildid/elf instead of path/to/bin/buildid")
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/annotate.c')
-rw-r--r-- | tools/perf/util/annotate.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/tools/perf/util/annotate.c b/tools/perf/util/annotate.c index 3d0263e5d1db..6dc9148b9b84 100644 --- a/tools/perf/util/annotate.c +++ b/tools/perf/util/annotate.c | |||
@@ -1307,6 +1307,7 @@ static int dso__disassemble_filename(struct dso *dso, char *filename, size_t fil | |||
1307 | { | 1307 | { |
1308 | char linkname[PATH_MAX]; | 1308 | char linkname[PATH_MAX]; |
1309 | char *build_id_filename; | 1309 | char *build_id_filename; |
1310 | char *build_id_path = NULL; | ||
1310 | 1311 | ||
1311 | if (dso->symtab_type == DSO_BINARY_TYPE__KALLSYMS && | 1312 | if (dso->symtab_type == DSO_BINARY_TYPE__KALLSYMS && |
1312 | !dso__is_kcore(dso)) | 1313 | !dso__is_kcore(dso)) |
@@ -1322,8 +1323,14 @@ static int dso__disassemble_filename(struct dso *dso, char *filename, size_t fil | |||
1322 | goto fallback; | 1323 | goto fallback; |
1323 | } | 1324 | } |
1324 | 1325 | ||
1326 | build_id_path = strdup(filename); | ||
1327 | if (!build_id_path) | ||
1328 | return -1; | ||
1329 | |||
1330 | dirname(build_id_path); | ||
1331 | |||
1325 | if (dso__is_kcore(dso) || | 1332 | if (dso__is_kcore(dso) || |
1326 | readlink(filename, linkname, sizeof(linkname)) < 0 || | 1333 | readlink(build_id_path, linkname, sizeof(linkname)) < 0 || |
1327 | strstr(linkname, DSO__NAME_KALLSYMS) || | 1334 | strstr(linkname, DSO__NAME_KALLSYMS) || |
1328 | access(filename, R_OK)) { | 1335 | access(filename, R_OK)) { |
1329 | fallback: | 1336 | fallback: |
@@ -1335,6 +1342,7 @@ fallback: | |||
1335 | __symbol__join_symfs(filename, filename_size, dso->long_name); | 1342 | __symbol__join_symfs(filename, filename_size, dso->long_name); |
1336 | } | 1343 | } |
1337 | 1344 | ||
1345 | free(build_id_path); | ||
1338 | return 0; | 1346 | return 0; |
1339 | } | 1347 | } |
1340 | 1348 | ||