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

perf stat: Use 'struct outstate' in evlist__print_counters()

This is a preparation for the later cleanup.  No functional changes
intended.
Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
Acked-by: default avatarIan Rogers <irogers@google.com>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Athira Jajeev <atrajeev@linux.vnet.ibm.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: James Clark <james.clark@arm.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Kan Liang <kan.liang@linux.intel.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Xing Zhengjun <zhengjun.xing@linux.intel.com>
Link: https://lore.kernel.org/r/20221123180208.2068936-9-namhyung@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 991991ab
...@@ -1372,13 +1372,16 @@ void evlist__print_counters(struct evlist *evlist, struct perf_stat_config *conf ...@@ -1372,13 +1372,16 @@ void evlist__print_counters(struct evlist *evlist, struct perf_stat_config *conf
bool metric_only = config->metric_only; bool metric_only = config->metric_only;
int interval = config->interval; int interval = config->interval;
struct evsel *counter; struct evsel *counter;
char buf[64], *prefix = NULL; char buf[64];
struct outstate os = {
.fh = config->output,
};
if (config->iostat_run) if (config->iostat_run)
evlist->selected = evlist__first(evlist); evlist->selected = evlist__first(evlist);
if (interval) { if (interval) {
prefix = buf; os.prefix = buf;
prepare_interval(config, buf, sizeof(buf), ts); prepare_interval(config, buf, sizeof(buf), ts);
} }
...@@ -1390,35 +1393,35 @@ void evlist__print_counters(struct evlist *evlist, struct perf_stat_config *conf ...@@ -1390,35 +1393,35 @@ void evlist__print_counters(struct evlist *evlist, struct perf_stat_config *conf
case AGGR_SOCKET: case AGGR_SOCKET:
case AGGR_NODE: case AGGR_NODE:
if (config->cgroup_list) if (config->cgroup_list)
print_aggr_cgroup(config, evlist, prefix); print_aggr_cgroup(config, evlist, os.prefix);
else else
print_aggr(config, evlist, prefix); print_aggr(config, evlist, os.prefix);
break; break;
case AGGR_THREAD: case AGGR_THREAD:
case AGGR_GLOBAL: case AGGR_GLOBAL:
if (config->iostat_run) { if (config->iostat_run) {
iostat_print_counters(evlist, config, ts, prefix = buf, iostat_print_counters(evlist, config, ts, buf,
print_counter); print_counter);
} else if (config->cgroup_list) { } else if (config->cgroup_list) {
print_cgroup_counter(config, evlist, prefix); print_cgroup_counter(config, evlist, os.prefix);
} else { } else {
print_metric_begin(config, evlist, prefix, print_metric_begin(config, evlist, os.prefix,
/*aggr_idx=*/0, /*cgrp=*/NULL); /*aggr_idx=*/0, /*cgrp=*/NULL);
evlist__for_each_entry(evlist, counter) { evlist__for_each_entry(evlist, counter) {
print_counter(config, counter, prefix); print_counter(config, counter, os.prefix);
} }
print_metric_end(config); print_metric_end(config);
} }
break; break;
case AGGR_NONE: case AGGR_NONE:
if (metric_only) if (metric_only)
print_no_aggr_metric(config, evlist, prefix); print_no_aggr_metric(config, evlist, os.prefix);
else { else {
evlist__for_each_entry(evlist, counter) { evlist__for_each_entry(evlist, counter) {
if (counter->percore) if (counter->percore)
print_percore(config, counter, prefix); print_percore(config, counter, os.prefix);
else else
print_counter(config, counter, prefix); print_counter(config, counter, os.prefix);
} }
} }
break; break;
......
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