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 | |
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>
-rw-r--r-- | tools/perf/builtin-record.c | 1 | ||||
-rw-r--r-- | tools/perf/builtin-trace.c | 4 | ||||
-rw-r--r-- | tools/perf/tests/code-reading.c | 1 | ||||
-rw-r--r-- | tools/perf/tests/keep-tracking.c | 1 | ||||
-rw-r--r-- | tools/perf/tests/mmap-basic.c | 11 | ||||
-rw-r--r-- | tools/perf/tests/open-syscall-tp-fields.c | 4 | ||||
-rw-r--r-- | tools/perf/tests/perf-record.c | 4 | ||||
-rw-r--r-- | tools/perf/tests/perf-time-to-tsc.c | 1 | ||||
-rw-r--r-- | tools/perf/tests/sw-clock.c | 4 | ||||
-rw-r--r-- | tools/perf/tests/task-exit.c | 4 | ||||
-rw-r--r-- | tools/perf/util/evlist.c | 1 |
11 files changed, 10 insertions, 26 deletions
diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c index 5149b41e63d1..b7f5e438276b 100644 --- a/tools/perf/builtin-record.c +++ b/tools/perf/builtin-record.c | |||
@@ -970,7 +970,6 @@ int cmd_record(int argc, const char **argv, const char *prefix __maybe_unused) | |||
970 | err = __cmd_record(&record, argc, argv); | 970 | err = __cmd_record(&record, argc, argv); |
971 | 971 | ||
972 | perf_evlist__munmap(rec->evlist); | 972 | perf_evlist__munmap(rec->evlist); |
973 | perf_evlist__close(rec->evlist); | ||
974 | out_symbol_exit: | 973 | out_symbol_exit: |
975 | symbol__exit(); | 974 | symbol__exit(); |
976 | return err; | 975 | return err; |
diff --git a/tools/perf/builtin-trace.c b/tools/perf/builtin-trace.c index f4ddd14b8a9b..aa8a5f46c361 100644 --- a/tools/perf/builtin-trace.c +++ b/tools/perf/builtin-trace.c | |||
@@ -1909,7 +1909,7 @@ static int trace__run(struct trace *trace, int argc, const char **argv) | |||
1909 | err = perf_evlist__mmap(evlist, trace->opts.mmap_pages, false); | 1909 | err = perf_evlist__mmap(evlist, trace->opts.mmap_pages, false); |
1910 | if (err < 0) { | 1910 | if (err < 0) { |
1911 | fprintf(trace->output, "Couldn't mmap the events: %s\n", strerror(errno)); | 1911 | fprintf(trace->output, "Couldn't mmap the events: %s\n", strerror(errno)); |
1912 | goto out_close_evlist; | 1912 | goto out_delete_evlist; |
1913 | } | 1913 | } |
1914 | 1914 | ||
1915 | perf_evlist__enable(evlist); | 1915 | perf_evlist__enable(evlist); |
@@ -1994,8 +1994,6 @@ out_disable: | |||
1994 | } | 1994 | } |
1995 | 1995 | ||
1996 | perf_evlist__munmap(evlist); | 1996 | perf_evlist__munmap(evlist); |
1997 | out_close_evlist: | ||
1998 | perf_evlist__close(evlist); | ||
1999 | out_delete_evlist: | 1997 | out_delete_evlist: |
2000 | perf_evlist__delete(evlist); | 1998 | perf_evlist__delete(evlist); |
2001 | out: | 1999 | out: |
diff --git a/tools/perf/tests/code-reading.c b/tools/perf/tests/code-reading.c index ddbc7756620c..2c0ce723749f 100644 --- a/tools/perf/tests/code-reading.c +++ b/tools/perf/tests/code-reading.c | |||
@@ -541,7 +541,6 @@ static int do_test_code_reading(bool try_kcore) | |||
541 | out_err: | 541 | out_err: |
542 | if (evlist) { | 542 | if (evlist) { |
543 | perf_evlist__munmap(evlist); | 543 | perf_evlist__munmap(evlist); |
544 | perf_evlist__close(evlist); | ||
545 | perf_evlist__delete(evlist); | 544 | perf_evlist__delete(evlist); |
546 | } else { | 545 | } else { |
547 | cpu_map__delete(cpus); | 546 | cpu_map__delete(cpus); |
diff --git a/tools/perf/tests/keep-tracking.c b/tools/perf/tests/keep-tracking.c index f9bc1fcd17cd..dd1c677510bd 100644 --- a/tools/perf/tests/keep-tracking.c +++ b/tools/perf/tests/keep-tracking.c | |||
@@ -143,7 +143,6 @@ out_err: | |||
143 | if (evlist) { | 143 | if (evlist) { |
144 | perf_evlist__disable(evlist); | 144 | perf_evlist__disable(evlist); |
145 | perf_evlist__munmap(evlist); | 145 | perf_evlist__munmap(evlist); |
146 | perf_evlist__close(evlist); | ||
147 | perf_evlist__delete(evlist); | 146 | perf_evlist__delete(evlist); |
148 | } else { | 147 | } else { |
149 | cpu_map__delete(cpus); | 148 | cpu_map__delete(cpus); |
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; |
diff --git a/tools/perf/tests/open-syscall-tp-fields.c b/tools/perf/tests/open-syscall-tp-fields.c index 595b577172a6..0a00638a9ebb 100644 --- a/tools/perf/tests/open-syscall-tp-fields.c +++ b/tools/perf/tests/open-syscall-tp-fields.c | |||
@@ -54,7 +54,7 @@ int test__syscall_open_tp_fields(void) | |||
54 | err = perf_evlist__mmap(evlist, UINT_MAX, false); | 54 | err = perf_evlist__mmap(evlist, UINT_MAX, false); |
55 | if (err < 0) { | 55 | if (err < 0) { |
56 | pr_debug("perf_evlist__mmap: %s\n", strerror(errno)); | 56 | pr_debug("perf_evlist__mmap: %s\n", strerror(errno)); |
57 | goto out_close_evlist; | 57 | goto out_delete_evlist; |
58 | } | 58 | } |
59 | 59 | ||
60 | perf_evlist__enable(evlist); | 60 | perf_evlist__enable(evlist); |
@@ -112,8 +112,6 @@ out_ok: | |||
112 | err = 0; | 112 | err = 0; |
113 | out_munmap: | 113 | out_munmap: |
114 | perf_evlist__munmap(evlist); | 114 | perf_evlist__munmap(evlist); |
115 | out_close_evlist: | ||
116 | perf_evlist__close(evlist); | ||
117 | out_delete_evlist: | 115 | out_delete_evlist: |
118 | perf_evlist__delete(evlist); | 116 | perf_evlist__delete(evlist); |
119 | out: | 117 | out: |
diff --git a/tools/perf/tests/perf-record.c b/tools/perf/tests/perf-record.c index 266da9d41300..682978e66efe 100644 --- a/tools/perf/tests/perf-record.c +++ b/tools/perf/tests/perf-record.c | |||
@@ -132,7 +132,7 @@ int test__PERF_RECORD(void) | |||
132 | err = perf_evlist__mmap(evlist, opts.mmap_pages, false); | 132 | err = perf_evlist__mmap(evlist, opts.mmap_pages, false); |
133 | if (err < 0) { | 133 | if (err < 0) { |
134 | pr_debug("perf_evlist__mmap: %s\n", strerror(errno)); | 134 | pr_debug("perf_evlist__mmap: %s\n", strerror(errno)); |
135 | goto out_close_evlist; | 135 | goto out_delete_evlist; |
136 | } | 136 | } |
137 | 137 | ||
138 | /* | 138 | /* |
@@ -304,8 +304,6 @@ found_exit: | |||
304 | } | 304 | } |
305 | out_err: | 305 | out_err: |
306 | perf_evlist__munmap(evlist); | 306 | perf_evlist__munmap(evlist); |
307 | out_close_evlist: | ||
308 | perf_evlist__close(evlist); | ||
309 | out_delete_evlist: | 307 | out_delete_evlist: |
310 | perf_evlist__delete(evlist); | 308 | perf_evlist__delete(evlist); |
311 | out: | 309 | out: |
diff --git a/tools/perf/tests/perf-time-to-tsc.c b/tools/perf/tests/perf-time-to-tsc.c index 97d08fff1f8d..3d50f2d2a4d5 100644 --- a/tools/perf/tests/perf-time-to-tsc.c +++ b/tools/perf/tests/perf-time-to-tsc.c | |||
@@ -167,7 +167,6 @@ out_err: | |||
167 | if (evlist) { | 167 | if (evlist) { |
168 | perf_evlist__disable(evlist); | 168 | perf_evlist__disable(evlist); |
169 | perf_evlist__munmap(evlist); | 169 | perf_evlist__munmap(evlist); |
170 | perf_evlist__close(evlist); | ||
171 | perf_evlist__delete(evlist); | 170 | perf_evlist__delete(evlist); |
172 | } | 171 | } |
173 | 172 | ||
diff --git a/tools/perf/tests/sw-clock.c b/tools/perf/tests/sw-clock.c index 266d38127ba6..b366f0edca79 100644 --- a/tools/perf/tests/sw-clock.c +++ b/tools/perf/tests/sw-clock.c | |||
@@ -70,7 +70,7 @@ static int __test__sw_clock_freq(enum perf_sw_ids clock_id) | |||
70 | if (err < 0) { | 70 | if (err < 0) { |
71 | pr_debug("failed to mmap event: %d (%s)\n", errno, | 71 | pr_debug("failed to mmap event: %d (%s)\n", errno, |
72 | strerror(errno)); | 72 | strerror(errno)); |
73 | goto out_close_evlist; | 73 | goto out_delete_evlist; |
74 | } | 74 | } |
75 | 75 | ||
76 | perf_evlist__enable(evlist); | 76 | perf_evlist__enable(evlist); |
@@ -107,8 +107,6 @@ next_event: | |||
107 | 107 | ||
108 | out_unmap_evlist: | 108 | out_unmap_evlist: |
109 | perf_evlist__munmap(evlist); | 109 | perf_evlist__munmap(evlist); |
110 | out_close_evlist: | ||
111 | perf_evlist__close(evlist); | ||
112 | out_delete_evlist: | 110 | out_delete_evlist: |
113 | perf_evlist__delete(evlist); | 111 | perf_evlist__delete(evlist); |
114 | return err; | 112 | return err; |
diff --git a/tools/perf/tests/task-exit.c b/tools/perf/tests/task-exit.c index fdeb2aa46a50..5511a0a929cd 100644 --- a/tools/perf/tests/task-exit.c +++ b/tools/perf/tests/task-exit.c | |||
@@ -89,7 +89,7 @@ int test__task_exit(void) | |||
89 | if (perf_evlist__mmap(evlist, 128, true) < 0) { | 89 | if (perf_evlist__mmap(evlist, 128, true) < 0) { |
90 | pr_debug("failed to mmap events: %d (%s)\n", errno, | 90 | pr_debug("failed to mmap events: %d (%s)\n", errno, |
91 | strerror(errno)); | 91 | strerror(errno)); |
92 | goto out_close_evlist; | 92 | goto out_delete_evlist; |
93 | } | 93 | } |
94 | 94 | ||
95 | perf_evlist__start_workload(evlist); | 95 | perf_evlist__start_workload(evlist); |
@@ -113,8 +113,6 @@ retry: | |||
113 | } | 113 | } |
114 | 114 | ||
115 | perf_evlist__munmap(evlist); | 115 | perf_evlist__munmap(evlist); |
116 | out_close_evlist: | ||
117 | perf_evlist__close(evlist); | ||
118 | out_delete_evlist: | 116 | out_delete_evlist: |
119 | perf_evlist__delete(evlist); | 117 | perf_evlist__delete(evlist); |
120 | return err; | 118 | return err; |
diff --git a/tools/perf/util/evlist.c b/tools/perf/util/evlist.c index 143eaf05178f..a083bdc4680e 100644 --- a/tools/perf/util/evlist.c +++ b/tools/perf/util/evlist.c | |||
@@ -107,6 +107,7 @@ void perf_evlist__exit(struct perf_evlist *evlist) | |||
107 | 107 | ||
108 | void perf_evlist__delete(struct perf_evlist *evlist) | 108 | void perf_evlist__delete(struct perf_evlist *evlist) |
109 | { | 109 | { |
110 | perf_evlist__close(evlist); | ||
110 | cpu_map__delete(evlist->cpus); | 111 | cpu_map__delete(evlist->cpus); |
111 | thread_map__delete(evlist->threads); | 112 | thread_map__delete(evlist->threads); |
112 | evlist->cpus = NULL; | 113 | evlist->cpus = NULL; |