From: Andi Kleen <a...@linux.intel.com>

Move the running/noise printing into printout to avoid
duplicated code in the callers.

v2: Merged with other patches. Remove unnecessary hunk.
Readd hunk that ended in earlier patch.
Signed-off-by: Andi Kleen <a...@linux.intel.com>
---
 tools/perf/builtin-stat.c | 52 ++++++++++-------------------------------------
 1 file changed, 11 insertions(+), 41 deletions(-)

diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c
index 78b1688..86da2e1 100644
--- a/tools/perf/builtin-stat.c
+++ b/tools/perf/builtin-stat.c
@@ -585,7 +585,7 @@ static void abs_printout(int id, int nr, struct perf_evsel 
*evsel, double avg)
 }
 
 static void printout(int id, int nr, struct perf_evsel *counter, double uval,
-                    char *prefix)
+                    char *prefix, u64 run, u64 ena, double noise)
 {
        struct perf_stat_output_ctx out;
        struct outstate os = {
@@ -612,6 +612,12 @@ static void printout(int id, int nr, struct perf_evsel 
*counter, double uval,
                                stat_config.aggr_mode == AGGR_GLOBAL ? 0 :
                                cpu_map__id_to_cpu(id),
                                &out);
+
+       if (!csv_output) {
+               print_noise(counter, noise);
+               if (run != ena)
+                       fprintf(stat_config.output, "  (%.2f%%)", 100.0 * run / 
ena);
+       }
 }
 
 static void print_aggr(char *prefix)
@@ -667,11 +673,7 @@ static void print_aggr(char *prefix)
                                continue;
                        }
                        uval = val * counter->scale;
-                       printout(id, nr, counter, uval, prefix);
-                       if (!csv_output)
-                               print_noise(counter, 1.0);
-
-                       print_running(run, ena);
+                       printout(id, nr, counter, uval, prefix, run, ena, 1.0);
                        fputc('\n', output);
                }
        }
@@ -698,12 +700,7 @@ static void print_aggr_thread(struct perf_evsel *counter, 
char *prefix)
                        fprintf(output, "%s", prefix);
 
                uval = val * counter->scale;
-               printout(thread, 0, counter, uval, prefix);
-
-               if (!csv_output)
-                       print_noise(counter, 1.0);
-
-               print_running(run, ena);
+               printout(thread, 0, counter, uval, prefix, run, ena, 1.0);
                fputc('\n', output);
        }
 }
@@ -717,7 +714,6 @@ static void print_counter_aggr(struct perf_evsel *counter, 
char *prefix)
        FILE *output = stat_config.output;
        struct perf_stat *ps = counter->priv;
        double avg = avg_stats(&ps->res_stats[0]);
-       int scaled = counter->counts->scaled;
        double uval;
        double avg_enabled, avg_running;
 
@@ -727,32 +723,8 @@ static void print_counter_aggr(struct perf_evsel *counter, 
char *prefix)
        if (prefix)
                fprintf(output, "%s", prefix);
 
-       if (scaled == -1 || !counter->supported) {
-               fprintf(output, "%*s%s",
-                       csv_output ? 0 : 18,
-                       counter->supported ? CNTR_NOT_COUNTED : 
CNTR_NOT_SUPPORTED,
-                       csv_sep);
-               fprintf(output, "%-*s%s",
-                       csv_output ? 0 : unit_width,
-                       counter->unit, csv_sep);
-               fprintf(output, "%*s",
-                       csv_output ? 0 : -25,
-                       perf_evsel__name(counter));
-
-               if (counter->cgrp)
-                       fprintf(output, "%s%s", csv_sep, counter->cgrp->name);
-
-               print_running(avg_running, avg_enabled);
-               fputc('\n', output);
-               return;
-       }
-
        uval = avg * counter->scale;
-       printout(-1, 0, counter, uval, prefix);
-
-       print_noise(counter, avg);
-
-       print_running(avg_running, avg_enabled);
+       printout(-1, 0, counter, uval, prefix, avg_running, avg_enabled, avg);
        fprintf(output, "\n");
 }
 
@@ -801,9 +773,7 @@ static void print_counter(struct perf_evsel *counter, char 
*prefix)
                }
 
                uval = val * counter->scale;
-               printout(cpu, 0, counter, uval, prefix);
-               if (!csv_output)
-                       print_noise(counter, 1.0);
+               printout(cpu, 0, counter, uval, prefix, run, ena, 1.0);
 
                fputc('\n', output);
        }
-- 
2.4.3

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to