aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/util/annotate.c
diff options
context:
space:
mode:
authorArnaldo Carvalho de Melo <acme@kernel.org>2014-07-29 09:21:58 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2014-07-31 08:58:21 -0400
commit972f393bc8870e236edbd2ea0150a8da85b709e2 (patch)
tree6578c82fca4534588702d0fe146b166749245983 /tools/perf/util/annotate.c
parent5f1c4225f6bcb20cc004b271dc72b96d0da29e9e (diff)
perf symbols: Make sure --symfs usage includes the path separator
Minchan reported that perf failed to load vmlinux if --symfs argument doesn't end with '/' character. Fix it by making sure that the '/' path separator is used when composing pathnames with a --symfs provided directory name. Reported-by: Minchan Kim <minchan@kernel.org> Cc: David Ahern <dsahern@gmail.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Minchan Kim <minchan@kernel.org> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Link: http://lkml.kernel.org/n/tip-8n4s6b6zvsez5ktanw006125@git.kernel.org 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.c9
1 files changed, 3 insertions, 6 deletions
diff --git a/tools/perf/util/annotate.c b/tools/perf/util/annotate.c
index 809b4c50beae..7745fec01a6b 100644
--- a/tools/perf/util/annotate.c
+++ b/tools/perf/util/annotate.c
@@ -899,10 +899,8 @@ int symbol__annotate(struct symbol *sym, struct map *map, size_t privsize)
899 struct kcore_extract kce; 899 struct kcore_extract kce;
900 bool delete_extract = false; 900 bool delete_extract = false;
901 901
902 if (filename) { 902 if (filename)
903 snprintf(symfs_filename, sizeof(symfs_filename), "%s%s", 903 symbol__join_symfs(symfs_filename, filename);
904 symbol_conf.symfs, filename);
905 }
906 904
907 if (filename == NULL) { 905 if (filename == NULL) {
908 if (dso->has_build_id) { 906 if (dso->has_build_id) {
@@ -922,8 +920,7 @@ fallback:
922 * DSO is the same as when 'perf record' ran. 920 * DSO is the same as when 'perf record' ran.
923 */ 921 */
924 filename = (char *)dso->long_name; 922 filename = (char *)dso->long_name;
925 snprintf(symfs_filename, sizeof(symfs_filename), "%s%s", 923 symbol__join_symfs(symfs_filename, filename);
926 symbol_conf.symfs, filename);
927 free_filename = false; 924 free_filename = false;
928 } 925 }
929 926