mirror of
https://github.com/torvalds/linux.git
synced 2024-11-10 22:21:40 +00:00
perf stat: Handle partially bad results with merging
When any result that is being merged is bad, mark them all bad to give consistent output in interval mode. No before/after, because the issue was only found in theoretical review and it is hard to reproduce Signed-off-by: Andi Kleen <ak@linux.intel.com> Acked-by: Jiri Olsa <jolsa@kernel.org> Link: http://lkml.kernel.org/r/20170320201711.14142-4-andi@firstfloor.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
430daf2dc7
commit
b4229e9d4c
@ -1237,6 +1237,16 @@ static void aggr_cb(struct perf_evsel *counter, void *data, bool first)
|
||||
if (first)
|
||||
ad->nr++;
|
||||
counts = perf_counts(counter->counts, cpu, 0);
|
||||
/*
|
||||
* When any result is bad, make them all to give
|
||||
* consistent output in interval mode.
|
||||
*/
|
||||
if (counts->ena == 0 || counts->run == 0 ||
|
||||
counter->counts->scaled == -1) {
|
||||
ad->ena = 0;
|
||||
ad->run = 0;
|
||||
break;
|
||||
}
|
||||
ad->val += counts->val;
|
||||
ad->ena += counts->ena;
|
||||
ad->run += counts->run;
|
||||
|
Loading…
Reference in New Issue
Block a user