|
@@ -721,10 +721,20 @@ void perf_evlist__set_selected(struct perf_evlist *evlist,
|
|
|
evlist->selected = evsel;
|
|
|
}
|
|
|
|
|
|
+void perf_evlist__close(struct perf_evlist *evlist)
|
|
|
+{
|
|
|
+ struct perf_evsel *evsel;
|
|
|
+ int ncpus = cpu_map__nr(evlist->cpus);
|
|
|
+ int nthreads = thread_map__nr(evlist->threads);
|
|
|
+
|
|
|
+ list_for_each_entry_reverse(evsel, &evlist->entries, node)
|
|
|
+ perf_evsel__close(evsel, ncpus, nthreads);
|
|
|
+}
|
|
|
+
|
|
|
int perf_evlist__open(struct perf_evlist *evlist)
|
|
|
{
|
|
|
struct perf_evsel *evsel;
|
|
|
- int err, ncpus, nthreads;
|
|
|
+ int err;
|
|
|
|
|
|
list_for_each_entry(evsel, &evlist->entries, node) {
|
|
|
err = perf_evsel__open(evsel, evlist->cpus, evlist->threads);
|
|
@@ -734,12 +744,7 @@ int perf_evlist__open(struct perf_evlist *evlist)
|
|
|
|
|
|
return 0;
|
|
|
out_err:
|
|
|
- ncpus = cpu_map__nr(evlist->cpus);
|
|
|
- nthreads = thread_map__nr(evlist->threads);
|
|
|
-
|
|
|
- list_for_each_entry_reverse(evsel, &evlist->entries, node)
|
|
|
- perf_evsel__close(evsel, ncpus, nthreads);
|
|
|
-
|
|
|
+ perf_evlist__close(evlist);
|
|
|
errno = -err;
|
|
|
return err;
|
|
|
}
|