On 04/07/2016 04:48 PM, Marc Zyngier wrote: > Hi Eric, > > On 07/04/16 15:08, Eric Auger wrote: >> Hi Marc, >> On 04/07/2016 04:04 PM, Marc Zyngier wrote: >>> On 26/03/16 02:14, Andre Przywara wrote: >>>> The ARM GICv3 ITS emulation code goes into a separate file, but >>>> needs to be connected to the GICv3 emulation, of which it is an >>>> option. >>>> Introduce the skeleton with function stubs to be filled later. >>>> Introduce the basic ITS data structure and initialize it, but don't >>>> return any success yet, as we are not yet ready for the show. >>>> >>>> Signed-off-by: Andre Przywara <andre.przywara@xxxxxxx> >>>> --- >>>> arch/arm64/kvm/Makefile | 1 + >>>> include/kvm/vgic/vgic.h | 6 +++ >>>> include/linux/irqchip/arm-gic-v3.h | 1 + >>>> virt/kvm/arm/vgic/its-emul.c | 84 ++++++++++++++++++++++++++++++++++++++ >>>> virt/kvm/arm/vgic/vgic.h | 14 +++++++ >>>> virt/kvm/arm/vgic/vgic_init.c | 6 +++ >>>> virt/kvm/arm/vgic/vgic_mmio.c | 18 ++++++-- >>>> 7 files changed, 126 insertions(+), 4 deletions(-) >>>> create mode 100644 virt/kvm/arm/vgic/its-emul.c >>>> >>>> diff --git a/arch/arm64/kvm/Makefile b/arch/arm64/kvm/Makefile >>>> index 2f5d431..3bec10e 100644 >>>> --- a/arch/arm64/kvm/Makefile >>>> +++ b/arch/arm64/kvm/Makefile >>>> @@ -28,6 +28,7 @@ kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/vgic/vgic-v2.o >>>> kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/vgic/vgic-v3.o >>>> kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/vgic/vgic_mmio.o >>>> kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/vgic/vgic_kvm_device.o >>>> +kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/vgic/its-emul.o >>>> else >>>> kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/vgic.o >>>> kvm-$(CONFIG_KVM_ARM_HOST) += $(KVM)/arm/vgic-v2.o >>>> diff --git a/include/kvm/vgic/vgic.h b/include/kvm/vgic/vgic.h >>>> index 8ea5dd7..c79bed5 100644 >>>> --- a/include/kvm/vgic/vgic.h >>>> +++ b/include/kvm/vgic/vgic.h >>>> @@ -112,6 +112,11 @@ struct vgic_io_device { >>>> struct kvm_io_device dev; >>>> }; >>>> >>>> +struct vgic_its { >>>> + bool enabled; >>>> + spinlock_t lock; >>>> +}; >>>> + >>>> struct vgic_dist { >>>> bool in_kernel; >>>> bool ready; >>>> @@ -153,6 +158,7 @@ struct vgic_dist { >>>> u64 *pendbaser; >>>> >>>> bool lpis_enabled; >>>> + struct vgic_its its; >>>> }; >>>> >>>> struct vgic_v2_cpu_if { >>>> diff --git a/include/linux/irqchip/arm-gic-v3.h b/include/linux/irqchip/arm-gic-v3.h >>>> index d5d798b..a813c3e 100644 >>>> --- a/include/linux/irqchip/arm-gic-v3.h >>>> +++ b/include/linux/irqchip/arm-gic-v3.h >>>> @@ -177,6 +177,7 @@ >>>> #define GITS_CWRITER 0x0088 >>>> #define GITS_CREADR 0x0090 >>>> #define GITS_BASER 0x0100 >>>> +#define GITS_IDREGS_BASE 0xffd0 >>>> #define GITS_PIDR2 GICR_PIDR2 >>>> >>>> #define GITS_TRANSLATER 0x10040 >>>> diff --git a/virt/kvm/arm/vgic/its-emul.c b/virt/kvm/arm/vgic/its-emul.c >>>> new file mode 100644 >>>> index 0000000..49dd5e4 >>>> --- /dev/null >>>> +++ b/virt/kvm/arm/vgic/its-emul.c >>>> @@ -0,0 +1,84 @@ >>>> +/* >>>> + * GICv3 ITS emulation >>>> + * >>>> + * Copyright (C) 2015 ARM Ltd. >>>> + * Author: Andre Przywara <andre.przywara@xxxxxxx> >>>> + * >>>> + * This program is free software; you can redistribute it and/or modify >>>> + * it under the terms of the GNU General Public License version 2 as >>>> + * published by the Free Software Foundation. >>>> + * >>>> + * This program is distributed in the hope that it will be useful, >>>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of >>>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the >>>> + * GNU General Public License for more details. >>>> + * >>>> + * You should have received a copy of the GNU General Public License >>>> + * along with this program. If not, see <http://www.gnu.org/licenses/>. >>>> + */ >>>> + >>>> +#include <linux/cpu.h> >>>> +#include <linux/kvm.h> >>>> +#include <linux/kvm_host.h> >>>> +#include <linux/interrupt.h> >>>> + >>>> +#include <linux/irqchip/arm-gic-v3.h> >>>> + >>>> +#include <asm/kvm_emulate.h> >>>> +#include <asm/kvm_arm.h> >>>> +#include <asm/kvm_mmu.h> >>>> + >>>> +#include "vgic.h" >>>> +#include "vgic_mmio.h" >>>> + >>>> +struct vgic_register_region its_registers[] = { >>>> + REGISTER_DESC_WITH_LENGTH(GITS_CTLR, >>>> + vgic_mmio_read_raz, vgic_mmio_write_wi, 4), >>>> + REGISTER_DESC_WITH_LENGTH(GITS_IIDR, >>>> + vgic_mmio_read_raz, vgic_mmio_write_wi, 4), >>>> + REGISTER_DESC_WITH_LENGTH(GITS_TYPER, >>>> + vgic_mmio_read_raz, vgic_mmio_write_wi, 4), >>> >>> GITS_TYPER is a 64bit register with plenty of things in the upper bits. >> In practice I think the 32 upper bits are reserved. > > Not quite. Only bits [63:38] are reserved. See 8.19.8 in the > Architecture Specification (IHI 0069B). Ah OK. Was using an older arch spec(PRD03-GENC-010745 22.0) Now switched to the indicated one and indeed it's different !;-) Eric > > Thanks, > > M. > -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html