aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/util/annotate.c
diff options
context:
space:
mode:
authorTaeung Song <treeze.taeung@gmail.com>2017-03-27 03:10:36 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2017-03-27 13:58:20 -0400
commit6ebd2547dd24daf95a21b2bc59931de8502afcc3 (patch)
treee98731e942523a48a48b7220481a2826466eb009 /tools/perf/util/annotate.c
parent5dfa210e407d0fedf746958bff206995bd46570d (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.c10
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)) {
1329fallback: 1336fallback:
@@ -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