diff options
author | Ingo Molnar <mingo@elte.hu> | 2010-08-03 01:45:00 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2010-08-03 01:45:00 -0400 |
commit | 43d7383bbec1878f838060d6bbd214f6d0485478 (patch) | |
tree | 64869524fc8e9fe23a9712993c608ccdcecfc2a1 /tools/perf/util/session.c | |
parent | 69e77a8b0426ded5d924eea7dbe4eca51e09f530 (diff) | |
parent | 0a1eae391d0d92b60cff9f55cdaf3861b4e33922 (diff) |
Merge branch 'perf/core' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux-2.6 into perf/core
Diffstat (limited to 'tools/perf/util/session.c')
-rw-r--r-- | tools/perf/util/session.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index 04a3b3db9e90..fa9d652c2dc3 100644 --- a/tools/perf/util/session.c +++ b/tools/perf/util/session.c | |||
@@ -79,6 +79,12 @@ int perf_session__create_kernel_maps(struct perf_session *self) | |||
79 | return ret; | 79 | return ret; |
80 | } | 80 | } |
81 | 81 | ||
82 | static void perf_session__destroy_kernel_maps(struct perf_session *self) | ||
83 | { | ||
84 | machine__destroy_kernel_maps(&self->host_machine); | ||
85 | machines__destroy_guest_kernel_maps(&self->machines); | ||
86 | } | ||
87 | |||
82 | struct perf_session *perf_session__new(const char *filename, int mode, bool force, bool repipe) | 88 | struct perf_session *perf_session__new(const char *filename, int mode, bool force, bool repipe) |
83 | { | 89 | { |
84 | size_t len = filename ? strlen(filename) + 1 : 0; | 90 | size_t len = filename ? strlen(filename) + 1 : 0; |
@@ -150,6 +156,7 @@ static void perf_session__delete_threads(struct perf_session *self) | |||
150 | void perf_session__delete(struct perf_session *self) | 156 | void perf_session__delete(struct perf_session *self) |
151 | { | 157 | { |
152 | perf_header__exit(&self->header); | 158 | perf_header__exit(&self->header); |
159 | perf_session__destroy_kernel_maps(self); | ||
153 | perf_session__delete_dead_threads(self); | 160 | perf_session__delete_dead_threads(self); |
154 | perf_session__delete_threads(self); | 161 | perf_session__delete_threads(self); |
155 | machine__exit(&self->host_machine); | 162 | machine__exit(&self->host_machine); |
@@ -159,6 +166,7 @@ void perf_session__delete(struct perf_session *self) | |||
159 | 166 | ||
160 | void perf_session__remove_thread(struct perf_session *self, struct thread *th) | 167 | void perf_session__remove_thread(struct perf_session *self, struct thread *th) |
161 | { | 168 | { |
169 | self->last_match = NULL; | ||
162 | rb_erase(&th->rb_node, &self->threads); | 170 | rb_erase(&th->rb_node, &self->threads); |
163 | /* | 171 | /* |
164 | * We may have references to this thread, for instance in some hist_entry | 172 | * We may have references to this thread, for instance in some hist_entry |