diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2015-03-31 12:48:16 -0300 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2015-03-31 17:52:32 -0300 |
commit | 9870d7809575515e26194f4b3df1750872a6ee60 (patch) | |
tree | 43905494fe3c7724b8fe4326a4e820e897e7a7e9 /tools/perf/util/session.c | |
parent | aae59fab978e143f24d22e52f075c4be3ee4e628 (diff) | |
download | lwn-9870d7809575515e26194f4b3df1750872a6ee60.tar.gz lwn-9870d7809575515e26194f4b3df1750872a6ee60.zip |
perf ordered_samples: Remove references to perf_{evlist,tool} and machines
As these can be obtained from the ordered_events pointer, via
container_of, reducing the cross section of ordered_samples.
These were added to ordered_samples in:
commit b7b61cbebd789a3dbca522e3fdb727fe5c95593f
Author: Arnaldo Carvalho de Melo <acme@redhat.com>
Date: Tue Mar 3 11:58:45 2015 -0300
perf ordered_events: Shorten function signatures
By keeping pointers to machines, evlist and tool in ordered_events.
But that was more a transitional patch while moving stuff out from
perf_session.c to ordered_events.c and possibly not even needed by then,
as we could use the container_of() method and instead of having the
nr_unordered_samples stats in events_stats, we can have it in
ordered_samples.
Based-on-a-patch-by: Jiri Olsa <jolsa@kernel.org>
Acked-by: Jiri Olsa <jolsa@kernel.org>
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: Namhyung Kim <namhyung@kernel.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-4lk0t9js82g0tfc0x1onpkjt@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/session.c')
-rw-r--r-- | tools/perf/util/session.c | 47 |
1 files changed, 29 insertions, 18 deletions
diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index 89c66797abe4..dfacf1d50162 100644 --- a/tools/perf/util/session.c +++ b/tools/perf/util/session.c @@ -93,11 +93,20 @@ static void perf_session__set_comm_exec(struct perf_session *session) } static int ordered_events__deliver_event(struct ordered_events *oe, - struct ordered_event *event, - struct perf_sample *sample) + struct ordered_event *event) { - return machines__deliver_event(oe->machines, oe->evlist, event->event, - sample, oe->tool, event->file_offset); + struct perf_sample sample; + struct perf_session *session = container_of(oe, struct perf_session, + ordered_events); + int ret = perf_evlist__parse_sample(session->evlist, event->event, &sample); + + if (ret) { + pr_err("Can't parse sample, err = %d\n", ret); + return ret; + } + + return machines__deliver_event(&session->machines, session->evlist, event->event, + &sample, session->tool, event->file_offset); } struct perf_session *perf_session__new(struct perf_data_file *file, @@ -109,9 +118,9 @@ struct perf_session *perf_session__new(struct perf_data_file *file, goto out; session->repipe = repipe; + session->tool = tool; machines__init(&session->machines); - ordered_events__init(&session->ordered_events, &session->machines, - session->evlist, tool, ordered_events__deliver_event); + ordered_events__init(&session->ordered_events, ordered_events__deliver_event); if (file) { if (perf_data_file__open(file)) @@ -940,7 +949,7 @@ static s64 perf_session__process_user_event(struct perf_session *session, u64 file_offset) { struct ordered_events *oe = &session->ordered_events; - struct perf_tool *tool = oe->tool; + struct perf_tool *tool = session->tool; int fd = perf_data_file__fd(session->file); int err; @@ -981,7 +990,7 @@ int perf_session__deliver_synth_event(struct perf_session *session, struct perf_sample *sample) { struct perf_evlist *evlist = session->evlist; - struct perf_tool *tool = session->ordered_events.tool; + struct perf_tool *tool = session->tool; events_stats__inc(&evlist->stats, event->header.type); @@ -1059,7 +1068,7 @@ static s64 perf_session__process_event(struct perf_session *session, union perf_event *event, u64 file_offset) { struct perf_evlist *evlist = session->evlist; - struct perf_tool *tool = session->ordered_events.tool; + struct perf_tool *tool = session->tool; struct perf_sample sample; int ret; @@ -1116,10 +1125,12 @@ static struct thread *perf_session__register_idle_thread(struct perf_session *se return thread; } -static void perf_tool__warn_about_errors(const struct perf_tool *tool, - const struct events_stats *stats) +static void perf_session__warn_about_errors(const struct perf_session *session) { - if (tool->lost == perf_event__process_lost && + const struct events_stats *stats = &session->evlist->stats; + const struct ordered_events *oe = &session->ordered_events; + + if (session->tool->lost == perf_event__process_lost && stats->nr_events[PERF_RECORD_LOST] != 0) { ui__warning("Processed %d events and lost %d chunks!\n\n" "Check IO/CPU overload!\n\n", @@ -1155,8 +1166,8 @@ static void perf_tool__warn_about_errors(const struct perf_tool *tool, stats->nr_unprocessable_samples); } - if (stats->nr_unordered_events != 0) - ui__warning("%u out of order events recorded.\n", stats->nr_unordered_events); + if (oe->nr_unordered_events != 0) + ui__warning("%u out of order events recorded.\n", oe->nr_unordered_events); } volatile int session_done; @@ -1164,7 +1175,7 @@ volatile int session_done; static int __perf_session__process_pipe_events(struct perf_session *session) { struct ordered_events *oe = &session->ordered_events; - struct perf_tool *tool = oe->tool; + struct perf_tool *tool = session->tool; int fd = perf_data_file__fd(session->file); union perf_event *event; uint32_t size, cur_size = 0; @@ -1247,7 +1258,7 @@ done: err = ordered_events__flush(oe, OE_FLUSH__FINAL); out_err: free(buf); - perf_tool__warn_about_errors(tool, &session->evlist->stats); + perf_session__warn_about_errors(session); ordered_events__free(&session->ordered_events); return err; } @@ -1297,7 +1308,7 @@ static int __perf_session__process_events(struct perf_session *session, u64 file_size) { struct ordered_events *oe = &session->ordered_events; - struct perf_tool *tool = oe->tool; + struct perf_tool *tool = session->tool; int fd = perf_data_file__fd(session->file); u64 head, page_offset, file_offset, file_pos, size; int err, mmap_prot, mmap_flags, map_idx = 0; @@ -1393,7 +1404,7 @@ out: err = ordered_events__flush(oe, OE_FLUSH__FINAL); out_err: ui_progress__finish(); - perf_tool__warn_about_errors(tool, &session->evlist->stats); + perf_session__warn_about_errors(session); ordered_events__free(&session->ordered_events); session->one_mmap = false; return err; |