diff options
author | Cody P Schafer <cody@linux.vnet.ibm.com> | 2012-08-10 18:22:58 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2012-08-13 13:33:01 -0400 |
commit | 005f92947a0da7eb47b0f1ff611f8fc3d7ab4751 (patch) | |
tree | 1cc08d9b9a5a4e7048a1d11a260a581917328ce8 | |
parent | b68e2f919c6d3a0422239c98673c35ff503e52fb (diff) |
perf symbols: Set symtab_type in dso__load_sym
In certain cases, dso__load requires dso->symbol_type to be set prior to
calling it. With the introduction of symsrc*, the symtab_type is now
stored in a symsrc which is then passed to dso__load_sym().
Change dso__load_sym() to use the symtab_type from them symsrc (setting
dso->symtab_type as well).
Setup for later patch
"perf symbols: Use both runtime and debug images"
Signed-off-by: Cody P Schafer <cody@linux.vnet.ibm.com>
Cc: David Hansen <dave@linux.vnet.ibm.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Matt Hellsley <matthltc@us.ibm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Sukadev Bhattiprolu <sukadev@linux.vnet.ibm.com>
Link: http://lkml.kernel.org/r/1344637382-22789-13-git-send-email-cody@linux.vnet.ibm.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
-rw-r--r-- | tools/perf/util/symbol-elf.c | 2 | ||||
-rw-r--r-- | tools/perf/util/symbol.c | 13 |
2 files changed, 9 insertions, 6 deletions
diff --git a/tools/perf/util/symbol-elf.c b/tools/perf/util/symbol-elf.c index 6974b2a44ee7..3a9c38a39bc9 100644 --- a/tools/perf/util/symbol-elf.c +++ b/tools/perf/util/symbol-elf.c | |||
@@ -645,6 +645,8 @@ int dso__load_sym(struct dso *dso, struct map *map, struct symsrc *ss, | |||
645 | int nr = 0; | 645 | int nr = 0; |
646 | size_t opdidx = 0; | 646 | size_t opdidx = 0; |
647 | 647 | ||
648 | dso->symtab_type = ss->type; | ||
649 | |||
648 | elf = ss->elf; | 650 | elf = ss->elf; |
649 | ehdr = ss->ehdr; | 651 | ehdr = ss->ehdr; |
650 | sec = ss->symtab; | 652 | sec = ss->symtab; |
diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c index afec3f048a94..2b3495a93fb6 100644 --- a/tools/perf/util/symbol.c +++ b/tools/perf/util/symbol.c | |||
@@ -1079,14 +1079,14 @@ int dso__load(struct dso *dso, struct map *map, symbol_filter_t filter) | |||
1079 | restart: | 1079 | restart: |
1080 | for (i = 0; i < DSO_BINARY_TYPE__SYMTAB_CNT; i++) { | 1080 | for (i = 0; i < DSO_BINARY_TYPE__SYMTAB_CNT; i++) { |
1081 | 1081 | ||
1082 | dso->symtab_type = binary_type_symtab[i]; | 1082 | enum dso_binary_type symtab_type = binary_type_symtab[i]; |
1083 | 1083 | ||
1084 | if (dso__binary_type_file(dso, dso->symtab_type, | 1084 | if (dso__binary_type_file(dso, symtab_type, |
1085 | root_dir, name, PATH_MAX)) | 1085 | root_dir, name, PATH_MAX)) |
1086 | continue; | 1086 | continue; |
1087 | 1087 | ||
1088 | /* Name is now the name of the next image to try */ | 1088 | /* Name is now the name of the next image to try */ |
1089 | if (symsrc__init(&ss, dso, name, dso->symtab_type) < 0) | 1089 | if (symsrc__init(&ss, dso, name, symtab_type) < 0) |
1090 | continue; | 1090 | continue; |
1091 | 1091 | ||
1092 | ret = dso__load_sym(dso, map, &ss, filter, 0, | 1092 | ret = dso__load_sym(dso, map, &ss, filter, 0, |
@@ -1361,16 +1361,17 @@ int dso__load_vmlinux(struct dso *dso, struct map *map, | |||
1361 | int err = -1; | 1361 | int err = -1; |
1362 | struct symsrc ss; | 1362 | struct symsrc ss; |
1363 | char symfs_vmlinux[PATH_MAX]; | 1363 | char symfs_vmlinux[PATH_MAX]; |
1364 | enum dso_binary_type symtab_type; | ||
1364 | 1365 | ||
1365 | snprintf(symfs_vmlinux, sizeof(symfs_vmlinux), "%s%s", | 1366 | snprintf(symfs_vmlinux, sizeof(symfs_vmlinux), "%s%s", |
1366 | symbol_conf.symfs, vmlinux); | 1367 | symbol_conf.symfs, vmlinux); |
1367 | 1368 | ||
1368 | if (dso->kernel == DSO_TYPE_GUEST_KERNEL) | 1369 | if (dso->kernel == DSO_TYPE_GUEST_KERNEL) |
1369 | dso->symtab_type = DSO_BINARY_TYPE__GUEST_VMLINUX; | 1370 | symtab_type = DSO_BINARY_TYPE__GUEST_VMLINUX; |
1370 | else | 1371 | else |
1371 | dso->symtab_type = DSO_BINARY_TYPE__VMLINUX; | 1372 | symtab_type = DSO_BINARY_TYPE__VMLINUX; |
1372 | 1373 | ||
1373 | if (symsrc__init(&ss, dso, symfs_vmlinux, dso->symtab_type)) | 1374 | if (symsrc__init(&ss, dso, symfs_vmlinux, symtab_type)) |
1374 | return -1; | 1375 | return -1; |
1375 | 1376 | ||
1376 | err = dso__load_sym(dso, map, &ss, filter, 0, 0); | 1377 | err = dso__load_sym(dso, map, &ss, filter, 0, 0); |