diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2014-01-03 14:54:12 -0500 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2014-01-13 08:06:22 -0500 |
commit | f26e1c7cb279051d83e0b671f48b30fe88c2c788 (patch) | |
tree | 9f580f4038fdcd9b55ad168bcd7fe864262637ce /tools/perf/tests/mmap-basic.c | |
parent | 03ad9747c5f2169556467101e96bc390c5aa4b83 (diff) |
perf evlist: Close fds on destructor
Since it is safe to call perf_evlist__close() multiple times, autoclose
it and remove the calls to the close from existing tools, reducing the
tooling boilerplate.
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-2kq9v7p1rude1tqxa0aue2tk@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/tests/mmap-basic.c')
-rw-r--r-- | tools/perf/tests/mmap-basic.c | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/tools/perf/tests/mmap-basic.c b/tools/perf/tests/mmap-basic.c index bbb334d2a864..111dd4a917ad 100644 --- a/tools/perf/tests/mmap-basic.c +++ b/tools/perf/tests/mmap-basic.c | |||
@@ -68,7 +68,7 @@ int test__basic_mmap(void) | |||
68 | evsels[i] = perf_evsel__newtp("syscalls", name); | 68 | evsels[i] = perf_evsel__newtp("syscalls", name); |
69 | if (evsels[i] == NULL) { | 69 | if (evsels[i] == NULL) { |
70 | pr_debug("perf_evsel__new\n"); | 70 | pr_debug("perf_evsel__new\n"); |
71 | goto out_free_evlist; | 71 | goto out_delete_evlist; |
72 | } | 72 | } |
73 | 73 | ||
74 | evsels[i]->attr.wakeup_events = 1; | 74 | evsels[i]->attr.wakeup_events = 1; |
@@ -80,7 +80,7 @@ int test__basic_mmap(void) | |||
80 | pr_debug("failed to open counter: %s, " | 80 | pr_debug("failed to open counter: %s, " |
81 | "tweak /proc/sys/kernel/perf_event_paranoid?\n", | 81 | "tweak /proc/sys/kernel/perf_event_paranoid?\n", |
82 | strerror(errno)); | 82 | strerror(errno)); |
83 | goto out_close_fd; | 83 | goto out_delete_evlist; |
84 | } | 84 | } |
85 | 85 | ||
86 | nr_events[i] = 0; | 86 | nr_events[i] = 0; |
@@ -90,7 +90,7 @@ int test__basic_mmap(void) | |||
90 | if (perf_evlist__mmap(evlist, 128, true) < 0) { | 90 | if (perf_evlist__mmap(evlist, 128, true) < 0) { |
91 | pr_debug("failed to mmap events: %d (%s)\n", errno, | 91 | pr_debug("failed to mmap events: %d (%s)\n", errno, |
92 | strerror(errno)); | 92 | strerror(errno)); |
93 | goto out_close_fd; | 93 | goto out_delete_evlist; |
94 | } | 94 | } |
95 | 95 | ||
96 | for (i = 0; i < nsyscalls; ++i) | 96 | for (i = 0; i < nsyscalls; ++i) |
@@ -138,10 +138,7 @@ int test__basic_mmap(void) | |||
138 | 138 | ||
139 | out_munmap: | 139 | out_munmap: |
140 | perf_evlist__munmap(evlist); | 140 | perf_evlist__munmap(evlist); |
141 | out_close_fd: | 141 | out_delete_evlist: |
142 | for (i = 0; i < nsyscalls; ++i) | ||
143 | perf_evsel__close_fd(evsels[i], 1, threads->nr); | ||
144 | out_free_evlist: | ||
145 | perf_evlist__delete(evlist); | 142 | perf_evlist__delete(evlist); |
146 | cpus = NULL; | 143 | cpus = NULL; |
147 | threads = NULL; | 144 | threads = NULL; |