diff options
author | Arnaldo Carvalho de Melo <acme@kernel.org> | 2014-07-29 09:21:58 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2014-07-31 08:58:21 -0400 |
commit | 972f393bc8870e236edbd2ea0150a8da85b709e2 (patch) | |
tree | 6578c82fca4534588702d0fe146b166749245983 /tools/perf/util/annotate.c | |
parent | 5f1c4225f6bcb20cc004b271dc72b96d0da29e9e (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.c | 9 |
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 | ||