diff options
author | Andre Przywara <andre.przywara@arm.com> | 2016-07-15 13:43:31 +0200 |
---|---|---|
committer | Marc Zyngier <marc.zyngier@arm.com> | 2016-07-18 19:14:35 +0200 |
commit | 1085fdc68c6097244627a02a56bd2d8fe58a1a9c (patch) | |
tree | 6a26676301cddc817aa4a4b0ba8eee7e841383f4 /virt/kvm/arm/vgic/vgic-mmio-v3.c | |
parent | KVM: arm64: vgic-its: Introduce ITS emulation file with MMIO framework (diff) | |
download | linux-1085fdc68c6097244627a02a56bd2d8fe58a1a9c.tar.xz linux-1085fdc68c6097244627a02a56bd2d8fe58a1a9c.zip |
KVM: arm64: vgic-its: Introduce new KVM ITS device
Introduce a new KVM device that represents an ARM Interrupt Translation
Service (ITS) controller. Since there can be multiple of this per guest,
we can't piggy back on the existing GICv3 distributor device, but create
a new type of KVM device.
On the KVM_CREATE_DEVICE ioctl we allocate and initialize the ITS data
structure and store the pointer in the kvm_device data.
Upon an explicit init ioctl from userland (after having setup the MMIO
address) we register the handlers with the kvm_io_bus framework.
Any reference to an ITS thus has to go via this interface.
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
Reviewed-by: Marc Zyngier <marc.zyngier@arm.com>
Tested-by: Eric Auger <eric.auger@redhat.com>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Diffstat (limited to 'virt/kvm/arm/vgic/vgic-mmio-v3.c')
-rw-r--r-- | virt/kvm/arm/vgic/vgic-mmio-v3.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/virt/kvm/arm/vgic/vgic-mmio-v3.c b/virt/kvm/arm/vgic/vgic-mmio-v3.c index b92b7d6cabe6..a5c35050c786 100644 --- a/virt/kvm/arm/vgic/vgic-mmio-v3.c +++ b/virt/kvm/arm/vgic/vgic-mmio-v3.c @@ -49,7 +49,7 @@ bool vgic_has_its(struct kvm *kvm) if (dist->vgic_model != KVM_DEV_TYPE_ARM_VGIC_V3) return false; - return false; + return dist->has_its; } static unsigned long vgic_mmio_read_v3_misc(struct kvm_vcpu *vcpu, |