diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2010-08-02 17:18:28 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2010-08-02 17:18:28 -0400 |
commit | 076c6e45215aea0de1ed34d3d5079fabeaabf5e1 (patch) | |
tree | a07e78f58e625eb69dfda8f32ab46e5316551025 /tools/perf/util/session.c | |
parent | 3772b734720e1a3f2dc1d95cfdfaa5332f4ccf01 (diff) |
perf session: Free the ref_reloc_sym memory at the right place
Which is at perf_session__destroy_kernel_maps, counterpart to the
perf_session__create_kernel_maps where the kmap structure is located, just
after the vmlinux_maps.
Make it also check if the kernel maps were actually created, which may not
be the case if, for instance, perf_session__new can't complete due to
permission problems in, for instance, a 'perf report' case, when a
segfault will take place, that is how this was noticed.
The problem was introduced in d65a458, thus post .35.
This also adds code to release guest machines as them are also created
in perf_session__create_kernel_maps, so should be deleted on this newly
introduced counterpart, perf_session__destroy_kernel_maps.
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
LKML-Reference: <new-submission>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/session.c')
-rw-r--r-- | tools/perf/util/session.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index 04a3b3db9e9..5d2fd52fe7b 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); |