Commit dece3a4d authored by Alexey Budankov's avatar Alexey Budankov Committed by Arnaldo Carvalho de Melo

perf stat: Factor out body of event handling loop for system wide

Introduce handle_interval() function that factors out body of event
handling loop for attach and system wide monitoring use cases.
Signed-off-by: default avatarAlexey Budankov <alexey.budankov@linux.intel.com>
Acked-by: default avatarJiri Olsa <jolsa@redhat.com>
Acked-by: default avatarNamhyung Kim <namhyung@kernel.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lore.kernel.org/lkml/73130f9e-0d0f-7391-da50-41b4bf4bf54d@linux.intel.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent ec886bf5
...@@ -475,6 +475,16 @@ static void process_interval(void) ...@@ -475,6 +475,16 @@ static void process_interval(void)
print_counters(&rs, 0, NULL); print_counters(&rs, 0, NULL);
} }
static bool handle_interval(unsigned int interval, int *times)
{
if (interval) {
process_interval();
if (interval_count && !(--(*times)))
return true;
}
return false;
}
static void enable_counters(void) static void enable_counters(void)
{ {
if (stat_config.initial_delay) if (stat_config.initial_delay)
...@@ -809,13 +819,8 @@ static int __run_perf_stat(int argc, const char **argv, int run_idx) ...@@ -809,13 +819,8 @@ static int __run_perf_stat(int argc, const char **argv, int run_idx)
nanosleep(&ts, NULL); nanosleep(&ts, NULL);
if (!is_target_alive(&target, evsel_list->core.threads)) if (!is_target_alive(&target, evsel_list->core.threads))
break; break;
if (timeout) if (timeout || handle_interval(interval, &times))
break; break;
if (interval) {
process_interval();
if (interval_count && !(--times))
break;
}
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment