aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorZhengyu He <zhengyuh@google.com>2011-06-23 16:45:42 -0400
committerIngo Molnar <mingo@elte.hu>2011-07-01 06:52:40 -0400
commit3ae9a34d747f9abf2bcc85dc0e77b951513ccdf2 (patch)
tree592baba4f60e156f9b0d596ade75e282ea21f1ab /tools
parent343a031f3c4a7a663192cf56368bb5a6c56870c0 (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')
-rw-r--r--tools/perf/builtin-stat.c9
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
523static void print_noise(struct perf_evsel *evsel, double avg) 526static 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