[PATCH v2 17/54] KVM: arm/arm64: vgic-new: Add GICv2 world switch backend

Marc Zyngier marc.zyngier at arm.com
Mon May 2 05:16:37 PDT 2016


On Thu, 28 Apr 2016 17:45:36 +0100
Andre Przywara <andre.przywara at arm.com> wrote:

> From: Marc Zyngier <marc.zyngier at arm.com>
> 
> Processing maintenance interrupts and accessing the list registers
> are dependent on the host's GIC version.
> Introduce vgic-v2.c to contain GICv2 specific functions.
> Implement the GICv2 specific code for syncing the emulation state
> into the VGIC registers.
> 
> Signed-off-by: Marc Zyngier <marc.zyngier at arm.com>
> Signed-off-by: Christoffer Dall <christoffer.dall at linaro.org>
> Signed-off-by: Eric Auger <eric.auger at linaro.org>
> Signed-off-by: Andre Przywara <andre.przywara at arm.com>
> ---
> Changelog RFC..v1:
> - remove explicit LR_STATE clearing on maintenance interrupt handling
> - improve documentation for vgic_v2_populate_lr()
> - remove WARN_ON on non-edge IRQs in maintenance interrupts
> - simplify multi-CPU source SGI handling
> 
> Changelog v1 .. v2:
> - inject the IRQ priority into the list register
> 
>  include/linux/irqchip/arm-gic.h |   1 +
>  virt/kvm/arm/vgic/vgic-v2.c     | 178 ++++++++++++++++++++++++++++++++++++++++
>  virt/kvm/arm/vgic/vgic.c        |  19 ++---
>  virt/kvm/arm/vgic/vgic.h        |   6 ++
>  4 files changed, 194 insertions(+), 10 deletions(-)
>  create mode 100644 virt/kvm/arm/vgic/vgic-v2.c
> 

[...]

> @@ -441,14 +447,12 @@ static int compute_ap_list_depth(struct kvm_vcpu *vcpu)
>  static void vgic_flush_lr_state(struct kvm_vcpu *vcpu)
>  {
>  	struct vgic_cpu *vgic_cpu = &vcpu->arch.vgic_cpu;
> -	struct vgic_dist *dist = &vcpu->kvm->arch.vgic;
> -	u32 model = dist->vgic_model;
>  	struct vgic_irq *irq;
>  	int count = 0;
>  
>  	DEBUG_SPINLOCK_BUG_ON(!spin_is_locked(vgic_cpu->ap_list_lock));
>  
> -	if (unlikely(!dist->enabled))
> +	if (unlikely(!vcpu->kvm->arch.vgic.enabled))
>  		goto out_clean;
>  
>  	if (compute_ap_list_depth(vcpu) > kvm_vgic_global_state.nr_lr) {
> @@ -466,14 +470,9 @@ static void vgic_flush_lr_state(struct kvm_vcpu *vcpu)
>  		 * If we get an SGI with multiple sources, try to get
>  		 * them in all at once.
>  		 */
> -		if (model == KVM_DEV_TYPE_ARM_VGIC_V2 &&
> -		    vgic_irq_is_sgi(irq->intid)) {
> -			while (irq->source &&
> -			       count < kvm_vgic_global_state.nr_lr)
> -				vgic_populate_lr(vcpu, irq, count++);
> -		} else {
> +		do {
>  			vgic_populate_lr(vcpu, irq, count++);
> -		}
> +		} while (irq->source && count < kvm_vgic_global_state.nr_lr);
>  
>  next:

Most, if not all of the changes in this function should be folded in the
previous patch, as we only have generic code in this file (this looks
like a leftover from an earlier rework).

Thanks,

	M.
-- 
Jazz is not dead. It just smells funny.



More information about the linux-arm-kernel mailing list