diff options
author | Zhengyu He <zhengyuh@google.com> | 2011-06-23 16:45:42 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2011-07-01 06:52:40 -0400 |
commit | 3ae9a34d747f9abf2bcc85dc0e77b951513ccdf2 (patch) | |
tree | 592baba4f60e156f9b0d596ade75e282ea21f1ab /tools/perf | |
parent | 343a031f3c4a7a663192cf56368bb5a6c56870c0 (diff) |
perf stat: Add noise output for csv mode
Previously, when you want perf-stat to output the statistics in
csv mode, no information of the noise will be printed out.
For example right now we output this --repeat information:
./perf stat -r3 -x, sleep 1
1.164789,task-clock
8,context-switches
0,CPU-migrations
219,page-faults
3337800,cycles
With this patch, the output will be appended with an additional
entry for the noise value:
./perf stat -r3 -x, sleep 1
1.164789,task-clock,3.75%
8,context-switches,75.00%
0,CPU-migrations,100.00%
219,page-faults,0.00%
3337800,cycles,3.36%
Signed-off-by: Zhengyu He <zhengyuh@google.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
Cc: Stephane Eranian <eranian@google.com>
Cc: Venkatesh Pallipadi <venki@google.com>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/r/1308861942-4945-1-git-send-email-zhengyuh@google.com
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'tools/perf')
-rw-r--r-- | tools/perf/builtin-stat.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c index 784ed6d6e0d6..1d08c8084cc4 100644 --- a/tools/perf/builtin-stat.c +++ b/tools/perf/builtin-stat.c | |||
@@ -517,7 +517,10 @@ static void print_noise_pct(double total, double avg) | |||
517 | if (avg) | 517 | if (avg) |
518 | pct = 100.0*total/avg; | 518 | pct = 100.0*total/avg; |
519 | 519 | ||
520 | fprintf(stderr, " ( +-%6.2f%% )", pct); | 520 | if (csv_output) |
521 | fprintf(stderr, "%s%.2f%%", csv_sep, pct); | ||
522 | else | ||
523 | fprintf(stderr, " ( +-%6.2f%% )", pct); | ||
521 | } | 524 | } |
522 | 525 | ||
523 | static void print_noise(struct perf_evsel *evsel, double avg) | 526 | static void print_noise(struct perf_evsel *evsel, double avg) |
@@ -882,13 +885,13 @@ static void print_counter_aggr(struct perf_evsel *counter) | |||
882 | else | 885 | else |
883 | abs_printout(-1, counter, avg); | 886 | abs_printout(-1, counter, avg); |
884 | 887 | ||
888 | print_noise(counter, avg); | ||
889 | |||
885 | if (csv_output) { | 890 | if (csv_output) { |
886 | fputc('\n', stderr); | 891 | fputc('\n', stderr); |
887 | return; | 892 | return; |
888 | } | 893 | } |
889 | 894 | ||
890 | print_noise(counter, avg); | ||
891 | |||
892 | if (scaled) { | 895 | if (scaled) { |
893 | double avg_enabled, avg_running; | 896 | double avg_enabled, avg_running; |
894 | 897 | ||