summaryrefslogtreecommitdiff
path: root/drivers/cpuidle
diff options
context:
space:
mode:
authorMarc Zyngier <maz@kernel.org>2020-03-04 23:33:10 +0300
committerMarc Zyngier <maz@kernel.org>2020-03-19 14:21:58 +0300
commitf3a059219bc718ccc3bf3ff894f089b7e9a93139 (patch)
tree31f4943e6b75e03a7b7e7a90890ee4f9ff8a3e84 /drivers/cpuidle
parent28d160de5194c68ff534443d2a8b6f1d10d57c58 (diff)
downloadlinux-f3a059219bc718ccc3bf3ff894f089b7e9a93139.tar.xz
irqchip/gic-v4.1: Ensure mutual exclusion between vPE affinity change and RD access
Before GICv4.1, all operations would be serialized with the affinity changes by virtue of using the same ITS command queue. With v4.1, things change, as invalidations (and a number of other operations) are issued using the redistributor MMIO frame. We must thus make sure that these redistributor accesses cannot race against aginst the affinity change, or we may end-up talking to the wrong redistributor. To ensure this, we expand the irq_to_cpuid() helper to take a spinlock when the LPI is mapped to a vLPI (a new per-VPE lock) on each operation that requires mutual exclusion. Signed-off-by: Marc Zyngier <maz@kernel.org> Reviewed-by: Zenghui Yu <yuzenghui@huawei.com> Link: https://lore.kernel.org/r/20200304203330.4967-4-maz@kernel.org
Diffstat (limited to 'drivers/cpuidle')
0 files changed, 0 insertions, 0 deletions