aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf
diff options
context:
space:
mode:
authorArnaldo Carvalho de Melo <acme@redhat.com>2014-10-09 14:29:51 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2014-10-14 16:32:03 -0400
commitce8ccff5dd6b87dfe3495c7e9c5d56169bbacf58 (patch)
treee40b13129e87e5f7a9e0544776f151d4e5084965 /tools/perf
parent2a1731fb85ec96a1f6a326fb2d52cd93494dafa2 (diff)
perf evsel: Subclassing
Provide a method to be called at tool start to config the perf_evsel instance size, together with optional constructor and destructor. This will be used so that perf_evsel doesn't always include a struct hists, tools that works with hists/hist_entries, like report, top and annotate, will, at start, tell the evsel class the size they need per instance. v2: Don't use exit as a name of a member of function parameter, as this breaks the build on at least fedora14 and rhel6. 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-7t8cay0ieryox4gqosie85ek@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf')
-rw-r--r--tools/perf/util/evsel.c48
-rw-r--r--tools/perf/util/evsel.h4
2 files changed, 50 insertions, 2 deletions
diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c
index e0868a901c4a..0580b13df2e6 100644
--- a/tools/perf/util/evsel.c
+++ b/tools/perf/util/evsel.c
@@ -32,6 +32,48 @@ static struct {
32 bool cloexec; 32 bool cloexec;
33} perf_missing_features; 33} perf_missing_features;
34 34
35static int perf_evsel__no_extra_init(struct perf_evsel *evsel __maybe_unused)
36{
37 return 0;
38}
39
40static void perf_evsel__no_extra_fini(struct perf_evsel *evsel __maybe_unused)
41{
42}
43
44static struct {
45 size_t size;
46 int (*init)(struct perf_evsel *evsel);
47 void (*fini)(struct perf_evsel *evsel);
48} perf_evsel__object = {
49 .size = sizeof(struct perf_evsel),
50 .init = perf_evsel__no_extra_init,
51 .fini = perf_evsel__no_extra_fini,
52};
53
54int perf_evsel__object_config(size_t object_size,
55 int (*init)(struct perf_evsel *evsel),
56 void (*fini)(struct perf_evsel *evsel))
57{
58
59 if (object_size == 0)
60 goto set_methods;
61
62 if (perf_evsel__object.size > object_size)
63 return -EINVAL;
64
65 perf_evsel__object.size = object_size;
66
67set_methods:
68 if (init != NULL)
69 perf_evsel__object.init = init;
70
71 if (fini != NULL)
72 perf_evsel__object.fini = fini;
73
74 return 0;
75}
76
35#define FD(e, x, y) (*(int *)xyarray__entry(e->fd, x, y)) 77#define FD(e, x, y) (*(int *)xyarray__entry(e->fd, x, y))
36 78
37int __perf_evsel__sample_size(u64 sample_type) 79int __perf_evsel__sample_size(u64 sample_type)
@@ -169,13 +211,14 @@ void perf_evsel__init(struct perf_evsel *evsel,
169 evsel->scale = 1.0; 211 evsel->scale = 1.0;
170 INIT_LIST_HEAD(&evsel->node); 212 INIT_LIST_HEAD(&evsel->node);
171 hists__init(&evsel->hists); 213 hists__init(&evsel->hists);
214 perf_evsel__object.init(evsel);
172 evsel->sample_size = __perf_evsel__sample_size(attr->sample_type); 215 evsel->sample_size = __perf_evsel__sample_size(attr->sample_type);
173 perf_evsel__calc_id_pos(evsel); 216 perf_evsel__calc_id_pos(evsel);
174} 217}
175 218
176struct perf_evsel *perf_evsel__new_idx(struct perf_event_attr *attr, int idx) 219struct perf_evsel *perf_evsel__new_idx(struct perf_event_attr *attr, int idx)
177{ 220{
178 struct perf_evsel *evsel = zalloc(sizeof(*evsel)); 221 struct perf_evsel *evsel = zalloc(perf_evsel__object.size);
179 222
180 if (evsel != NULL) 223 if (evsel != NULL)
181 perf_evsel__init(evsel, attr, idx); 224 perf_evsel__init(evsel, attr, idx);
@@ -185,7 +228,7 @@ struct perf_evsel *perf_evsel__new_idx(struct perf_event_attr *attr, int idx)
185 228
186struct perf_evsel *perf_evsel__newtp_idx(const char *sys, const char *name, int idx) 229struct perf_evsel *perf_evsel__newtp_idx(const char *sys, const char *name, int idx)
187{ 230{
188 struct perf_evsel *evsel = zalloc(sizeof(*evsel)); 231 struct perf_evsel *evsel = zalloc(perf_evsel__object.size);
189 232
190 if (evsel != NULL) { 233 if (evsel != NULL) {
191 struct perf_event_attr attr = { 234 struct perf_event_attr attr = {
@@ -817,6 +860,7 @@ void perf_evsel__exit(struct perf_evsel *evsel)
817 assert(list_empty(&evsel->node)); 860 assert(list_empty(&evsel->node));
818 perf_evsel__free_fd(evsel); 861 perf_evsel__free_fd(evsel);
819 perf_evsel__free_id(evsel); 862 perf_evsel__free_id(evsel);
863 perf_evsel__object.fini(evsel);
820} 864}
821 865
822void perf_evsel__delete(struct perf_evsel *evsel) 866void perf_evsel__delete(struct perf_evsel *evsel)
diff --git a/tools/perf/util/evsel.h b/tools/perf/util/evsel.h
index ff72ce058724..d6325106c8fd 100644
--- a/tools/perf/util/evsel.h
+++ b/tools/perf/util/evsel.h
@@ -112,6 +112,10 @@ struct thread_map;
112struct perf_evlist; 112struct perf_evlist;
113struct record_opts; 113struct record_opts;
114 114
115int perf_evsel__object_config(size_t object_size,
116 int (*init)(struct perf_evsel *evsel),
117 void (*fini)(struct perf_evsel *evsel));
118
115struct perf_evsel *perf_evsel__new_idx(struct perf_event_attr *attr, int idx); 119struct perf_evsel *perf_evsel__new_idx(struct perf_event_attr *attr, int idx);
116 120
117static inline struct perf_evsel *perf_evsel__new(struct perf_event_attr *attr) 121static inline struct perf_evsel *perf_evsel__new(struct perf_event_attr *attr)