On Mon, 5 Dec 2016, Peter Zijlstra wrote: > --- > Subject: perf,x86: Fix full width counter, counter overflow > Date: Tue, 29 Nov 2016 20:33:28 +0000 > > Lukasz reported that perf stat counters overflow is broken on KNL/SLM. > > Both these parts have full_width_write set, and that does indeed have > a problem. In order to deal with counter wrap, we must sample the > counter at at least half the counter period (see also the sampling > theorem) such that we can unambiguously reconstruct the count.
I know I'm a bit late to this issue, but I suddenly have PAPI users being very worried that their results are going to be wrong ad I hadn't heard about this until recently. I'm trying to make a reproducer test and want to make sure I understand the issue. (And I don't have any of the easy trigger hardware either. And what is SLM? Silvermont? Are we really that short on Changelog space that we can't spell out the abbreviations to make things clear for non-Intel employees?) So from what I understand, the issue is if we have an architecture with full-width counters and we trigger a x86_perf_event_update() when bit 47 is set? So if I have a test that runs in a loop for 2^48 retired instructions (which takes ~12 hours on a recent machine) and then reads the results, they might be wrong? It sounds like this can also be triggered by a sampling event with a really long period, but I couldn't puzzle out from the Changelog exactly how to reproduce this (or even how serious the issue is). Vince

