diff options
Diffstat (limited to 'tools/perf/util/symbol.c')
-rw-r--r-- | tools/perf/util/symbol.c | 73 |
1 files changed, 34 insertions, 39 deletions
diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c index 13677b5dbe5e..cf2c7f778868 100644 --- a/tools/perf/util/symbol.c +++ b/tools/perf/util/symbol.c | |||
@@ -26,6 +26,7 @@ static void dsos__add(struct dso *dso); | |||
26 | static struct dso *dsos__find(const char *name); | 26 | static struct dso *dsos__find(const char *name); |
27 | static struct map *map__new2(u64 start, struct dso *dso); | 27 | static struct map *map__new2(u64 start, struct dso *dso); |
28 | static void kernel_maps__insert(struct map *map); | 28 | static void kernel_maps__insert(struct map *map); |
29 | unsigned int symbol__priv_size; | ||
29 | 30 | ||
30 | static struct rb_root kernel_maps; | 31 | static struct rb_root kernel_maps; |
31 | 32 | ||
@@ -75,18 +76,17 @@ static void kernel_maps__fixup_end(void) | |||
75 | } | 76 | } |
76 | } | 77 | } |
77 | 78 | ||
78 | static struct symbol *symbol__new(u64 start, u64 len, const char *name, | 79 | static struct symbol *symbol__new(u64 start, u64 len, const char *name) |
79 | unsigned int priv_size) | ||
80 | { | 80 | { |
81 | size_t namelen = strlen(name) + 1; | 81 | size_t namelen = strlen(name) + 1; |
82 | struct symbol *self = calloc(1, priv_size + sizeof(*self) + namelen); | 82 | struct symbol *self = calloc(1, (symbol__priv_size + |
83 | 83 | sizeof(*self) + namelen)); | |
84 | if (!self) | 84 | if (!self) |
85 | return NULL; | 85 | return NULL; |
86 | 86 | ||
87 | if (priv_size) { | 87 | if (symbol__priv_size) { |
88 | memset(self, 0, priv_size); | 88 | memset(self, 0, symbol__priv_size); |
89 | self = ((void *)self) + priv_size; | 89 | self = ((void *)self) + symbol__priv_size; |
90 | } | 90 | } |
91 | self->start = start; | 91 | self->start = start; |
92 | self->end = len ? start + len - 1 : start; | 92 | self->end = len ? start + len - 1 : start; |
@@ -98,9 +98,9 @@ static struct symbol *symbol__new(u64 start, u64 len, const char *name, | |||
98 | return self; | 98 | return self; |
99 | } | 99 | } |
100 | 100 | ||
101 | static void symbol__delete(struct symbol *self, unsigned int priv_size) | 101 | static void symbol__delete(struct symbol *self) |
102 | { | 102 | { |
103 | free(((void *)self) - priv_size); | 103 | free(((void *)self) - symbol__priv_size); |
104 | } | 104 | } |
105 | 105 | ||
106 | static size_t symbol__fprintf(struct symbol *self, FILE *fp) | 106 | static size_t symbol__fprintf(struct symbol *self, FILE *fp) |
@@ -109,7 +109,7 @@ static size_t symbol__fprintf(struct symbol *self, FILE *fp) | |||
109 | self->start, self->end, self->name); | 109 | self->start, self->end, self->name); |
110 | } | 110 | } |
111 | 111 | ||
112 | struct dso *dso__new(const char *name, unsigned int sym_priv_size) | 112 | struct dso *dso__new(const char *name) |
113 | { | 113 | { |
114 | struct dso *self = malloc(sizeof(*self) + strlen(name) + 1); | 114 | struct dso *self = malloc(sizeof(*self) + strlen(name) + 1); |
115 | 115 | ||
@@ -118,7 +118,6 @@ struct dso *dso__new(const char *name, unsigned int sym_priv_size) | |||
118 | self->long_name = self->name; | 118 | self->long_name = self->name; |
119 | self->short_name = self->name; | 119 | self->short_name = self->name; |
120 | self->syms = RB_ROOT; | 120 | self->syms = RB_ROOT; |
121 | self->sym_priv_size = sym_priv_size; | ||
122 | self->find_symbol = dso__find_symbol; | 121 | self->find_symbol = dso__find_symbol; |
123 | self->slen_calculated = 0; | 122 | self->slen_calculated = 0; |
124 | self->origin = DSO__ORIG_NOT_FOUND; | 123 | self->origin = DSO__ORIG_NOT_FOUND; |
@@ -136,7 +135,7 @@ static void dso__delete_symbols(struct dso *self) | |||
136 | pos = rb_entry(next, struct symbol, rb_node); | 135 | pos = rb_entry(next, struct symbol, rb_node); |
137 | next = rb_next(&pos->rb_node); | 136 | next = rb_next(&pos->rb_node); |
138 | rb_erase(&pos->rb_node, &self->syms); | 137 | rb_erase(&pos->rb_node, &self->syms); |
139 | symbol__delete(pos, self->sym_priv_size); | 138 | symbol__delete(pos); |
140 | } | 139 | } |
141 | } | 140 | } |
142 | 141 | ||
@@ -250,8 +249,7 @@ static int kernel_maps__load_all_kallsyms(void) | |||
250 | /* | 249 | /* |
251 | * Will fix up the end later, when we have all symbols sorted. | 250 | * Will fix up the end later, when we have all symbols sorted. |
252 | */ | 251 | */ |
253 | sym = symbol__new(start, 0, symbol_name, | 252 | sym = symbol__new(start, 0, symbol_name); |
254 | kernel_map->dso->sym_priv_size); | ||
255 | 253 | ||
256 | if (sym == NULL) | 254 | if (sym == NULL) |
257 | goto out_delete_line; | 255 | goto out_delete_line; |
@@ -317,8 +315,7 @@ static int kernel_maps__split_kallsyms(symbol_filter_t filter, int use_modules) | |||
317 | snprintf(dso_name, sizeof(dso_name), "[kernel].%d", | 315 | snprintf(dso_name, sizeof(dso_name), "[kernel].%d", |
318 | kernel_range++); | 316 | kernel_range++); |
319 | 317 | ||
320 | dso = dso__new(dso_name, | 318 | dso = dso__new(dso_name); |
321 | kernel_map->dso->sym_priv_size); | ||
322 | if (dso == NULL) | 319 | if (dso == NULL) |
323 | return -1; | 320 | return -1; |
324 | 321 | ||
@@ -336,7 +333,7 @@ static int kernel_maps__split_kallsyms(symbol_filter_t filter, int use_modules) | |||
336 | if (filter && filter(map, pos)) { | 333 | if (filter && filter(map, pos)) { |
337 | delete_symbol: | 334 | delete_symbol: |
338 | rb_erase(&pos->rb_node, &kernel_map->dso->syms); | 335 | rb_erase(&pos->rb_node, &kernel_map->dso->syms); |
339 | symbol__delete(pos, kernel_map->dso->sym_priv_size); | 336 | symbol__delete(pos); |
340 | } else { | 337 | } else { |
341 | if (map != kernel_map) { | 338 | if (map != kernel_map) { |
342 | rb_erase(&pos->rb_node, &kernel_map->dso->syms); | 339 | rb_erase(&pos->rb_node, &kernel_map->dso->syms); |
@@ -417,14 +414,13 @@ static int dso__load_perf_map(struct dso *self, struct map *map, | |||
417 | if (len + 2 >= line_len) | 414 | if (len + 2 >= line_len) |
418 | continue; | 415 | continue; |
419 | 416 | ||
420 | sym = symbol__new(start, size, line + len, | 417 | sym = symbol__new(start, size, line + len); |
421 | self->sym_priv_size); | ||
422 | 418 | ||
423 | if (sym == NULL) | 419 | if (sym == NULL) |
424 | goto out_delete_line; | 420 | goto out_delete_line; |
425 | 421 | ||
426 | if (filter && filter(map, sym)) | 422 | if (filter && filter(map, sym)) |
427 | symbol__delete(sym, self->sym_priv_size); | 423 | symbol__delete(sym); |
428 | else { | 424 | else { |
429 | dso__insert_symbol(self, sym); | 425 | dso__insert_symbol(self, sym); |
430 | nr_syms++; | 426 | nr_syms++; |
@@ -616,7 +612,7 @@ static int dso__synthesize_plt_symbols(struct dso *self) | |||
616 | "%s@plt", elf_sym__name(&sym, symstrs)); | 612 | "%s@plt", elf_sym__name(&sym, symstrs)); |
617 | 613 | ||
618 | f = symbol__new(plt_offset, shdr_plt.sh_entsize, | 614 | f = symbol__new(plt_offset, shdr_plt.sh_entsize, |
619 | sympltname, self->sym_priv_size); | 615 | sympltname); |
620 | if (!f) | 616 | if (!f) |
621 | goto out_elf_end; | 617 | goto out_elf_end; |
622 | 618 | ||
@@ -634,7 +630,7 @@ static int dso__synthesize_plt_symbols(struct dso *self) | |||
634 | "%s@plt", elf_sym__name(&sym, symstrs)); | 630 | "%s@plt", elf_sym__name(&sym, symstrs)); |
635 | 631 | ||
636 | f = symbol__new(plt_offset, shdr_plt.sh_entsize, | 632 | f = symbol__new(plt_offset, shdr_plt.sh_entsize, |
637 | sympltname, self->sym_priv_size); | 633 | sympltname); |
638 | if (!f) | 634 | if (!f) |
639 | goto out_elf_end; | 635 | goto out_elf_end; |
640 | 636 | ||
@@ -769,7 +765,7 @@ static int dso__load_sym(struct dso *self, struct map *map, const char *name, | |||
769 | if (kmodule) | 765 | if (kmodule) |
770 | start += map->start + shdr.sh_offset; | 766 | start += map->start + shdr.sh_offset; |
771 | 767 | ||
772 | curr_dso = dso__new(dso_name, self->sym_priv_size); | 768 | curr_dso = dso__new(dso_name); |
773 | if (curr_dso == NULL) | 769 | if (curr_dso == NULL) |
774 | goto out_elf_end; | 770 | goto out_elf_end; |
775 | curr_map = map__new2(start, curr_dso); | 771 | curr_map = map__new2(start, curr_dso); |
@@ -803,14 +799,13 @@ static int dso__load_sym(struct dso *self, struct map *map, const char *name, | |||
803 | if (demangled != NULL) | 799 | if (demangled != NULL) |
804 | elf_name = demangled; | 800 | elf_name = demangled; |
805 | new_symbol: | 801 | new_symbol: |
806 | f = symbol__new(sym.st_value, sym.st_size, elf_name, | 802 | f = symbol__new(sym.st_value, sym.st_size, elf_name); |
807 | curr_dso->sym_priv_size); | ||
808 | free(demangled); | 803 | free(demangled); |
809 | if (!f) | 804 | if (!f) |
810 | goto out_elf_end; | 805 | goto out_elf_end; |
811 | 806 | ||
812 | if (filter && filter(curr_map, f)) | 807 | if (filter && filter(curr_map, f)) |
813 | symbol__delete(f, curr_dso->sym_priv_size); | 808 | symbol__delete(f); |
814 | else { | 809 | else { |
815 | dso__insert_symbol(curr_dso, f); | 810 | dso__insert_symbol(curr_dso, f); |
816 | nr++; | 811 | nr++; |
@@ -1141,7 +1136,7 @@ static struct map *map__new2(u64 start, struct dso *dso) | |||
1141 | return self; | 1136 | return self; |
1142 | } | 1137 | } |
1143 | 1138 | ||
1144 | static int dsos__load_modules(unsigned int sym_priv_size) | 1139 | static int dsos__load_modules(void) |
1145 | { | 1140 | { |
1146 | char *line = NULL; | 1141 | char *line = NULL; |
1147 | size_t n; | 1142 | size_t n; |
@@ -1180,7 +1175,7 @@ static int dsos__load_modules(unsigned int sym_priv_size) | |||
1180 | *sep = '\0'; | 1175 | *sep = '\0'; |
1181 | 1176 | ||
1182 | snprintf(name, sizeof(name), "[%s]", line); | 1177 | snprintf(name, sizeof(name), "[%s]", line); |
1183 | dso = dso__new(name, sym_priv_size); | 1178 | dso = dso__new(name); |
1184 | 1179 | ||
1185 | if (dso == NULL) | 1180 | if (dso == NULL) |
1186 | goto out_delete_line; | 1181 | goto out_delete_line; |
@@ -1224,11 +1219,11 @@ static int dso__load_vmlinux(struct dso *self, struct map *map, | |||
1224 | return err; | 1219 | return err; |
1225 | } | 1220 | } |
1226 | 1221 | ||
1227 | int dsos__load_kernel(const char *vmlinux, unsigned int sym_priv_size, | 1222 | int dsos__load_kernel(const char *vmlinux, symbol_filter_t filter, |
1228 | symbol_filter_t filter, int use_modules) | 1223 | int use_modules) |
1229 | { | 1224 | { |
1230 | int err = -1; | 1225 | int err = -1; |
1231 | struct dso *dso = dso__new(vmlinux, sym_priv_size); | 1226 | struct dso *dso = dso__new(vmlinux); |
1232 | 1227 | ||
1233 | if (dso == NULL) | 1228 | if (dso == NULL) |
1234 | return -1; | 1229 | return -1; |
@@ -1240,7 +1235,7 @@ int dsos__load_kernel(const char *vmlinux, unsigned int sym_priv_size, | |||
1240 | 1235 | ||
1241 | kernel_map->map_ip = kernel_map->unmap_ip = identity__map_ip; | 1236 | kernel_map->map_ip = kernel_map->unmap_ip = identity__map_ip; |
1242 | 1237 | ||
1243 | if (use_modules && dsos__load_modules(sym_priv_size) < 0) { | 1238 | if (use_modules && dsos__load_modules() < 0) { |
1244 | pr_warning("Failed to load list of modules in use! " | 1239 | pr_warning("Failed to load list of modules in use! " |
1245 | "Continuing...\n"); | 1240 | "Continuing...\n"); |
1246 | use_modules = 0; | 1241 | use_modules = 0; |
@@ -1312,12 +1307,12 @@ static struct dso *dsos__find(const char *name) | |||
1312 | return NULL; | 1307 | return NULL; |
1313 | } | 1308 | } |
1314 | 1309 | ||
1315 | struct dso *dsos__findnew(const char *name, unsigned int sym_priv_size) | 1310 | struct dso *dsos__findnew(const char *name) |
1316 | { | 1311 | { |
1317 | struct dso *dso = dsos__find(name); | 1312 | struct dso *dso = dsos__find(name); |
1318 | 1313 | ||
1319 | if (!dso) { | 1314 | if (!dso) { |
1320 | dso = dso__new(name, sym_priv_size); | 1315 | dso = dso__new(name); |
1321 | if (dso != NULL) | 1316 | if (dso != NULL) |
1322 | dsos__add(dso); | 1317 | dsos__add(dso); |
1323 | } | 1318 | } |
@@ -1333,13 +1328,12 @@ void dsos__fprintf(FILE *fp) | |||
1333 | dso__fprintf(pos, fp); | 1328 | dso__fprintf(pos, fp); |
1334 | } | 1329 | } |
1335 | 1330 | ||
1336 | int load_kernel(unsigned int sym_priv_size, symbol_filter_t filter) | 1331 | int load_kernel(symbol_filter_t filter) |
1337 | { | 1332 | { |
1338 | if (dsos__load_kernel(vmlinux_name, sym_priv_size, filter, | 1333 | if (dsos__load_kernel(vmlinux_name, filter, modules) <= 0) |
1339 | modules) <= 0) | ||
1340 | return -1; | 1334 | return -1; |
1341 | 1335 | ||
1342 | vdso = dso__new("[vdso]", 0); | 1336 | vdso = dso__new("[vdso]"); |
1343 | if (!vdso) | 1337 | if (!vdso) |
1344 | return -1; | 1338 | return -1; |
1345 | 1339 | ||
@@ -1348,7 +1342,8 @@ int load_kernel(unsigned int sym_priv_size, symbol_filter_t filter) | |||
1348 | return 0; | 1342 | return 0; |
1349 | } | 1343 | } |
1350 | 1344 | ||
1351 | void symbol__init(void) | 1345 | void symbol__init(unsigned int priv_size) |
1352 | { | 1346 | { |
1353 | elf_version(EV_CURRENT); | 1347 | elf_version(EV_CURRENT); |
1348 | symbol__priv_size = priv_size; | ||
1354 | } | 1349 | } |