Commit bf8f8587 authored by Namhyung Kim's avatar Namhyung Kim Committed by Arnaldo Carvalho de Melo

perf top: Use evlist->events_stat to count events

It's mainly to count lost events for the warning so it should be ok
to use the evlist->stats instead.  This is needed for changes in the
next commit.
Reviewed-by: default avatarAndi Kleen <ak@linux.intel.com>
Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
Acked-by: default avatarJiri Olsa <jolsa@redhat.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Ian Rogers <irogers@google.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: https://lore.kernel.org/r/20210427013717.1651674-2-namhyung@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent d0713d4c
...@@ -328,13 +328,13 @@ static void perf_top__print_sym_table(struct perf_top *top) ...@@ -328,13 +328,13 @@ static void perf_top__print_sym_table(struct perf_top *top)
printf("%-*.*s\n", win_width, win_width, graph_dotted_line); printf("%-*.*s\n", win_width, win_width, graph_dotted_line);
if (!top->record_opts.overwrite && if (!top->record_opts.overwrite &&
(hists->stats.nr_lost_warned != (top->evlist->stats.nr_lost_warned !=
hists->stats.nr_events[PERF_RECORD_LOST])) { top->evlist->stats.nr_events[PERF_RECORD_LOST])) {
hists->stats.nr_lost_warned = top->evlist->stats.nr_lost_warned =
hists->stats.nr_events[PERF_RECORD_LOST]; top->evlist->stats.nr_events[PERF_RECORD_LOST];
color_fprintf(stdout, PERF_COLOR_RED, color_fprintf(stdout, PERF_COLOR_RED,
"WARNING: LOST %d chunks, Check IO/CPU overload", "WARNING: LOST %d chunks, Check IO/CPU overload",
hists->stats.nr_lost_warned); top->evlist->stats.nr_lost_warned);
++printed; ++printed;
} }
...@@ -852,11 +852,9 @@ static void ...@@ -852,11 +852,9 @@ static void
perf_top__process_lost(struct perf_top *top, union perf_event *event, perf_top__process_lost(struct perf_top *top, union perf_event *event,
struct evsel *evsel) struct evsel *evsel)
{ {
struct hists *hists = evsel__hists(evsel);
top->lost += event->lost.lost; top->lost += event->lost.lost;
top->lost_total += event->lost.lost; top->lost_total += event->lost.lost;
hists->stats.total_lost += event->lost.lost; evsel->evlist->stats.total_lost += event->lost.lost;
} }
static void static void
...@@ -864,11 +862,9 @@ perf_top__process_lost_samples(struct perf_top *top, ...@@ -864,11 +862,9 @@ perf_top__process_lost_samples(struct perf_top *top,
union perf_event *event, union perf_event *event,
struct evsel *evsel) struct evsel *evsel)
{ {
struct hists *hists = evsel__hists(evsel);
top->lost += event->lost_samples.lost; top->lost += event->lost_samples.lost;
top->lost_total += event->lost_samples.lost; top->lost_total += event->lost_samples.lost;
hists->stats.total_lost_samples += event->lost_samples.lost; evsel->evlist->stats.total_lost_samples += event->lost_samples.lost;
} }
static u64 last_timestamp; static u64 last_timestamp;
...@@ -1205,7 +1201,7 @@ static int deliver_event(struct ordered_events *qe, ...@@ -1205,7 +1201,7 @@ static int deliver_event(struct ordered_events *qe,
} else if (event->header.type == PERF_RECORD_LOST_SAMPLES) { } else if (event->header.type == PERF_RECORD_LOST_SAMPLES) {
perf_top__process_lost_samples(top, event, evsel); perf_top__process_lost_samples(top, event, evsel);
} else if (event->header.type < PERF_RECORD_MAX) { } else if (event->header.type < PERF_RECORD_MAX) {
hists__inc_nr_events(evsel__hists(evsel), event->header.type); events_stats__inc(&session->evlist->stats, event->header.type);
machine__process_event(machine, event, &sample); machine__process_event(machine, event, &sample);
} else } else
++session->evlist->stats.nr_unknown_events; ++session->evlist->stats.nr_unknown_events;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment