aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorIngo Molnar <mingo@elte.hu>2010-12-16 05:22:25 -0500
committerIngo Molnar <mingo@elte.hu>2010-12-16 05:22:27 -0500
commit006b20fe4c69189b0d854e5eabf269e50ca86cdd (patch)
tree948b08825a36114c85ddc2bfcd965c261e32810f /tools
parent5f29805a4f4627e766f862ff9f10c14f5f314359 (diff)
parentd949750fed168b6553ca11ed19e4affd19d7a4d7 (diff)
Merge branch 'perf/urgent' into perf/core
Merge reason: We want to apply a dependent patch. Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'tools')
-rw-r--r--tools/perf/builtin-record.c6
-rw-r--r--tools/perf/util/header.c11
-rw-r--r--tools/perf/util/symbol.c59
3 files changed, 65 insertions, 11 deletions
diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c
index 699dd2149c4b..e9be6ae87a27 100644
--- a/tools/perf/builtin-record.c
+++ b/tools/perf/builtin-record.c
@@ -202,7 +202,7 @@ static void sig_atexit(void)
202 if (child_pid > 0) 202 if (child_pid > 0)
203 kill(child_pid, SIGTERM); 203 kill(child_pid, SIGTERM);
204 204
205 if (signr == -1) 205 if (signr == -1 || signr == SIGUSR1)
206 return; 206 return;
207 207
208 signal(signr, SIG_DFL); 208 signal(signr, SIG_DFL);
@@ -535,6 +535,7 @@ static int __cmd_record(int argc, const char **argv)
535 atexit(sig_atexit); 535 atexit(sig_atexit);
536 signal(SIGCHLD, sig_handler); 536 signal(SIGCHLD, sig_handler);
537 signal(SIGINT, sig_handler); 537 signal(SIGINT, sig_handler);
538 signal(SIGUSR1, sig_handler);
538 539
539 if (forks && (pipe(child_ready_pipe) < 0 || pipe(go_pipe) < 0)) { 540 if (forks && (pipe(child_ready_pipe) < 0 || pipe(go_pipe) < 0)) {
540 perror("failed to create pipes"); 541 perror("failed to create pipes");
@@ -629,6 +630,7 @@ static int __cmd_record(int argc, const char **argv)
629 execvp(argv[0], (char **)argv); 630 execvp(argv[0], (char **)argv);
630 631
631 perror(argv[0]); 632 perror(argv[0]);
633 kill(getppid(), SIGUSR1);
632 exit(-1); 634 exit(-1);
633 } 635 }
634 636
@@ -789,7 +791,7 @@ static int __cmd_record(int argc, const char **argv)
789 } 791 }
790 } 792 }
791 793
792 if (quiet) 794 if (quiet || signr == SIGUSR1)
793 return 0; 795 return 0;
794 796
795 fprintf(stderr, "[ perf record: Woken up %ld times to write data ]\n", waking); 797 fprintf(stderr, "[ perf record: Woken up %ld times to write data ]\n", waking);
diff --git a/tools/perf/util/header.c b/tools/perf/util/header.c
index 76e949a59ea4..16a16021eaa6 100644
--- a/tools/perf/util/header.c
+++ b/tools/perf/util/header.c
@@ -971,11 +971,16 @@ perf_header__find_attr(u64 id, struct perf_header *header)
971 971
972 /* 972 /*
973 * We set id to -1 if the data file doesn't contain sample 973 * We set id to -1 if the data file doesn't contain sample
974 * ids. Check for this and avoid walking through the entire 974 * ids. This can happen when the data file contains one type
975 * list of ids which may be large. 975 * of event and in that case, the header can still store the
976 * event attribute information. Check for this and avoid
977 * walking through the entire list of ids which may be large.
976 */ 978 */
977 if (id == -1ULL) 979 if (id == -1ULL) {
980 if (header->attrs > 0)
981 return &header->attr[0]->attr;
978 return NULL; 982 return NULL;
983 }
979 984
980 for (i = 0; i < header->attrs; i++) { 985 for (i = 0; i < header->attrs; i++) {
981 struct perf_header_attr *attr = header->attr[i]; 986 struct perf_header_attr *attr = header->attr[i];
diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c
index f40c076aeb7b..ceefa6568def 100644
--- a/tools/perf/util/symbol.c
+++ b/tools/perf/util/symbol.c
@@ -532,7 +532,7 @@ static int dso__split_kallsyms(struct dso *self, struct map *map,
532 struct machine *machine = kmaps->machine; 532 struct machine *machine = kmaps->machine;
533 struct map *curr_map = map; 533 struct map *curr_map = map;
534 struct symbol *pos; 534 struct symbol *pos;
535 int count = 0; 535 int count = 0, moved = 0;
536 struct rb_root *root = &self->symbols[map->type]; 536 struct rb_root *root = &self->symbols[map->type];
537 struct rb_node *next = rb_first(root); 537 struct rb_node *next = rb_first(root);
538 int kernel_range = 0; 538 int kernel_range = 0;
@@ -590,6 +590,11 @@ static int dso__split_kallsyms(struct dso *self, struct map *map,
590 char dso_name[PATH_MAX]; 590 char dso_name[PATH_MAX];
591 struct dso *dso; 591 struct dso *dso;
592 592
593 if (count == 0) {
594 curr_map = map;
595 goto filter_symbol;
596 }
597
593 if (self->kernel == DSO_TYPE_GUEST_KERNEL) 598 if (self->kernel == DSO_TYPE_GUEST_KERNEL)
594 snprintf(dso_name, sizeof(dso_name), 599 snprintf(dso_name, sizeof(dso_name),
595 "[guest.kernel].%d", 600 "[guest.kernel].%d",
@@ -615,7 +620,7 @@ static int dso__split_kallsyms(struct dso *self, struct map *map,
615 map_groups__insert(kmaps, curr_map); 620 map_groups__insert(kmaps, curr_map);
616 ++kernel_range; 621 ++kernel_range;
617 } 622 }
618 623filter_symbol:
619 if (filter && filter(curr_map, pos)) { 624 if (filter && filter(curr_map, pos)) {
620discard_symbol: rb_erase(&pos->rb_node, root); 625discard_symbol: rb_erase(&pos->rb_node, root);
621 symbol__delete(pos); 626 symbol__delete(pos);
@@ -623,8 +628,9 @@ discard_symbol: rb_erase(&pos->rb_node, root);
623 if (curr_map != map) { 628 if (curr_map != map) {
624 rb_erase(&pos->rb_node, root); 629 rb_erase(&pos->rb_node, root);
625 symbols__insert(&curr_map->dso->symbols[curr_map->type], pos); 630 symbols__insert(&curr_map->dso->symbols[curr_map->type], pos);
626 } 631 ++moved;
627 count++; 632 } else
633 ++count;
628 } 634 }
629 } 635 }
630 636
@@ -634,7 +640,7 @@ discard_symbol: rb_erase(&pos->rb_node, root);
634 dso__set_loaded(curr_map->dso, curr_map->type); 640 dso__set_loaded(curr_map->dso, curr_map->type);
635 } 641 }
636 642
637 return count; 643 return count + moved;
638} 644}
639 645
640int dso__load_kallsyms(struct dso *self, const char *filename, 646int dso__load_kallsyms(struct dso *self, const char *filename,
@@ -2130,14 +2136,55 @@ static struct dso *machine__create_kernel(struct machine *self)
2130 return kernel; 2136 return kernel;
2131} 2137}
2132 2138
2139struct process_args {
2140 u64 start;
2141};
2142
2143static int symbol__in_kernel(void *arg, const char *name,
2144 char type __used, u64 start)
2145{
2146 struct process_args *args = arg;
2147
2148 if (strchr(name, '['))
2149 return 0;
2150
2151 args->start = start;
2152 return 1;
2153}
2154
2155/* Figure out the start address of kernel map from /proc/kallsyms */
2156static u64 machine__get_kernel_start_addr(struct machine *machine)
2157{
2158 const char *filename;
2159 char path[PATH_MAX];
2160 struct process_args args;
2161
2162 if (machine__is_host(machine)) {
2163 filename = "/proc/kallsyms";
2164 } else {
2165 if (machine__is_default_guest(machine))
2166 filename = (char *)symbol_conf.default_guest_kallsyms;
2167 else {
2168 sprintf(path, "%s/proc/kallsyms", machine->root_dir);
2169 filename = path;
2170 }
2171 }
2172
2173 if (kallsyms__parse(filename, &args, symbol__in_kernel) <= 0)
2174 return 0;
2175
2176 return args.start;
2177}
2178
2133int __machine__create_kernel_maps(struct machine *self, struct dso *kernel) 2179int __machine__create_kernel_maps(struct machine *self, struct dso *kernel)
2134{ 2180{
2135 enum map_type type; 2181 enum map_type type;
2182 u64 start = machine__get_kernel_start_addr(self);
2136 2183
2137 for (type = 0; type < MAP__NR_TYPES; ++type) { 2184 for (type = 0; type < MAP__NR_TYPES; ++type) {
2138 struct kmap *kmap; 2185 struct kmap *kmap;
2139 2186
2140 self->vmlinux_maps[type] = map__new2(0, kernel, type); 2187 self->vmlinux_maps[type] = map__new2(start, kernel, type);
2141 if (self->vmlinux_maps[type] == NULL) 2188 if (self->vmlinux_maps[type] == NULL)
2142 return -1; 2189 return -1;
2143 2190