diff options
author | Jin Yao <yao.jin@linux.intel.com> | 2019-04-12 09:59:49 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2019-05-16 13:17:24 -0400 |
commit | 4fc4d8dfa056dfd48afe73b9ea3b7570ceb80b9c (patch) | |
tree | 6ac8af8fe1ab5768a49d22ba74569acbd41b4f0d /tools/perf/util/stat-display.c | |
parent | 40480a8136700d678dc07222c4d7287c89d0c04d (diff) |
perf stat: Support 'percore' event qualifier
With this patch, we can use the 'percore' event qualifier in perf-stat.
root@skl:/tmp# perf stat -e cpu/event=0,umask=0x3,percore=1/,cpu/event=0,umask=0x3/ -a -A -I1000
1.000773050 S0-C0 98,352,832 cpu/event=0,umask=0x3,percore=1/ (50.01%)
1.000773050 S0-C1 103,763,057 cpu/event=0,umask=0x3,percore=1/ (50.02%)
1.000773050 S0-C2 196,776,995 cpu/event=0,umask=0x3,percore=1/ (50.02%)
1.000773050 S0-C3 176,493,779 cpu/event=0,umask=0x3,percore=1/ (50.02%)
1.000773050 CPU0 47,699,641 cpu/event=0,umask=0x3/ (50.02%)
1.000773050 CPU1 49,052,451 cpu/event=0,umask=0x3/ (49.98%)
1.000773050 CPU2 102,771,422 cpu/event=0,umask=0x3/ (49.98%)
1.000773050 CPU3 100,784,662 cpu/event=0,umask=0x3/ (49.98%)
1.000773050 CPU4 43,171,342 cpu/event=0,umask=0x3/ (49.98%)
1.000773050 CPU5 54,152,158 cpu/event=0,umask=0x3/ (49.98%)
1.000773050 CPU6 93,618,410 cpu/event=0,umask=0x3/ (49.98%)
1.000773050 CPU7 74,477,589 cpu/event=0,umask=0x3/ (49.99%)
In this example, we count the event 'ref-cycles' per-core and per-CPU in
one perf stat command-line. From the output, we can see:
S0-C0 = CPU0 + CPU4
S0-C1 = CPU1 + CPU5
S0-C2 = CPU2 + CPU6
S0-C3 = CPU3 + CPU7
So the result is expected (tiny difference is ignored).
Note that, the 'percore' event qualifier needs to use with option '-A'.
Signed-off-by: Jin Yao <yao.jin@linux.intel.com>
Tested-by: Ravi Bangoria <ravi.bangoria@linux.ibm.com>
Acked-by: Jiri Olsa <jolsa@kernel.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Jin Yao <yao.jin@intel.com>
Cc: Kan Liang <kan.liang@linux.intel.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1555077590-27664-4-git-send-email-yao.jin@linux.intel.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/stat-display.c')
-rw-r--r-- | tools/perf/util/stat-display.c | 43 |
1 files changed, 39 insertions, 4 deletions
diff --git a/tools/perf/util/stat-display.c b/tools/perf/util/stat-display.c index f5b4ee79568c..4c53bae5644b 100644 --- a/tools/perf/util/stat-display.c +++ b/tools/perf/util/stat-display.c | |||
@@ -88,9 +88,17 @@ static void aggr_printout(struct perf_stat_config *config, | |||
88 | config->csv_sep); | 88 | config->csv_sep); |
89 | break; | 89 | break; |
90 | case AGGR_NONE: | 90 | case AGGR_NONE: |
91 | fprintf(config->output, "CPU%*d%s", | 91 | if (evsel->percore) { |
92 | config->csv_output ? 0 : -4, | 92 | fprintf(config->output, "S%d-C%*d%s", |
93 | perf_evsel__cpus(evsel)->map[id], config->csv_sep); | 93 | cpu_map__id_to_socket(id), |
94 | config->csv_output ? 0 : -5, | ||
95 | cpu_map__id_to_cpu(id), config->csv_sep); | ||
96 | } else { | ||
97 | fprintf(config->output, "CPU%*d%s ", | ||
98 | config->csv_output ? 0 : -5, | ||
99 | perf_evsel__cpus(evsel)->map[id], | ||
100 | config->csv_sep); | ||
101 | } | ||
94 | break; | 102 | break; |
95 | case AGGR_THREAD: | 103 | case AGGR_THREAD: |
96 | fprintf(config->output, "%*s-%*d%s", | 104 | fprintf(config->output, "%*s-%*d%s", |
@@ -1103,6 +1111,30 @@ static void print_footer(struct perf_stat_config *config) | |||
1103 | "the same PMU. Try reorganizing the group.\n"); | 1111 | "the same PMU. Try reorganizing the group.\n"); |
1104 | } | 1112 | } |
1105 | 1113 | ||
1114 | static void print_percore(struct perf_stat_config *config, | ||
1115 | struct perf_evsel *counter, char *prefix) | ||
1116 | { | ||
1117 | bool metric_only = config->metric_only; | ||
1118 | FILE *output = config->output; | ||
1119 | int s; | ||
1120 | bool first = true; | ||
1121 | |||
1122 | if (!(config->aggr_map || config->aggr_get_id)) | ||
1123 | return; | ||
1124 | |||
1125 | for (s = 0; s < config->aggr_map->nr; s++) { | ||
1126 | if (prefix && metric_only) | ||
1127 | fprintf(output, "%s", prefix); | ||
1128 | |||
1129 | print_counter_aggrdata(config, counter, s, | ||
1130 | prefix, metric_only, | ||
1131 | &first); | ||
1132 | } | ||
1133 | |||
1134 | if (metric_only) | ||
1135 | fputc('\n', output); | ||
1136 | } | ||
1137 | |||
1106 | void | 1138 | void |
1107 | perf_evlist__print_counters(struct perf_evlist *evlist, | 1139 | perf_evlist__print_counters(struct perf_evlist *evlist, |
1108 | struct perf_stat_config *config, | 1140 | struct perf_stat_config *config, |
@@ -1153,7 +1185,10 @@ perf_evlist__print_counters(struct perf_evlist *evlist, | |||
1153 | print_no_aggr_metric(config, evlist, prefix); | 1185 | print_no_aggr_metric(config, evlist, prefix); |
1154 | else { | 1186 | else { |
1155 | evlist__for_each_entry(evlist, counter) { | 1187 | evlist__for_each_entry(evlist, counter) { |
1156 | print_counter(config, counter, prefix); | 1188 | if (counter->percore) |
1189 | print_percore(config, counter, prefix); | ||
1190 | else | ||
1191 | print_counter(config, counter, prefix); | ||
1157 | } | 1192 | } |
1158 | } | 1193 | } |
1159 | break; | 1194 | break; |