diff options
-rw-r--r-- | tools/perf/builtin-annotate.c | 64 |
1 files changed, 33 insertions, 31 deletions
diff --git a/tools/perf/builtin-annotate.c b/tools/perf/builtin-annotate.c index 8b9091bce98d..4f0c3d98352d 100644 --- a/tools/perf/builtin-annotate.c +++ b/tools/perf/builtin-annotate.c | |||
@@ -30,18 +30,17 @@ | |||
30 | 30 | ||
31 | #include <linux/bitmap.h> | 31 | #include <linux/bitmap.h> |
32 | 32 | ||
33 | static char const *input_name = "perf.data"; | 33 | static struct perf_annotate { |
34 | 34 | char const *input_name; | |
35 | static bool force, use_tui, use_stdio; | 35 | bool force, use_tui, use_stdio; |
36 | 36 | bool full_paths; | |
37 | static bool full_paths; | 37 | bool print_line; |
38 | 38 | const char *sym_hist_filter; | |
39 | static bool print_line; | 39 | const char *cpu_list; |
40 | 40 | DECLARE_BITMAP(cpu_bitmap, MAX_NR_CPUS); | |
41 | static const char *sym_hist_filter; | 41 | } annotate = { |
42 | 42 | .input_name = "perf.data", | |
43 | static const char *cpu_list; | 43 | }, *ann = &annotate; |
44 | static DECLARE_BITMAP(cpu_bitmap, MAX_NR_CPUS); | ||
45 | 44 | ||
46 | static int perf_evsel__add_sample(struct perf_evsel *evsel, | 45 | static int perf_evsel__add_sample(struct perf_evsel *evsel, |
47 | struct perf_sample *sample, | 46 | struct perf_sample *sample, |
@@ -50,8 +49,9 @@ static int perf_evsel__add_sample(struct perf_evsel *evsel, | |||
50 | struct hist_entry *he; | 49 | struct hist_entry *he; |
51 | int ret; | 50 | int ret; |
52 | 51 | ||
53 | if (sym_hist_filter != NULL && | 52 | if (ann->sym_hist_filter != NULL && |
54 | (al->sym == NULL || strcmp(sym_hist_filter, al->sym->name) != 0)) { | 53 | (al->sym == NULL || |
54 | strcmp(ann->sym_hist_filter, al->sym->name) != 0)) { | ||
55 | /* We're only interested in a symbol named sym_hist_filter */ | 55 | /* We're only interested in a symbol named sym_hist_filter */ |
56 | if (al->sym != NULL) { | 56 | if (al->sym != NULL) { |
57 | rb_erase(&al->sym->rb_node, | 57 | rb_erase(&al->sym->rb_node, |
@@ -93,7 +93,7 @@ static int process_sample_event(union perf_event *event, | |||
93 | return -1; | 93 | return -1; |
94 | } | 94 | } |
95 | 95 | ||
96 | if (cpu_list && !test_bit(sample->cpu, cpu_bitmap)) | 96 | if (ann->cpu_list && !test_bit(sample->cpu, ann->cpu_bitmap)) |
97 | return 0; | 97 | return 0; |
98 | 98 | ||
99 | if (!al.filtered && perf_evsel__add_sample(evsel, sample, &al)) { | 99 | if (!al.filtered && perf_evsel__add_sample(evsel, sample, &al)) { |
@@ -108,7 +108,7 @@ static int process_sample_event(union perf_event *event, | |||
108 | static int hist_entry__tty_annotate(struct hist_entry *he, int evidx) | 108 | static int hist_entry__tty_annotate(struct hist_entry *he, int evidx) |
109 | { | 109 | { |
110 | return symbol__tty_annotate(he->ms.sym, he->ms.map, evidx, | 110 | return symbol__tty_annotate(he->ms.sym, he->ms.map, evidx, |
111 | print_line, full_paths, 0, 0); | 111 | ann->print_line, ann->full_paths, 0, 0); |
112 | } | 112 | } |
113 | 113 | ||
114 | static void hists__find_annotations(struct hists *self, int evidx) | 114 | static void hists__find_annotations(struct hists *self, int evidx) |
@@ -178,12 +178,14 @@ static int __cmd_annotate(void) | |||
178 | struct perf_evsel *pos; | 178 | struct perf_evsel *pos; |
179 | u64 total_nr_samples; | 179 | u64 total_nr_samples; |
180 | 180 | ||
181 | session = perf_session__new(input_name, O_RDONLY, force, false, &event_ops); | 181 | session = perf_session__new(ann->input_name, O_RDONLY, |
182 | ann->force, false, &event_ops); | ||
182 | if (session == NULL) | 183 | if (session == NULL) |
183 | return -ENOMEM; | 184 | return -ENOMEM; |
184 | 185 | ||
185 | if (cpu_list) { | 186 | if (ann->cpu_list) { |
186 | ret = perf_session__cpu_bitmap(session, cpu_list, cpu_bitmap); | 187 | ret = perf_session__cpu_bitmap(session, ann->cpu_list, |
188 | ann->cpu_bitmap); | ||
187 | if (ret) | 189 | if (ret) |
188 | goto out_delete; | 190 | goto out_delete; |
189 | } | 191 | } |
@@ -217,7 +219,7 @@ static int __cmd_annotate(void) | |||
217 | } | 219 | } |
218 | 220 | ||
219 | if (total_nr_samples == 0) { | 221 | if (total_nr_samples == 0) { |
220 | ui__warning("The %s file has no samples!\n", input_name); | 222 | ui__warning("The %s file has no samples!\n", ann->input_name); |
221 | goto out_delete; | 223 | goto out_delete; |
222 | } | 224 | } |
223 | out_delete: | 225 | out_delete: |
@@ -242,28 +244,28 @@ static const char * const annotate_usage[] = { | |||
242 | }; | 244 | }; |
243 | 245 | ||
244 | static const struct option options[] = { | 246 | static const struct option options[] = { |
245 | OPT_STRING('i', "input", &input_name, "file", | 247 | OPT_STRING('i', "input", &annotate.input_name, "file", |
246 | "input file name"), | 248 | "input file name"), |
247 | OPT_STRING('d', "dsos", &symbol_conf.dso_list_str, "dso[,dso...]", | 249 | OPT_STRING('d', "dsos", &symbol_conf.dso_list_str, "dso[,dso...]", |
248 | "only consider symbols in these dsos"), | 250 | "only consider symbols in these dsos"), |
249 | OPT_STRING('s', "symbol", &sym_hist_filter, "symbol", | 251 | OPT_STRING('s', "symbol", &annotate.sym_hist_filter, "symbol", |
250 | "symbol to annotate"), | 252 | "symbol to annotate"), |
251 | OPT_BOOLEAN('f', "force", &force, "don't complain, do it"), | 253 | OPT_BOOLEAN('f', "force", &annotate.force, "don't complain, do it"), |
252 | OPT_INCR('v', "verbose", &verbose, | 254 | OPT_INCR('v', "verbose", &verbose, |
253 | "be more verbose (show symbol address, etc)"), | 255 | "be more verbose (show symbol address, etc)"), |
254 | OPT_BOOLEAN('D', "dump-raw-trace", &dump_trace, | 256 | OPT_BOOLEAN('D', "dump-raw-trace", &dump_trace, |
255 | "dump raw trace in ASCII"), | 257 | "dump raw trace in ASCII"), |
256 | OPT_BOOLEAN(0, "tui", &use_tui, "Use the TUI interface"), | 258 | OPT_BOOLEAN(0, "tui", &annotate.use_tui, "Use the TUI interface"), |
257 | OPT_BOOLEAN(0, "stdio", &use_stdio, "Use the stdio interface"), | 259 | OPT_BOOLEAN(0, "stdio", &annotate.use_stdio, "Use the stdio interface"), |
258 | OPT_STRING('k', "vmlinux", &symbol_conf.vmlinux_name, | 260 | OPT_STRING('k', "vmlinux", &symbol_conf.vmlinux_name, |
259 | "file", "vmlinux pathname"), | 261 | "file", "vmlinux pathname"), |
260 | OPT_BOOLEAN('m', "modules", &symbol_conf.use_modules, | 262 | OPT_BOOLEAN('m', "modules", &symbol_conf.use_modules, |
261 | "load module symbols - WARNING: use only with -k and LIVE kernel"), | 263 | "load module symbols - WARNING: use only with -k and LIVE kernel"), |
262 | OPT_BOOLEAN('l', "print-line", &print_line, | 264 | OPT_BOOLEAN('l', "print-line", &annotate.print_line, |
263 | "print matching source lines (may be slow)"), | 265 | "print matching source lines (may be slow)"), |
264 | OPT_BOOLEAN('P', "full-paths", &full_paths, | 266 | OPT_BOOLEAN('P', "full-paths", &annotate.full_paths, |
265 | "Don't shorten the displayed pathnames"), | 267 | "Don't shorten the displayed pathnames"), |
266 | OPT_STRING('c', "cpu", &cpu_list, "cpu", "list of cpus to profile"), | 268 | OPT_STRING('c', "cpu", &annotate.cpu_list, "cpu", "list of cpus to profile"), |
267 | OPT_STRING(0, "symfs", &symbol_conf.symfs, "directory", | 269 | OPT_STRING(0, "symfs", &symbol_conf.symfs, "directory", |
268 | "Look for files with symbols relative to this directory"), | 270 | "Look for files with symbols relative to this directory"), |
269 | OPT_BOOLEAN(0, "source", &symbol_conf.annotate_src, | 271 | OPT_BOOLEAN(0, "source", &symbol_conf.annotate_src, |
@@ -279,9 +281,9 @@ int cmd_annotate(int argc, const char **argv, const char *prefix __used) | |||
279 | { | 281 | { |
280 | argc = parse_options(argc, argv, options, annotate_usage, 0); | 282 | argc = parse_options(argc, argv, options, annotate_usage, 0); |
281 | 283 | ||
282 | if (use_stdio) | 284 | if (annotate.use_stdio) |
283 | use_browser = 0; | 285 | use_browser = 0; |
284 | else if (use_tui) | 286 | else if (annotate.use_tui) |
285 | use_browser = 1; | 287 | use_browser = 1; |
286 | 288 | ||
287 | setup_browser(true); | 289 | setup_browser(true); |
@@ -302,7 +304,7 @@ int cmd_annotate(int argc, const char **argv, const char *prefix __used) | |||
302 | if (argc > 1) | 304 | if (argc > 1) |
303 | usage_with_options(annotate_usage, options); | 305 | usage_with_options(annotate_usage, options); |
304 | 306 | ||
305 | sym_hist_filter = argv[0]; | 307 | annotate.sym_hist_filter = argv[0]; |
306 | } | 308 | } |
307 | 309 | ||
308 | if (field_sep && *field_sep == '.') { | 310 | if (field_sep && *field_sep == '.') { |