diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2010-05-10 12:04:11 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2010-05-10 12:13:49 -0400 |
commit | 1c02c4d2e92f2097f1bba63ec71560b0e05a7f36 (patch) | |
tree | ad2a722931398ce3cd3ae850c4cfa148558a52ea /tools/perf/util/hist.h | |
parent | d118f8ba6ac2af2bf11d40cba657c813f0f39ca2 (diff) |
perf hist: Introduce hists class and move lots of methods to it
In cbbc79a we introduced support for multiple events by introducing a
new "event_stat_id" struct and then made several perf_session methods
receive a point to it instead of a pointer to perf_session, and kept the
event_stats and hists rb_tree in perf_session.
While working on the new newt based browser, I realised that it would be
better to introduce a new class, "hists" (short for "histograms"),
renaming the "event_stat_id" struct and the perf_session methods that
were really "hists" methods, as they manipulate only struct hists
members, not touching anything in the other perf_session members.
Other optimizations, such as calculating the maximum lenght of a symbol
name present in an hists instance will be possible as we add them,
avoiding a re-traversal just for finding that information.
The rationale for the name "hists" to replace "event_stat_id" is that we
may have multiple sets of hists for the same event_stat id, as, for
instance, the 'perf diff' tool has, so event stat id is not what
characterizes what this struct and the functions that manipulate it do.
Cc: Eric B Munson <ebmunson@us.ibm.com>
Cc: Frédéric Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Tom Zanussi <tzanussi@gmail.com>
LKML-Reference: <new-submission>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/hist.h')
-rw-r--r-- | tools/perf/util/hist.h | 48 |
1 files changed, 27 insertions, 21 deletions
diff --git a/tools/perf/util/hist.h b/tools/perf/util/hist.h index b49013adb34b..bdde81eca69f 100644 --- a/tools/perf/util/hist.h +++ b/tools/perf/util/hist.h | |||
@@ -6,34 +6,40 @@ | |||
6 | 6 | ||
7 | extern struct callchain_param callchain_param; | 7 | extern struct callchain_param callchain_param; |
8 | 8 | ||
9 | struct perf_session; | ||
10 | struct hist_entry; | 9 | struct hist_entry; |
11 | struct addr_location; | 10 | struct addr_location; |
12 | struct symbol; | 11 | struct symbol; |
13 | struct rb_root; | 12 | struct rb_root; |
14 | 13 | ||
15 | struct hist_entry *__perf_session__add_hist_entry(struct rb_root *hists, | 14 | struct events_stats { |
16 | struct addr_location *al, | 15 | u64 total; |
17 | struct symbol *parent, | 16 | u64 lost; |
18 | u64 count); | 17 | }; |
18 | |||
19 | struct hists { | ||
20 | struct rb_node rb_node; | ||
21 | struct rb_root entries; | ||
22 | struct events_stats stats; | ||
23 | u64 config; | ||
24 | u64 event_stream; | ||
25 | u32 type; | ||
26 | }; | ||
27 | |||
28 | struct hist_entry *__hists__add_entry(struct hists *self, | ||
29 | struct addr_location *al, | ||
30 | struct symbol *parent, u64 count); | ||
19 | extern int64_t hist_entry__cmp(struct hist_entry *, struct hist_entry *); | 31 | extern int64_t hist_entry__cmp(struct hist_entry *, struct hist_entry *); |
20 | extern int64_t hist_entry__collapse(struct hist_entry *, struct hist_entry *); | 32 | extern int64_t hist_entry__collapse(struct hist_entry *, struct hist_entry *); |
21 | int hist_entry__fprintf(struct hist_entry *self, | 33 | int hist_entry__fprintf(struct hist_entry *self, struct hists *pair_hists, |
22 | struct perf_session *pair_session, | 34 | bool show_displacement, long displacement, FILE *fp, |
23 | bool show_displacement, | 35 | u64 total); |
24 | long displacement, FILE *fp, | 36 | int hist_entry__snprintf(struct hist_entry *self, char *bf, size_t size, |
25 | u64 session_total); | 37 | struct hists *pair_hists, bool show_displacement, |
26 | int hist_entry__snprintf(struct hist_entry *self, | 38 | long displacement, bool color, u64 total); |
27 | char *bf, size_t size, | ||
28 | struct perf_session *pair_session, | ||
29 | bool show_displacement, long displacement, | ||
30 | bool color, u64 session_total); | ||
31 | void hist_entry__free(struct hist_entry *); | 39 | void hist_entry__free(struct hist_entry *); |
32 | 40 | ||
33 | u64 perf_session__output_resort(struct rb_root *hists, u64 total_samples); | 41 | u64 hists__output_resort(struct hists *self); |
34 | void perf_session__collapse_resort(struct rb_root *hists); | 42 | void hists__collapse_resort(struct hists *self); |
35 | size_t perf_session__fprintf_hists(struct rb_root *hists, | 43 | size_t hists__fprintf(struct hists *self, struct hists *pair, |
36 | struct perf_session *pair, | 44 | bool show_displacement, FILE *fp); |
37 | bool show_displacement, FILE *fp, | ||
38 | u64 session_total); | ||
39 | #endif /* __PERF_HIST_H */ | 45 | #endif /* __PERF_HIST_H */ |