summaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorJiri Olsa <jolsa@kernel.org>2015-06-26 05:29:19 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2015-06-26 10:48:02 -0400
commit106a94a0f8c207ef4113ce7e32f34a00b3b174e7 (patch)
tree09c5dab8445fb634fb56e8a29040e6cef8a37071 /tools
parentf99f4719b841a9745d6a7652eef3956aaf2db66a (diff)
perf stat: Introduce read_counters function
Moving read counters logic into single read_counters function, which will be called for both interval and overall processing legs. The reason is to split reading and processing (following patches) counters code, so we could read counters from other sources (like perf.data) and process them in the same way as 'perf stat' command does. Signed-off-by: Jiri Olsa <jolsa@kernel.org> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Andi Kleen <ak@linux.intel.com> Cc: David Ahern <dsahern@gmail.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Stephane Eranian <eranian@google.com> Link: http://lkml.kernel.org/r/1435310967-14570-15-git-send-email-jolsa@kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools')
-rw-r--r--tools/perf/builtin-stat.c47
1 files changed, 22 insertions, 25 deletions
diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c
index 3e385f9f12ee..158859e622d3 100644
--- a/tools/perf/builtin-stat.c
+++ b/tools/perf/builtin-stat.c
@@ -323,27 +323,35 @@ static int read_counter(struct perf_evsel *counter)
323 return 0; 323 return 0;
324} 324}
325 325
326static void print_interval(void) 326static void read_counters(bool close)
327{ 327{
328 static int num_print_interval;
329 struct perf_evsel *counter; 328 struct perf_evsel *counter;
330 struct perf_stat *ps; 329 struct perf_stat *ps;
331 struct timespec ts, rs;
332 char prefix[64];
333 330
334 if (aggr_mode == AGGR_GLOBAL) { 331 evlist__for_each(evsel_list, counter) {
335 evlist__for_each(evsel_list, counter) { 332 ps = counter->priv;
336 ps = counter->priv; 333 memset(ps->res_stats, 0, sizeof(ps->res_stats));
337 memset(ps->res_stats, 0, sizeof(ps->res_stats)); 334
335 if (aggr_mode == AGGR_GLOBAL)
338 read_counter_aggr(counter); 336 read_counter_aggr(counter);
339 } 337 else
340 } else {
341 evlist__for_each(evsel_list, counter) {
342 ps = counter->priv;
343 memset(ps->res_stats, 0, sizeof(ps->res_stats));
344 read_counter(counter); 338 read_counter(counter);
339
340 if (close) {
341 perf_evsel__close_fd(counter, perf_evsel__nr_cpus(counter),
342 thread_map__nr(evsel_list->threads));
345 } 343 }
346 } 344 }
345}
346
347static void print_interval(void)
348{
349 static int num_print_interval;
350 struct perf_evsel *counter;
351 struct timespec ts, rs;
352 char prefix[64];
353
354 read_counters(false);
347 355
348 clock_gettime(CLOCK_MONOTONIC, &ts); 356 clock_gettime(CLOCK_MONOTONIC, &ts);
349 diff_timespec(&rs, &ts, &ref_time); 357 diff_timespec(&rs, &ts, &ref_time);
@@ -525,18 +533,7 @@ static int __run_perf_stat(int argc, const char **argv)
525 533
526 update_stats(&walltime_nsecs_stats, t1 - t0); 534 update_stats(&walltime_nsecs_stats, t1 - t0);
527 535
528 if (aggr_mode == AGGR_GLOBAL) { 536 read_counters(true);
529 evlist__for_each(evsel_list, counter) {
530 read_counter_aggr(counter);
531 perf_evsel__close_fd(counter, perf_evsel__nr_cpus(counter),
532 thread_map__nr(evsel_list->threads));
533 }
534 } else {
535 evlist__for_each(evsel_list, counter) {
536 read_counter(counter);
537 perf_evsel__close_fd(counter, perf_evsel__nr_cpus(counter), 1);
538 }
539 }
540 537
541 return WEXITSTATUS(status); 538 return WEXITSTATUS(status);
542} 539}