summaryrefslogtreecommitdiff
path: root/arch/powerpc/purgatory
diff options
context:
space:
mode:
authorLorenzo Pieralisi <lpieralisi@kernel.org>2023-07-04 17:50:34 +0200
committerMarc Zyngier <maz@kernel.org>2023-07-11 09:04:31 +0100
commit6fe5c68ee6a1aae0ef291a56001e7888de547fa2 (patch)
treed1ff279888b87f9f0a5c9771f4be3accab0eca38 /arch/powerpc/purgatory
parent567f67acac94e7bbc4cb4b71ff9773555d02609a (diff)
irqchip/gic-v3: Workaround for GIC-700 erratum 2941627
GIC700 erratum 2941627 may cause GIC-700 missing SPIs wake requests when SPIs are deactivated while targeting a sleeping CPU - ie a CPU for which the redistributor: GICR_WAKER.ProcessorSleep == 1 This runtime situation can happen if an SPI that has been activated on a core is retargeted to a different core, it becomes pending and the target core subsequently enters a power state quiescing the respective redistributor. When this situation is hit, the de-activation carried out on the core that activated the SPI (through either ICC_EOIR1_EL1 or ICC_DIR_EL1 register writes) does not trigger a wake requests for the sleeping GIC redistributor even if the SPI is pending. Work around the erratum by de-activating the SPI using the redistributor GICD_ICACTIVER register if the runtime conditions require it (ie the IRQ was retargeted between activation and de-activation). Signed-off-by: Lorenzo Pieralisi <lpieralisi@kernel.org> Signed-off-by: Marc Zyngier <maz@kernel.org> Link: https://lore.kernel.org/r/20230704155034.148262-1-lpieralisi@kernel.org
Diffstat (limited to 'arch/powerpc/purgatory')
0 files changed, 0 insertions, 0 deletions