diff options
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; |