KVM: arm64: vgic-debug: Don't put unmarked LPIs
authorZenghui Yu <yuzenghui@huawei.com>
Sat, 17 Aug 2024 10:15:41 +0000 (18:15 +0800)
committerOliver Upton <oliver.upton@linux.dev>
Mon, 19 Aug 2024 17:04:36 +0000 (17:04 +0000)
commit2240a50e6294214de791729e9dcba6880fa7e44e
treea69e0365c0e1a733de41b733896b443843f99e0f
parent9eb18136af9fe4dd688724070f2bfba271bd1542
KVM: arm64: vgic-debug: Don't put unmarked LPIs

If there were LPIs being mapped behind our back (i.e., between .start() and
.stop()), we would put them at iter_unmark_lpis() without checking if they
were actually *marked*, which is obviously not good.

Switch to use the xa_for_each_marked() iterator to fix it.

Cc: stable@vger.kernel.org
Fixes: 85d3ccc8b75b ("KVM: arm64: vgic-debug: Use an xarray mark for debug iterator")
Signed-off-by: Zenghui Yu <yuzenghui@huawei.com>
Reviewed-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20240817101541.1664-1-yuzenghui@huawei.com
Signed-off-by: Oliver Upton <oliver.upton@linux.dev>
arch/arm64/kvm/vgic/vgic-debug.c