KVM: arm/arm64: Fix GICv4 ITS initialization issues
authorChristoffer Dall <christoffer.dall@linaro.org>
Fri, 10 Nov 2017 08:16:23 +0000 (09:16 +0100)
committerChristoffer Dall <christoffer.dall@linaro.org>
Fri, 10 Nov 2017 08:55:59 +0000 (09:55 +0100)
commit3d1ad640f8c94a9ae9c7c8bbb311614bc0332a7e
tree7ca1847dee2a945c4ad3a7e8935cdf8fd60b344b
parented8703a506a8241f921feb63a656d0ff5a090895
KVM: arm/arm64: Fix GICv4 ITS initialization issues

We should only try to initialize GICv4 data structures on a GICv4
capable system.  Move the vgic_supports_direct_msis() check inito
vgic_v4_init() so that any KVM VGIC initialization path does not fail
on non-GICv4 systems.

Also be slightly more strict in the checking of the return value in
vgic_its_create, and only error out on negative return values from the
vgic_v4_init() function.  This is important because the kvm device code
only treats negative values as errors and only cleans up in this case.
Errornously treating a positive return value as an error from the
vgic_v4_init() function can lead to NULL pointer dereferences, as has
recently been observed.

Acked-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Christoffer Dall <christoffer.dall@linaro.org>
virt/kvm/arm/vgic/vgic-init.c
virt/kvm/arm/vgic/vgic-its.c
virt/kvm/arm/vgic/vgic-v4.c