diff options
| author | Peter Zijlstra <peterz@infradead.org> | 2023-11-15 18:13:23 +0300 | 
|---|---|---|
| committer | Peter Zijlstra <peterz@infradead.org> | 2023-11-29 17:44:01 +0300 | 
| commit | edc8fc01f608108b0b7580cb2c29dfb5135e5f0e (patch) | |
| tree | c7b4fc57842e68df9706a6fb5194791875563b63 /scripts/gdb/linux/modules.py | |
| parent | 7d09a052a3bdb62de9a86d43359d6c22eeaf105a (diff) | |
| download | linux-edc8fc01f608108b0b7580cb2c29dfb5135e5f0e.tar.xz | |
x86: Fix CPUIDLE_FLAG_IRQ_ENABLE leaking timer reprogram
intel_idle_irq() re-enables IRQs very early. As a result, an interrupt
may fire before mwait() is eventually called. If such an interrupt queues
a timer, it may go unnoticed until mwait returns and the idle loop
handles the tick re-evaluation. And monitoring TIF_NEED_RESCHED doesn't
help because a local timer enqueue doesn't set that flag.
The issue is mitigated by the fact that this idle handler is only invoked
for shallow C-states when, presumably, the next tick is supposed to be
close enough. There may still be rare cases though when the next tick
is far away and the selected C-state is shallow, resulting in a timer
getting ignored for a while.
Fix this with using sti_mwait() whose IRQ-reenablement only triggers
upon calling mwait(), dealing with the race while keeping the interrupt
latency within acceptable bounds.
Fixes: c227233ad64c (intel_idle: enable interrupts before C1 on Xeons)
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Signed-off-by: Frederic Weisbecker <frederic@kernel.org>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Acked-by: Rafael J. Wysocki <rafael@kernel.org>
Link: https://lkml.kernel.org/r/20231115151325.6262-3-frederic@kernel.org
Diffstat (limited to 'scripts/gdb/linux/modules.py')
0 files changed, 0 insertions, 0 deletions
