mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-02 22:06:47 +07:00
perf_counter, x86: fix zero irq_period counters
The quirk to irq_period unearthed an unrobustness we had in the hw_counter initialization sequence: we left irq_period at 0, which was then quirked up to 2 ... which then generated a _lot_ of interrupts during 'perf stat' runs, slowed them down and skewed the counter results in general. Initialize irq_period to the maximum instead. [ Impact: fix perf stat results ] Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Srivatsa Vaddagiri <vatsa@in.ibm.com> Cc: Paul Mackerras <paulus@samba.org> Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com> Cc: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Marcelo Tosatti <mtosatti@redhat.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
parent
0203026b58
commit
d2517a49d5
@ -286,6 +286,9 @@ static int __hw_perf_counter_init(struct perf_counter *counter)
|
||||
hwc->nmi = 1;
|
||||
}
|
||||
|
||||
if (!hwc->irq_period)
|
||||
hwc->irq_period = x86_pmu.max_period;
|
||||
|
||||
atomic64_set(&hwc->period_left,
|
||||
min(x86_pmu.max_period, hwc->irq_period));
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user