diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-09-29 13:04:03 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-09-29 13:04:03 -0400 |
commit | cac6653529eeac9b661fc8342c47d849c3adb085 (patch) | |
tree | c65a3efd8149d065611b570fa330c67798fe3745 | |
parent | b97b869a83318c473aa5fce8dcd45edb0275004e (diff) | |
parent | 14951f22f1cc8375ead345d2ca08455e91f2152b (diff) |
Merge branch 'perf-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull perf revert from Ingo Molnar:
"This fixes the 'perf top' regression Markus Trippelsdorf reported"
* 'perf-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
Revert "perf symbols: Demangle cloned functions"
-rw-r--r-- | tools/perf/util/symbol-elf.c | 27 |
1 files changed, 1 insertions, 26 deletions
diff --git a/tools/perf/util/symbol-elf.c b/tools/perf/util/symbol-elf.c index d2a888e2e058..a9c829be5216 100644 --- a/tools/perf/util/symbol-elf.c +++ b/tools/perf/util/symbol-elf.c | |||
@@ -928,33 +928,8 @@ int dso__load_sym(struct dso *dso, struct map *map, | |||
928 | * to it... | 928 | * to it... |
929 | */ | 929 | */ |
930 | if (symbol_conf.demangle) { | 930 | if (symbol_conf.demangle) { |
931 | /* | 931 | demangled = bfd_demangle(NULL, elf_name, |
932 | * The demangler doesn't deal with cloned functions. | ||
933 | * XXXX.clone.NUM or similar | ||
934 | * Strip the dot part and readd it later. | ||
935 | */ | ||
936 | char *p = (char *)elf_name, *dot; | ||
937 | dot = strchr(elf_name, '.'); | ||
938 | if (dot) { | ||
939 | p = strdup(elf_name); | ||
940 | if (!p) | ||
941 | goto new_symbol; | ||
942 | dot = strchr(p, '.'); | ||
943 | *dot = 0; | ||
944 | } | ||
945 | |||
946 | demangled = bfd_demangle(NULL, p, | ||
947 | DMGL_PARAMS | DMGL_ANSI); | 932 | DMGL_PARAMS | DMGL_ANSI); |
948 | if (dot) | ||
949 | *dot = '.'; | ||
950 | if (demangled && dot) { | ||
951 | demangled = realloc(demangled, strlen(demangled) + strlen(dot) + 1); | ||
952 | if (!demangled) | ||
953 | goto new_symbol; | ||
954 | strcpy(demangled + (dot - p), dot); | ||
955 | } | ||
956 | if (p != elf_name) | ||
957 | free(p); | ||
958 | if (demangled != NULL) | 933 | if (demangled != NULL) |
959 | elf_name = demangled; | 934 | elf_name = demangled; |
960 | } | 935 | } |