perf evsel: Move exit stuff from __delete to __exit
authorArnaldo Carvalho de Melo <acme@redhat.com>
Thu, 16 Oct 2014 16:25:01 +0000 (13:25 -0300)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Fri, 17 Oct 2014 14:14:15 +0000 (11:14 -0300)
So that when an evsel is embedded into other struct it can free up
resources calling perf_evsel__exit().

Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Borislav Petkov <bp@suse.de>
Cc: David Ahern <dsahern@gmail.com>
Cc: Don Zickus <dzickus@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Jean Pihet <jean.pihet@linaro.org>
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-n1w68pfe9m2vkhm4sqs8y1en@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/util/evsel.c

index d1ecde0fd56c456a8b3abcb56ff08a97690e090e..786ea557af26285d806ca6728782a39d43bc2071 100644 (file)
@@ -850,17 +850,17 @@ void perf_evsel__exit(struct perf_evsel *evsel)
        assert(list_empty(&evsel->node));
        perf_evsel__free_fd(evsel);
        perf_evsel__free_id(evsel);
+       close_cgroup(evsel->cgrp);
+       zfree(&evsel->group_name);
+       if (evsel->tp_format)
+               pevent_free_format(evsel->tp_format);
+       zfree(&evsel->name);
        perf_evsel__object.fini(evsel);
 }
 
 void perf_evsel__delete(struct perf_evsel *evsel)
 {
        perf_evsel__exit(evsel);
-       close_cgroup(evsel->cgrp);
-       zfree(&evsel->group_name);
-       if (evsel->tp_format)
-               pevent_free_format(evsel->tp_format);
-       zfree(&evsel->name);
        free(evsel);
 }