irqchip/gic-v4.1: Properly lock VPEs when doing a directLPI invalidation
authorMarc Zyngier <maz@kernel.org>
Sat, 17 Jun 2023 07:32:42 +0000 (08:32 +0100)
committerMarc Zyngier <maz@kernel.org>
Mon, 3 Jul 2023 18:48:04 +0000 (19:48 +0100)
commit926846a703cbf5d0635cc06e67d34b228746554b
treed09a9c7b08caa400c29d58e75fdef750b3f1a560
parent55ad24857341c36616ecc1d9580af5626c226cf1
irqchip/gic-v4.1: Properly lock VPEs when doing a directLPI invalidation

We normally rely on the irq_to_cpuid_[un]lock() primitives to make
sure nothing will change col->idx while performing a LPI invalidation.

However, these primitives do not cover VPE doorbells, and we have
some open-coded locking for that. Unfortunately, this locking is
pretty bogus.

Instead, extend the above primitives to cover VPE doorbells and
convert the whole thing to it.

Fixes: f3a059219bc7 ("irqchip/gic-v4.1: Ensure mutual exclusion between vPE affinity change and RD access")
Reported-by: Kunkun Jiang <jiangkunkun@huawei.com>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Cc: Zenghui Yu <yuzenghui@huawei.com>
Cc: wanghaibin.wang@huawei.com
Tested-by: Kunkun Jiang <jiangkunkun@huawei.com>
Reviewed-by: Zenghui Yu <yuzenghui@huawei.com>
Link: https://lore.kernel.org/r/20230617073242.3199746-1-maz@kernel.org
drivers/irqchip/irq-gic-v3-its.c