diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2009-11-24 09:05:15 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-11-24 10:37:02 -0500 |
commit | b32d133aec5dc882cf783a293f393bfb3f4379e1 (patch) | |
tree | 41fc56a4aaec8892a235ffd530b36278d147dc4e | |
parent | 7cc017edb9459193d3b581155a14029e4bef0c49 (diff) |
perf symbols: Simplify symbol machinery setup
And also express its configuration toggles via a struct.
Now all one has to do is to call symbol__init(NULL) if the
defaults are OK, or pass a struct symbol_conf pointer with the
desired configuration.
If a tool uses kernel_maps__find_symbol() to look at the kernel
and modules mappings for a symbol but didn't call symbol__init()
first, that will generate a one time warning too, alerting the
subcommand developer that symbol__init() must be called.
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frédéric Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Paul Mackerras <paulus@samba.org>
LKML-Reference: <1259071517-3242-2-git-send-email-acme@infradead.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r-- | tools/perf/builtin-annotate.c | 20 | ||||
-rw-r--r-- | tools/perf/builtin-kmem.c | 2 | ||||
-rw-r--r-- | tools/perf/builtin-report.c | 15 | ||||
-rw-r--r-- | tools/perf/builtin-sched.c | 2 | ||||
-rw-r--r-- | tools/perf/builtin-top.c | 24 | ||||
-rw-r--r-- | tools/perf/builtin-trace.c | 2 | ||||
-rw-r--r-- | tools/perf/util/data_map.c | 8 | ||||
-rw-r--r-- | tools/perf/util/data_map.h | 2 | ||||
-rw-r--r-- | tools/perf/util/header.c | 6 | ||||
-rw-r--r-- | tools/perf/util/include/asm/bug.h | 22 | ||||
-rw-r--r-- | tools/perf/util/symbol.c | 31 | ||||
-rw-r--r-- | tools/perf/util/symbol.h | 11 |
12 files changed, 85 insertions, 60 deletions
diff --git a/tools/perf/builtin-annotate.c b/tools/perf/builtin-annotate.c index 59b6123abec2..cd97c2b1cc3b 100644 --- a/tools/perf/builtin-annotate.c +++ b/tools/perf/builtin-annotate.c | |||
@@ -34,11 +34,9 @@ static int input; | |||
34 | static int full_paths; | 34 | static int full_paths; |
35 | 35 | ||
36 | static int print_line; | 36 | static int print_line; |
37 | static bool use_modules; | ||
38 | 37 | ||
39 | static unsigned long page_size; | 38 | static unsigned long page_size; |
40 | static unsigned long mmap_window = 32; | 39 | static unsigned long mmap_window = 32; |
41 | const char *vmlinux_name; | ||
42 | 40 | ||
43 | struct sym_hist { | 41 | struct sym_hist { |
44 | u64 sum; | 42 | u64 sum; |
@@ -56,6 +54,11 @@ struct sym_priv { | |||
56 | struct sym_ext *ext; | 54 | struct sym_ext *ext; |
57 | }; | 55 | }; |
58 | 56 | ||
57 | static struct symbol_conf symbol_conf = { | ||
58 | .priv_size = sizeof(struct sym_priv), | ||
59 | .try_vmlinux_path = true, | ||
60 | }; | ||
61 | |||
59 | static const char *sym_hist_filter; | 62 | static const char *sym_hist_filter; |
60 | 63 | ||
61 | static int symbol_filter(struct map *map __used, struct symbol *sym) | 64 | static int symbol_filter(struct map *map __used, struct symbol *sym) |
@@ -586,11 +589,6 @@ static int __cmd_annotate(void) | |||
586 | exit(0); | 589 | exit(0); |
587 | } | 590 | } |
588 | 591 | ||
589 | if (kernel_maps__init(vmlinux_name, true, use_modules) < 0) { | ||
590 | pr_err("failed to create kernel maps for symbol resolution\b"); | ||
591 | return -1; | ||
592 | } | ||
593 | |||
594 | remap: | 592 | remap: |
595 | buf = (char *)mmap(NULL, page_size * mmap_window, PROT_READ, | 593 | buf = (char *)mmap(NULL, page_size * mmap_window, PROT_READ, |
596 | MAP_SHARED, input, offset); | 594 | MAP_SHARED, input, offset); |
@@ -691,8 +689,9 @@ static const struct option options[] = { | |||
691 | "be more verbose (show symbol address, etc)"), | 689 | "be more verbose (show symbol address, etc)"), |
692 | OPT_BOOLEAN('D', "dump-raw-trace", &dump_trace, | 690 | OPT_BOOLEAN('D', "dump-raw-trace", &dump_trace, |
693 | "dump raw trace in ASCII"), | 691 | "dump raw trace in ASCII"), |
694 | OPT_STRING('k', "vmlinux", &vmlinux_name, "file", "vmlinux pathname"), | 692 | OPT_STRING('k', "vmlinux", &symbol_conf.vmlinux_name, |
695 | OPT_BOOLEAN('m', "modules", &use_modules, | 693 | "file", "vmlinux pathname"), |
694 | OPT_BOOLEAN('m', "modules", &symbol_conf.use_modules, | ||
696 | "load module symbols - WARNING: use only with -k and LIVE kernel"), | 695 | "load module symbols - WARNING: use only with -k and LIVE kernel"), |
697 | OPT_BOOLEAN('l', "print-line", &print_line, | 696 | OPT_BOOLEAN('l', "print-line", &print_line, |
698 | "print matching source lines (may be slow)"), | 697 | "print matching source lines (may be slow)"), |
@@ -718,7 +717,8 @@ static void setup_sorting(void) | |||
718 | 717 | ||
719 | int cmd_annotate(int argc, const char **argv, const char *prefix __used) | 718 | int cmd_annotate(int argc, const char **argv, const char *prefix __used) |
720 | { | 719 | { |
721 | symbol__init(sizeof(struct sym_priv)); | 720 | if (symbol__init(&symbol_conf) < 0) |
721 | return -1; | ||
722 | 722 | ||
723 | page_size = getpagesize(); | 723 | page_size = getpagesize(); |
724 | 724 | ||
diff --git a/tools/perf/builtin-kmem.c b/tools/perf/builtin-kmem.c index 173d6db42ecb..330dbc762f9e 100644 --- a/tools/perf/builtin-kmem.c +++ b/tools/perf/builtin-kmem.c | |||
@@ -412,7 +412,7 @@ static int read_events(void) | |||
412 | register_idle_thread(); | 412 | register_idle_thread(); |
413 | register_perf_file_handler(&file_handler); | 413 | register_perf_file_handler(&file_handler); |
414 | 414 | ||
415 | return mmap_dispatch_perf_file(&header, input_name, NULL, false, 0, 0, | 415 | return mmap_dispatch_perf_file(&header, input_name, 0, 0, |
416 | &cwdlen, &cwd); | 416 | &cwdlen, &cwd); |
417 | } | 417 | } |
418 | 418 | ||
diff --git a/tools/perf/builtin-report.c b/tools/perf/builtin-report.c index 1826be719b58..0ee3d05a0409 100644 --- a/tools/perf/builtin-report.c +++ b/tools/perf/builtin-report.c | |||
@@ -39,7 +39,6 @@ static char *dso_list_str, *comm_list_str, *sym_list_str, | |||
39 | static struct strlist *dso_list, *comm_list, *sym_list; | 39 | static struct strlist *dso_list, *comm_list, *sym_list; |
40 | 40 | ||
41 | static int force; | 41 | static int force; |
42 | static bool use_modules; | ||
43 | 42 | ||
44 | static int full_paths; | 43 | static int full_paths; |
45 | static int show_nr_samples; | 44 | static int show_nr_samples; |
@@ -53,12 +52,13 @@ static char *pretty_printing_style = default_pretty_printing_style; | |||
53 | static int exclude_other = 1; | 52 | static int exclude_other = 1; |
54 | 53 | ||
55 | static char callchain_default_opt[] = "fractal,0.5"; | 54 | static char callchain_default_opt[] = "fractal,0.5"; |
56 | const char *vmlinux_name; | ||
57 | 55 | ||
58 | static struct perf_header *header; | 56 | static struct perf_header *header; |
59 | 57 | ||
60 | static u64 sample_type; | 58 | static u64 sample_type; |
61 | 59 | ||
60 | struct symbol_conf symbol_conf; | ||
61 | |||
62 | 62 | ||
63 | static size_t | 63 | static size_t |
64 | callchain__fprintf_left_margin(FILE *fp, int left_margin) | 64 | callchain__fprintf_left_margin(FILE *fp, int left_margin) |
@@ -865,8 +865,7 @@ static int __cmd_report(void) | |||
865 | 865 | ||
866 | register_perf_file_handler(&file_handler); | 866 | register_perf_file_handler(&file_handler); |
867 | 867 | ||
868 | ret = mmap_dispatch_perf_file(&header, input_name, vmlinux_name, | 868 | ret = mmap_dispatch_perf_file(&header, input_name, force, |
869 | !vmlinux_name, force, | ||
870 | full_paths, &cwdlen, &cwd); | 869 | full_paths, &cwdlen, &cwd); |
871 | if (ret) | 870 | if (ret) |
872 | return ret; | 871 | return ret; |
@@ -963,9 +962,10 @@ static const struct option options[] = { | |||
963 | "be more verbose (show symbol address, etc)"), | 962 | "be more verbose (show symbol address, etc)"), |
964 | OPT_BOOLEAN('D', "dump-raw-trace", &dump_trace, | 963 | OPT_BOOLEAN('D', "dump-raw-trace", &dump_trace, |
965 | "dump raw trace in ASCII"), | 964 | "dump raw trace in ASCII"), |
966 | OPT_STRING('k', "vmlinux", &vmlinux_name, "file", "vmlinux pathname"), | 965 | OPT_STRING('k', "vmlinux", &symbol_conf.vmlinux_name, |
966 | "file", "vmlinux pathname"), | ||
967 | OPT_BOOLEAN('f', "force", &force, "don't complain, do it"), | 967 | OPT_BOOLEAN('f', "force", &force, "don't complain, do it"), |
968 | OPT_BOOLEAN('m', "modules", &use_modules, | 968 | OPT_BOOLEAN('m', "modules", &symbol_conf.use_modules, |
969 | "load module symbols - WARNING: use only with -k and LIVE kernel"), | 969 | "load module symbols - WARNING: use only with -k and LIVE kernel"), |
970 | OPT_BOOLEAN('n', "show-nr-samples", &show_nr_samples, | 970 | OPT_BOOLEAN('n', "show-nr-samples", &show_nr_samples, |
971 | "Show a column with the number of samples"), | 971 | "Show a column with the number of samples"), |
@@ -1035,7 +1035,8 @@ static void setup_list(struct strlist **list, const char *list_str, | |||
1035 | 1035 | ||
1036 | int cmd_report(int argc, const char **argv, const char *prefix __used) | 1036 | int cmd_report(int argc, const char **argv, const char *prefix __used) |
1037 | { | 1037 | { |
1038 | symbol__init(0); | 1038 | if (symbol__init(&symbol_conf) < 0) |
1039 | return -1; | ||
1039 | 1040 | ||
1040 | argc = parse_options(argc, argv, options, report_usage, 0); | 1041 | argc = parse_options(argc, argv, options, report_usage, 0); |
1041 | 1042 | ||
diff --git a/tools/perf/builtin-sched.c b/tools/perf/builtin-sched.c index 260f57a72ee0..dbf089b12def 100644 --- a/tools/perf/builtin-sched.c +++ b/tools/perf/builtin-sched.c | |||
@@ -1718,7 +1718,7 @@ static int read_events(void) | |||
1718 | register_idle_thread(); | 1718 | register_idle_thread(); |
1719 | register_perf_file_handler(&file_handler); | 1719 | register_perf_file_handler(&file_handler); |
1720 | 1720 | ||
1721 | return mmap_dispatch_perf_file(&header, input_name, NULL, false, 0, 0, | 1721 | return mmap_dispatch_perf_file(&header, input_name, 0, 0, |
1722 | &cwdlen, &cwd); | 1722 | &cwdlen, &cwd); |
1723 | } | 1723 | } |
1724 | 1724 | ||
diff --git a/tools/perf/builtin-top.c b/tools/perf/builtin-top.c index b9a321fd184e..a21247543fc1 100644 --- a/tools/perf/builtin-top.c +++ b/tools/perf/builtin-top.c | |||
@@ -79,7 +79,7 @@ static int dump_symtab = 0; | |||
79 | static bool hide_kernel_symbols = false; | 79 | static bool hide_kernel_symbols = false; |
80 | static bool hide_user_symbols = false; | 80 | static bool hide_user_symbols = false; |
81 | static struct winsize winsize; | 81 | static struct winsize winsize; |
82 | const char *vmlinux_name; | 82 | struct symbol_conf symbol_conf; |
83 | 83 | ||
84 | /* | 84 | /* |
85 | * Source | 85 | * Source |
@@ -128,7 +128,7 @@ struct sym_entry { | |||
128 | 128 | ||
129 | static inline struct symbol *sym_entry__symbol(struct sym_entry *self) | 129 | static inline struct symbol *sym_entry__symbol(struct sym_entry *self) |
130 | { | 130 | { |
131 | return ((void *)self) + symbol__priv_size; | 131 | return ((void *)self) + symbol_conf.priv_size; |
132 | } | 132 | } |
133 | 133 | ||
134 | static void get_term_dimensions(struct winsize *ws) | 134 | static void get_term_dimensions(struct winsize *ws) |
@@ -695,7 +695,7 @@ static void print_mapped_keys(void) | |||
695 | 695 | ||
696 | fprintf(stdout, "\t[f] profile display filter (count). \t(%d)\n", count_filter); | 696 | fprintf(stdout, "\t[f] profile display filter (count). \t(%d)\n", count_filter); |
697 | 697 | ||
698 | if (vmlinux_name) { | 698 | if (symbol_conf.vmlinux_name) { |
699 | fprintf(stdout, "\t[F] annotate display filter (percent). \t(%d%%)\n", sym_pcnt_filter); | 699 | fprintf(stdout, "\t[F] annotate display filter (percent). \t(%d%%)\n", sym_pcnt_filter); |
700 | fprintf(stdout, "\t[s] annotate symbol. \t(%s)\n", name?: "NULL"); | 700 | fprintf(stdout, "\t[s] annotate symbol. \t(%s)\n", name?: "NULL"); |
701 | fprintf(stdout, "\t[S] stop annotation.\n"); | 701 | fprintf(stdout, "\t[S] stop annotation.\n"); |
@@ -732,7 +732,7 @@ static int key_mapped(int c) | |||
732 | case 'F': | 732 | case 'F': |
733 | case 's': | 733 | case 's': |
734 | case 'S': | 734 | case 'S': |
735 | return vmlinux_name ? 1 : 0; | 735 | return symbol_conf.vmlinux_name ? 1 : 0; |
736 | default: | 736 | default: |
737 | break; | 737 | break; |
738 | } | 738 | } |
@@ -1261,7 +1261,8 @@ static const struct option options[] = { | |||
1261 | "system-wide collection from all CPUs"), | 1261 | "system-wide collection from all CPUs"), |
1262 | OPT_INTEGER('C', "CPU", &profile_cpu, | 1262 | OPT_INTEGER('C', "CPU", &profile_cpu, |
1263 | "CPU to profile on"), | 1263 | "CPU to profile on"), |
1264 | OPT_STRING('k', "vmlinux", &vmlinux_name, "file", "vmlinux pathname"), | 1264 | OPT_STRING('k', "vmlinux", &symbol_conf.vmlinux_name, |
1265 | "file", "vmlinux pathname"), | ||
1265 | OPT_BOOLEAN('K', "hide_kernel_symbols", &hide_kernel_symbols, | 1266 | OPT_BOOLEAN('K', "hide_kernel_symbols", &hide_kernel_symbols, |
1266 | "hide kernel symbols"), | 1267 | "hide kernel symbols"), |
1267 | OPT_INTEGER('m', "mmap-pages", &mmap_pages, | 1268 | OPT_INTEGER('m', "mmap-pages", &mmap_pages, |
@@ -1295,7 +1296,7 @@ static const struct option options[] = { | |||
1295 | 1296 | ||
1296 | int cmd_top(int argc, const char **argv, const char *prefix __used) | 1297 | int cmd_top(int argc, const char **argv, const char *prefix __used) |
1297 | { | 1298 | { |
1298 | int counter, err; | 1299 | int counter; |
1299 | 1300 | ||
1300 | page_size = sysconf(_SC_PAGE_SIZE); | 1301 | page_size = sysconf(_SC_PAGE_SIZE); |
1301 | 1302 | ||
@@ -1313,15 +1314,16 @@ int cmd_top(int argc, const char **argv, const char *prefix __used) | |||
1313 | if (!nr_counters) | 1314 | if (!nr_counters) |
1314 | nr_counters = 1; | 1315 | nr_counters = 1; |
1315 | 1316 | ||
1316 | symbol__init(sizeof(struct sym_entry) + | 1317 | symbol_conf.priv_size = (sizeof(struct sym_entry) + |
1317 | (nr_counters + 1) * sizeof(unsigned long)); | 1318 | (nr_counters + 1) * sizeof(unsigned long)); |
1319 | if (symbol_conf.vmlinux_name == NULL) | ||
1320 | symbol_conf.try_vmlinux_path = true; | ||
1321 | if (symbol__init(&symbol_conf) < 0) | ||
1322 | return -1; | ||
1318 | 1323 | ||
1319 | if (delay_secs < 1) | 1324 | if (delay_secs < 1) |
1320 | delay_secs = 1; | 1325 | delay_secs = 1; |
1321 | 1326 | ||
1322 | err = kernel_maps__init(vmlinux_name, !vmlinux_name, true); | ||
1323 | if (err < 0) | ||
1324 | return err; | ||
1325 | parse_source(sym_filter_entry); | 1327 | parse_source(sym_filter_entry); |
1326 | 1328 | ||
1327 | /* | 1329 | /* |
diff --git a/tools/perf/builtin-trace.c b/tools/perf/builtin-trace.c index b71198e5dc14..75972fd073df 100644 --- a/tools/perf/builtin-trace.c +++ b/tools/perf/builtin-trace.c | |||
@@ -131,7 +131,7 @@ static int __cmd_trace(void) | |||
131 | register_idle_thread(); | 131 | register_idle_thread(); |
132 | register_perf_file_handler(&file_handler); | 132 | register_perf_file_handler(&file_handler); |
133 | 133 | ||
134 | return mmap_dispatch_perf_file(&header, input_name, NULL, false, | 134 | return mmap_dispatch_perf_file(&header, input_name, |
135 | 0, 0, &cwdlen, &cwd); | 135 | 0, 0, &cwdlen, &cwd); |
136 | } | 136 | } |
137 | 137 | ||
diff --git a/tools/perf/util/data_map.c b/tools/perf/util/data_map.c index f318d19b2562..b238462b8983 100644 --- a/tools/perf/util/data_map.c +++ b/tools/perf/util/data_map.c | |||
@@ -101,8 +101,6 @@ out: | |||
101 | 101 | ||
102 | int mmap_dispatch_perf_file(struct perf_header **pheader, | 102 | int mmap_dispatch_perf_file(struct perf_header **pheader, |
103 | const char *input_name, | 103 | const char *input_name, |
104 | const char *vmlinux_name, | ||
105 | bool try_vmlinux_path, | ||
106 | int force, | 104 | int force, |
107 | int full_paths, | 105 | int full_paths, |
108 | int *cwdlen, | 106 | int *cwdlen, |
@@ -172,12 +170,6 @@ int mmap_dispatch_perf_file(struct perf_header **pheader, | |||
172 | curr_handler->sample_type_check(sample_type) < 0) | 170 | curr_handler->sample_type_check(sample_type) < 0) |
173 | goto out_delete; | 171 | goto out_delete; |
174 | 172 | ||
175 | err = -ENOMEM; | ||
176 | if (kernel_maps__init(vmlinux_name, try_vmlinux_path, true) < 0) { | ||
177 | pr_err("failed to setup the kernel maps to resolve symbols\n"); | ||
178 | goto out_delete; | ||
179 | } | ||
180 | |||
181 | if (!full_paths) { | 173 | if (!full_paths) { |
182 | if (getcwd(__cwd, sizeof(__cwd)) == NULL) { | 174 | if (getcwd(__cwd, sizeof(__cwd)) == NULL) { |
183 | pr_err("failed to get the current directory\n"); | 175 | pr_err("failed to get the current directory\n"); |
diff --git a/tools/perf/util/data_map.h b/tools/perf/util/data_map.h index 3f0d21b3819e..ae036ecd7625 100644 --- a/tools/perf/util/data_map.h +++ b/tools/perf/util/data_map.h | |||
@@ -23,8 +23,6 @@ struct perf_file_handler { | |||
23 | void register_perf_file_handler(struct perf_file_handler *handler); | 23 | void register_perf_file_handler(struct perf_file_handler *handler); |
24 | int mmap_dispatch_perf_file(struct perf_header **pheader, | 24 | int mmap_dispatch_perf_file(struct perf_header **pheader, |
25 | const char *input_name, | 25 | const char *input_name, |
26 | const char *vmlinux_name, | ||
27 | bool try_vmlinux_path, | ||
28 | int force, | 26 | int force, |
29 | int full_paths, | 27 | int full_paths, |
30 | int *cwdlen, | 28 | int *cwdlen, |
diff --git a/tools/perf/util/header.c b/tools/perf/util/header.c index 1332f8ec04aa..271a1600e6f7 100644 --- a/tools/perf/util/header.c +++ b/tools/perf/util/header.c | |||
@@ -253,12 +253,6 @@ static int perf_header__adds_write(struct perf_header *self, int fd) | |||
253 | 253 | ||
254 | buildid_sec = &feat_sec[idx++]; | 254 | buildid_sec = &feat_sec[idx++]; |
255 | 255 | ||
256 | /* | ||
257 | * Read the kernel buildid nad the list of loaded modules with | ||
258 | * its build_ids: | ||
259 | */ | ||
260 | kernel_maps__init(NULL, false, true); | ||
261 | |||
262 | /* Write build-ids */ | 256 | /* Write build-ids */ |
263 | buildid_sec->offset = lseek(fd, 0, SEEK_CUR); | 257 | buildid_sec->offset = lseek(fd, 0, SEEK_CUR); |
264 | err = dsos__write_buildid_table(fd); | 258 | err = dsos__write_buildid_table(fd); |
diff --git a/tools/perf/util/include/asm/bug.h b/tools/perf/util/include/asm/bug.h new file mode 100644 index 000000000000..7fcc6810adc2 --- /dev/null +++ b/tools/perf/util/include/asm/bug.h | |||
@@ -0,0 +1,22 @@ | |||
1 | #ifndef _PERF_ASM_GENERIC_BUG_H | ||
2 | #define _PERF_ASM_GENERIC_BUG_H | ||
3 | |||
4 | #define __WARN_printf(arg...) do { fprintf(stderr, arg); } while (0) | ||
5 | |||
6 | #define WARN(condition, format...) ({ \ | ||
7 | int __ret_warn_on = !!(condition); \ | ||
8 | if (unlikely(__ret_warn_on)) \ | ||
9 | __WARN_printf(format); \ | ||
10 | unlikely(__ret_warn_on); \ | ||
11 | }) | ||
12 | |||
13 | #define WARN_ONCE(condition, format...) ({ \ | ||
14 | static int __warned; \ | ||
15 | int __ret_warn_once = !!(condition); \ | ||
16 | \ | ||
17 | if (unlikely(__ret_warn_once)) \ | ||
18 | if (WARN(!__warned, format)) \ | ||
19 | __warned = 1; \ | ||
20 | unlikely(__ret_warn_once); \ | ||
21 | }) | ||
22 | #endif | ||
diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c index 44d81d5ae8cf..c4ca974b36e3 100644 --- a/tools/perf/util/symbol.c +++ b/tools/perf/util/symbol.c | |||
@@ -6,6 +6,7 @@ | |||
6 | 6 | ||
7 | #include "debug.h" | 7 | #include "debug.h" |
8 | 8 | ||
9 | #include <asm/bug.h> | ||
9 | #include <libelf.h> | 10 | #include <libelf.h> |
10 | #include <gelf.h> | 11 | #include <gelf.h> |
11 | #include <elf.h> | 12 | #include <elf.h> |
@@ -37,6 +38,11 @@ unsigned int symbol__priv_size; | |||
37 | static int vmlinux_path__nr_entries; | 38 | static int vmlinux_path__nr_entries; |
38 | static char **vmlinux_path; | 39 | static char **vmlinux_path; |
39 | 40 | ||
41 | static struct symbol_conf symbol_conf__defaults = { | ||
42 | .use_modules = true, | ||
43 | .try_vmlinux_path = true, | ||
44 | }; | ||
45 | |||
40 | static struct rb_root kernel_maps; | 46 | static struct rb_root kernel_maps; |
41 | 47 | ||
42 | static void dso__fixup_sym_end(struct dso *self) | 48 | static void dso__fixup_sym_end(struct dso *self) |
@@ -1166,7 +1172,9 @@ struct symbol *kernel_maps__find_symbol(u64 ip, struct map **mapp, | |||
1166 | if (map) { | 1172 | if (map) { |
1167 | ip = map->map_ip(map, ip); | 1173 | ip = map->map_ip(map, ip); |
1168 | return map__find_symbol(map, ip, filter); | 1174 | return map__find_symbol(map, ip, filter); |
1169 | } | 1175 | } else |
1176 | WARN_ONCE(RB_EMPTY_ROOT(&kernel_maps), | ||
1177 | "Empty kernel_maps, was symbol__init() called?\n"); | ||
1170 | 1178 | ||
1171 | return NULL; | 1179 | return NULL; |
1172 | } | 1180 | } |
@@ -1485,9 +1493,9 @@ size_t dsos__fprintf_buildid(FILE *fp) | |||
1485 | return ret; | 1493 | return ret; |
1486 | } | 1494 | } |
1487 | 1495 | ||
1488 | static int kernel_maps__create_kernel_map(const char *vmlinux_name) | 1496 | static int kernel_maps__create_kernel_map(const struct symbol_conf *conf) |
1489 | { | 1497 | { |
1490 | struct dso *kernel = dso__new(vmlinux_name ?: "[kernel.kallsyms]"); | 1498 | struct dso *kernel = dso__new(conf->vmlinux_name ?: "[kernel.kallsyms]"); |
1491 | 1499 | ||
1492 | if (kernel == NULL) | 1500 | if (kernel == NULL) |
1493 | return -1; | 1501 | return -1; |
@@ -1577,18 +1585,21 @@ out_fail: | |||
1577 | return -1; | 1585 | return -1; |
1578 | } | 1586 | } |
1579 | 1587 | ||
1580 | int kernel_maps__init(const char *vmlinux_name, bool try_vmlinux_path, | 1588 | static int kernel_maps__init(const struct symbol_conf *conf) |
1581 | bool use_modules) | ||
1582 | { | 1589 | { |
1583 | if (try_vmlinux_path && vmlinux_path__init() < 0) | 1590 | const struct symbol_conf *pconf = conf ?: &symbol_conf__defaults; |
1591 | |||
1592 | symbol__priv_size = pconf->priv_size; | ||
1593 | |||
1594 | if (pconf->try_vmlinux_path && vmlinux_path__init() < 0) | ||
1584 | return -1; | 1595 | return -1; |
1585 | 1596 | ||
1586 | if (kernel_maps__create_kernel_map(vmlinux_name) < 0) { | 1597 | if (kernel_maps__create_kernel_map(pconf) < 0) { |
1587 | vmlinux_path__exit(); | 1598 | vmlinux_path__exit(); |
1588 | return -1; | 1599 | return -1; |
1589 | } | 1600 | } |
1590 | 1601 | ||
1591 | if (use_modules && kernel_maps__create_module_maps() < 0) | 1602 | if (pconf->use_modules && kernel_maps__create_module_maps() < 0) |
1592 | pr_debug("Failed to load list of modules in use, " | 1603 | pr_debug("Failed to load list of modules in use, " |
1593 | "continuing...\n"); | 1604 | "continuing...\n"); |
1594 | /* | 1605 | /* |
@@ -1598,8 +1609,8 @@ int kernel_maps__init(const char *vmlinux_name, bool try_vmlinux_path, | |||
1598 | return 0; | 1609 | return 0; |
1599 | } | 1610 | } |
1600 | 1611 | ||
1601 | void symbol__init(unsigned int priv_size) | 1612 | int symbol__init(struct symbol_conf *conf) |
1602 | { | 1613 | { |
1603 | elf_version(EV_CURRENT); | 1614 | elf_version(EV_CURRENT); |
1604 | symbol__priv_size = priv_size; | 1615 | return kernel_maps__init(conf); |
1605 | } | 1616 | } |
diff --git a/tools/perf/util/symbol.h b/tools/perf/util/symbol.h index 8c4d026e067a..5538691494af 100644 --- a/tools/perf/util/symbol.h +++ b/tools/perf/util/symbol.h | |||
@@ -49,6 +49,13 @@ struct symbol { | |||
49 | char name[0]; | 49 | char name[0]; |
50 | }; | 50 | }; |
51 | 51 | ||
52 | struct symbol_conf { | ||
53 | unsigned short priv_size; | ||
54 | bool try_vmlinux_path, | ||
55 | use_modules; | ||
56 | const char *vmlinux_name; | ||
57 | }; | ||
58 | |||
52 | extern unsigned int symbol__priv_size; | 59 | extern unsigned int symbol__priv_size; |
53 | 60 | ||
54 | static inline void *symbol__priv(struct symbol *self) | 61 | static inline void *symbol__priv(struct symbol *self) |
@@ -93,11 +100,9 @@ int sysfs__read_build_id(const char *filename, void *bf, size_t size); | |||
93 | bool dsos__read_build_ids(void); | 100 | bool dsos__read_build_ids(void); |
94 | int build_id__sprintf(u8 *self, int len, char *bf); | 101 | int build_id__sprintf(u8 *self, int len, char *bf); |
95 | 102 | ||
96 | int kernel_maps__init(const char *vmlinux_name, bool try_vmlinux_path, | ||
97 | bool use_modules); | ||
98 | size_t kernel_maps__fprintf(FILE *fp); | 103 | size_t kernel_maps__fprintf(FILE *fp); |
99 | 104 | ||
100 | void symbol__init(unsigned int priv_size); | 105 | int symbol__init(struct symbol_conf *conf); |
101 | 106 | ||
102 | extern struct list_head dsos; | 107 | extern struct list_head dsos; |
103 | extern struct map *kernel_map; | 108 | extern struct map *kernel_map; |