diff options
| -rw-r--r-- | virt/kvm/arm/vgic/vgic-init.c | 8 | ||||
| -rw-r--r-- | virt/kvm/arm/vgic/vgic-its.c | 2 | ||||
| -rw-r--r-- | virt/kvm/arm/vgic/vgic-v4.c | 3 |
3 files changed, 7 insertions, 6 deletions
diff --git a/virt/kvm/arm/vgic/vgic-init.c b/virt/kvm/arm/vgic/vgic-init.c index 40be908da238..62310122ee78 100644 --- a/virt/kvm/arm/vgic/vgic-init.c +++ b/virt/kvm/arm/vgic/vgic-init.c | |||
| @@ -285,11 +285,9 @@ int vgic_init(struct kvm *kvm) | |||
| 285 | if (ret) | 285 | if (ret) |
| 286 | goto out; | 286 | goto out; |
| 287 | 287 | ||
| 288 | if (vgic_supports_direct_msis(kvm)) { | 288 | ret = vgic_v4_init(kvm); |
| 289 | ret = vgic_v4_init(kvm); | 289 | if (ret) |
| 290 | if (ret) | 290 | goto out; |
| 291 | goto out; | ||
| 292 | } | ||
| 293 | 291 | ||
| 294 | kvm_for_each_vcpu(i, vcpu, kvm) | 292 | kvm_for_each_vcpu(i, vcpu, kvm) |
| 295 | kvm_vgic_vcpu_enable(vcpu); | 293 | kvm_vgic_vcpu_enable(vcpu); |
diff --git a/virt/kvm/arm/vgic/vgic-its.c b/virt/kvm/arm/vgic/vgic-its.c index b8c1b724ba3e..c93ecd4a903b 100644 --- a/virt/kvm/arm/vgic/vgic-its.c +++ b/virt/kvm/arm/vgic/vgic-its.c | |||
| @@ -1673,7 +1673,7 @@ static int vgic_its_create(struct kvm_device *dev, u32 type) | |||
| 1673 | 1673 | ||
| 1674 | if (vgic_initialized(dev->kvm)) { | 1674 | if (vgic_initialized(dev->kvm)) { |
| 1675 | int ret = vgic_v4_init(dev->kvm); | 1675 | int ret = vgic_v4_init(dev->kvm); |
| 1676 | if (ret) { | 1676 | if (ret < 0) { |
| 1677 | kfree(its); | 1677 | kfree(its); |
| 1678 | return ret; | 1678 | return ret; |
| 1679 | } | 1679 | } |
diff --git a/virt/kvm/arm/vgic/vgic-v4.c b/virt/kvm/arm/vgic/vgic-v4.c index 915d09dc2638..53c324aa44ef 100644 --- a/virt/kvm/arm/vgic/vgic-v4.c +++ b/virt/kvm/arm/vgic/vgic-v4.c | |||
| @@ -118,6 +118,9 @@ int vgic_v4_init(struct kvm *kvm) | |||
| 118 | struct kvm_vcpu *vcpu; | 118 | struct kvm_vcpu *vcpu; |
| 119 | int i, nr_vcpus, ret; | 119 | int i, nr_vcpus, ret; |
| 120 | 120 | ||
| 121 | if (!vgic_supports_direct_msis(kvm)) | ||
| 122 | return 0; /* Nothing to see here... move along. */ | ||
| 123 | |||
| 121 | if (dist->its_vm.vpes) | 124 | if (dist->its_vm.vpes) |
| 122 | return 0; | 125 | return 0; |
| 123 | 126 | ||
