All of lore.kernel.org
 help / color / mirror / Atom feed
From: christoffer.dall@linaro.org (Christoffer Dall)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 8/8] KVM: arm-vgic: Support CPU interface reg access
Date: Wed, 25 Sep 2013 17:54:37 -0700	[thread overview]
Message-ID: <20130926005437.GI32311@cbox> (raw)
In-Reply-To: <BD74C365-718A-4946-AC27-21BADEF6F0DC@suse.de>

On Thu, Sep 26, 2013 at 12:37:03AM +0200, Alexander Graf wrote:
> 
> On 25.09.2013, at 23:30, Christoffer Dall wrote:
> 
> > On Sun, Aug 25, 2013 at 04:24:20PM +0100, Alexander Graf wrote:
> >> 
> >> On 23.08.2013, at 20:20, Christoffer Dall wrote:
> >> 
> >>> Implement support for the CPU interface register access driven by MMIO
> >>> address offsets from the CPU interface base address.  Useful for user
> >>> space to support save/restore of the VGIC state.
> >>> 
> >>> This commit adds support only for the same logic as the current VGIC
> >>> support, and no more.  For example, the active priority registers are
> >>> handled as RAZ/WI, just like setting priorities on the emulated
> >>> distributor.
> >>> 
> >>> Signed-off-by: Christoffer Dall <christoffer.dall@linaro.org>
> >>> ---
> >>> virt/kvm/arm/vgic.c |   66 +++++++++++++++++++++++++++++++++++++++++++++++----
> >>> 1 file changed, 62 insertions(+), 4 deletions(-)
> >>> 
> >>> diff --git a/virt/kvm/arm/vgic.c b/virt/kvm/arm/vgic.c
> >>> index d44b5a1..257dbae 100644
> >>> --- a/virt/kvm/arm/vgic.c
> >>> +++ b/virt/kvm/arm/vgic.c
> >>> @@ -1684,9 +1684,67 @@ int kvm_vgic_addr(struct kvm *kvm, unsigned long type, u64 *addr, bool write)
> >>> static bool handle_cpu_mmio_misc(struct kvm_vcpu *vcpu,
> >>> 				 struct kvm_exit_mmio *mmio, phys_addr_t offset)
> >>> {
> >>> -	return true;
> >>> +	struct vgic_cpu *vgic_cpu = &vcpu->arch.vgic_cpu;
> >>> +	u32 reg, mask = 0, shift = 0;
> >>> +	bool updated = false;
> >>> +
> >>> +	switch (offset & ~0x3) {
> >>> +	case GIC_CPU_CTRL:
> >>> +		mask = GICH_VMCR_CTRL_MASK;
> >>> +		shift = GICH_VMCR_CTRL_SHIFT;
> >>> +		break;
> >>> +	case GIC_CPU_PRIMASK:
> >>> +		mask = GICH_VMCR_PRIMASK_MASK;
> >>> +		shift = GICH_VMCR_PRIMASK_SHIFT;
> >>> +		break;
> >>> +	case GIC_CPU_BINPOINT:
> >>> +		mask = GICH_VMCR_BINPOINT_MASK;
> >>> +		shift = GICH_VMCR_BINPOINT_SHIFT;
> >>> +		break;
> >>> +	case GIC_CPU_ALIAS_BINPOINT:
> >>> +		mask = GICH_VMCR_ALIAS_BINPOINT_MASK;
> >>> +		shift = GICH_VMCR_ALIAS_BINPOINT_SHIFT;
> >>> +		break;
> >>> +	}
> >>> +
> >>> +	if (!mmio->is_write) {
> >>> +		reg = (vgic_cpu->vgic_vmcr & mask) >> shift;
> >>> +		memcpy(mmio->data, &reg, sizeof(reg));
> >>> +	} else {
> >>> +		memcpy(&reg, mmio->data, sizeof(reg));
> >>> +		reg = (reg << shift) & mask;
> >>> +		if (reg != (vgic_cpu->vgic_vmcr & mask))
> >>> +			updated = true;
> >>> +		vgic_cpu->vgic_vmcr &= ~mask;
> >>> +		vgic_cpu->vgic_vmcr |= reg;
> >>> +	}
> >>> +	return updated;
> >>> +}
> >>> +
> >>> +static bool handle_mmio_abpr(struct kvm_vcpu *vcpu,
> >>> +			     struct kvm_exit_mmio *mmio, phys_addr_t offset)
> >>> +{
> >>> +	return handle_cpu_mmio_misc(vcpu, mmio, GIC_CPU_ALIAS_BINPOINT);
> >>> +}
> >>> +
> >>> +static bool handle_cpu_mmio_ident(struct kvm_vcpu *vcpu,
> >>> +				  struct kvm_exit_mmio *mmio,
> >>> +				  phys_addr_t offset)
> >>> +{
> >>> +	u32 reg;
> >>> +
> >>> +	if (mmio->is_write)
> >>> +		return false;
> >>> +
> >>> +	reg = 0x0002043B;
> >> 
> >> This wants a comment and probably also a #define :).
> >> 
> > 
> > Marc, where does the 0x4b0 product id code come from for the distributor
> > IIDR?
> > 
> > Would this be satisfying?
> > 
> > 
> > diff --git a/virt/kvm/arm/vgic.c b/virt/kvm/arm/vgic.c
> > index 5214424..558be38 100644
> > --- a/virt/kvm/arm/vgic.c
> > +++ b/virt/kvm/arm/vgic.c
> > @@ -71,6 +71,9 @@
> > #define VGIC_ADDR_UNDEF		(-1)
> > #define IS_VGIC_ADDR_UNDEF(_x)  ((_x) == VGIC_ADDR_UNDEF)
> > 
> > +#define GIC_PRODUCT_ID		0x4b0
> 
> This is a specific GIC version. PL390 for example is 0x3b0:
> 
>   http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.ddi0416b/Beiggeba.html
> 
> That should be reflected in the #define. If it means "GICv2" then it should be GICV2_PRODUCT_ID for example.
> 

I know what field in the register it is thanks :)

But I couldn't find 0x4b0 anywhere in the docs, so I'm asking
Marc where he got it from.  I don't believe it means GICv2, but a
specific implementation of a GICv2, and once I have more info I can
change the define name, I suspect this is potentially something made-up
to indicate that this is the KVM VGIC...

> > +#define ARM_JEP106_IMPLEMENTER	0x43b
> 
> I think naming this JEP106_IMPLEMENTER_ARM makes it more obvious that we're talking about the implementer code for ARM. Or maybe just only IMPLEMENTER_ARM.
> 

ok

> > +
> > /* Physical address of vgic virtual cpu interface */
> > static phys_addr_t vgic_vcpu_base;
> > 
> > @@ -331,7 +334,7 @@ static bool handle_mmio_misc(struct kvm_vcpu *vcpu,
> > 		break;
> > 
> > 	case 8:			/* IIDR */
> > -		reg = 0x4B00043B;
> > +		reg = (GIC_PRODUCT_ID << 20) | ARM_JEP106_IMPLEMENTER;
> > 		vgic_reg_access(mmio, &reg, word_offset,
> > 				ACCESS_READ_VALUE | ACCESS_WRITE_IGNORED);
> > 		break;
> > @@ -1734,7 +1737,7 @@ static bool handle_cpu_mmio_ident(struct kvm_vcpu *vcpu,
> > 	if (mmio->is_write)
> > 		return false;
> > 
> > -	reg = 0x0002043B;
> > +	reg = (GIC_PRODUCT_ID << 20) | (0x2 << 16) | ARM_JEP106_IMPLEMENTER;
> 
> What is the 0x2 here?
> 
> 

GICv2, and now you're going to tell me to create a define for it right?

Which of course I can, but it's getting a bit silly, because then you
can ask me what is the field shifted at 16 bits, and the next question
is what is the GICC_IIDR, and at some point you're just going to have to
look up the definition of this specific register in the GIC specs.

-Christoffer

WARNING: multiple messages have this Message-ID (diff)
From: Christoffer Dall <christoffer.dall@linaro.org>
To: Alexander Graf <agraf@suse.de>
Cc: kvmarm@lists.cs.columbia.edu, linaro-kernel@lists.linaro.org,
	linux-arm-kernel@lists.infradead.org, kvm@vger.kernel.org,
	patches@linaro.org, Marc Zyngier <marc.zyngier@arm.com>
Subject: Re: [PATCH 8/8] KVM: arm-vgic: Support CPU interface reg access
Date: Wed, 25 Sep 2013 17:54:37 -0700	[thread overview]
Message-ID: <20130926005437.GI32311@cbox> (raw)
In-Reply-To: <BD74C365-718A-4946-AC27-21BADEF6F0DC@suse.de>

On Thu, Sep 26, 2013 at 12:37:03AM +0200, Alexander Graf wrote:
> 
> On 25.09.2013, at 23:30, Christoffer Dall wrote:
> 
> > On Sun, Aug 25, 2013 at 04:24:20PM +0100, Alexander Graf wrote:
> >> 
> >> On 23.08.2013, at 20:20, Christoffer Dall wrote:
> >> 
> >>> Implement support for the CPU interface register access driven by MMIO
> >>> address offsets from the CPU interface base address.  Useful for user
> >>> space to support save/restore of the VGIC state.
> >>> 
> >>> This commit adds support only for the same logic as the current VGIC
> >>> support, and no more.  For example, the active priority registers are
> >>> handled as RAZ/WI, just like setting priorities on the emulated
> >>> distributor.
> >>> 
> >>> Signed-off-by: Christoffer Dall <christoffer.dall@linaro.org>
> >>> ---
> >>> virt/kvm/arm/vgic.c |   66 +++++++++++++++++++++++++++++++++++++++++++++++----
> >>> 1 file changed, 62 insertions(+), 4 deletions(-)
> >>> 
> >>> diff --git a/virt/kvm/arm/vgic.c b/virt/kvm/arm/vgic.c
> >>> index d44b5a1..257dbae 100644
> >>> --- a/virt/kvm/arm/vgic.c
> >>> +++ b/virt/kvm/arm/vgic.c
> >>> @@ -1684,9 +1684,67 @@ int kvm_vgic_addr(struct kvm *kvm, unsigned long type, u64 *addr, bool write)
> >>> static bool handle_cpu_mmio_misc(struct kvm_vcpu *vcpu,
> >>> 				 struct kvm_exit_mmio *mmio, phys_addr_t offset)
> >>> {
> >>> -	return true;
> >>> +	struct vgic_cpu *vgic_cpu = &vcpu->arch.vgic_cpu;
> >>> +	u32 reg, mask = 0, shift = 0;
> >>> +	bool updated = false;
> >>> +
> >>> +	switch (offset & ~0x3) {
> >>> +	case GIC_CPU_CTRL:
> >>> +		mask = GICH_VMCR_CTRL_MASK;
> >>> +		shift = GICH_VMCR_CTRL_SHIFT;
> >>> +		break;
> >>> +	case GIC_CPU_PRIMASK:
> >>> +		mask = GICH_VMCR_PRIMASK_MASK;
> >>> +		shift = GICH_VMCR_PRIMASK_SHIFT;
> >>> +		break;
> >>> +	case GIC_CPU_BINPOINT:
> >>> +		mask = GICH_VMCR_BINPOINT_MASK;
> >>> +		shift = GICH_VMCR_BINPOINT_SHIFT;
> >>> +		break;
> >>> +	case GIC_CPU_ALIAS_BINPOINT:
> >>> +		mask = GICH_VMCR_ALIAS_BINPOINT_MASK;
> >>> +		shift = GICH_VMCR_ALIAS_BINPOINT_SHIFT;
> >>> +		break;
> >>> +	}
> >>> +
> >>> +	if (!mmio->is_write) {
> >>> +		reg = (vgic_cpu->vgic_vmcr & mask) >> shift;
> >>> +		memcpy(mmio->data, &reg, sizeof(reg));
> >>> +	} else {
> >>> +		memcpy(&reg, mmio->data, sizeof(reg));
> >>> +		reg = (reg << shift) & mask;
> >>> +		if (reg != (vgic_cpu->vgic_vmcr & mask))
> >>> +			updated = true;
> >>> +		vgic_cpu->vgic_vmcr &= ~mask;
> >>> +		vgic_cpu->vgic_vmcr |= reg;
> >>> +	}
> >>> +	return updated;
> >>> +}
> >>> +
> >>> +static bool handle_mmio_abpr(struct kvm_vcpu *vcpu,
> >>> +			     struct kvm_exit_mmio *mmio, phys_addr_t offset)
> >>> +{
> >>> +	return handle_cpu_mmio_misc(vcpu, mmio, GIC_CPU_ALIAS_BINPOINT);
> >>> +}
> >>> +
> >>> +static bool handle_cpu_mmio_ident(struct kvm_vcpu *vcpu,
> >>> +				  struct kvm_exit_mmio *mmio,
> >>> +				  phys_addr_t offset)
> >>> +{
> >>> +	u32 reg;
> >>> +
> >>> +	if (mmio->is_write)
> >>> +		return false;
> >>> +
> >>> +	reg = 0x0002043B;
> >> 
> >> This wants a comment and probably also a #define :).
> >> 
> > 
> > Marc, where does the 0x4b0 product id code come from for the distributor
> > IIDR?
> > 
> > Would this be satisfying?
> > 
> > 
> > diff --git a/virt/kvm/arm/vgic.c b/virt/kvm/arm/vgic.c
> > index 5214424..558be38 100644
> > --- a/virt/kvm/arm/vgic.c
> > +++ b/virt/kvm/arm/vgic.c
> > @@ -71,6 +71,9 @@
> > #define VGIC_ADDR_UNDEF		(-1)
> > #define IS_VGIC_ADDR_UNDEF(_x)  ((_x) == VGIC_ADDR_UNDEF)
> > 
> > +#define GIC_PRODUCT_ID		0x4b0
> 
> This is a specific GIC version. PL390 for example is 0x3b0:
> 
>   http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.ddi0416b/Beiggeba.html
> 
> That should be reflected in the #define. If it means "GICv2" then it should be GICV2_PRODUCT_ID for example.
> 

I know what field in the register it is thanks :)

But I couldn't find 0x4b0 anywhere in the docs, so I'm asking
Marc where he got it from.  I don't believe it means GICv2, but a
specific implementation of a GICv2, and once I have more info I can
change the define name, I suspect this is potentially something made-up
to indicate that this is the KVM VGIC...

> > +#define ARM_JEP106_IMPLEMENTER	0x43b
> 
> I think naming this JEP106_IMPLEMENTER_ARM makes it more obvious that we're talking about the implementer code for ARM. Or maybe just only IMPLEMENTER_ARM.
> 

ok

> > +
> > /* Physical address of vgic virtual cpu interface */
> > static phys_addr_t vgic_vcpu_base;
> > 
> > @@ -331,7 +334,7 @@ static bool handle_mmio_misc(struct kvm_vcpu *vcpu,
> > 		break;
> > 
> > 	case 8:			/* IIDR */
> > -		reg = 0x4B00043B;
> > +		reg = (GIC_PRODUCT_ID << 20) | ARM_JEP106_IMPLEMENTER;
> > 		vgic_reg_access(mmio, &reg, word_offset,
> > 				ACCESS_READ_VALUE | ACCESS_WRITE_IGNORED);
> > 		break;
> > @@ -1734,7 +1737,7 @@ static bool handle_cpu_mmio_ident(struct kvm_vcpu *vcpu,
> > 	if (mmio->is_write)
> > 		return false;
> > 
> > -	reg = 0x0002043B;
> > +	reg = (GIC_PRODUCT_ID << 20) | (0x2 << 16) | ARM_JEP106_IMPLEMENTER;
> 
> What is the 0x2 here?
> 
> 

GICv2, and now you're going to tell me to create a define for it right?

Which of course I can, but it's getting a bit silly, because then you
can ask me what is the field shifted at 16 bits, and the next question
is what is the GICC_IIDR, and at some point you're just going to have to
look up the definition of this specific register in the GIC specs.

-Christoffer

  reply	other threads:[~2013-09-26  0:54 UTC|newest]

Thread overview: 46+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-08-23 19:19 [PATCH 0/8] Support VGIC save/restore using device control API Christoffer Dall
2013-08-23 19:19 ` Christoffer Dall
2013-08-23 19:19 ` [PATCH 1/8] ARM: KVM: Allow creating the VGIC after VCPUs Christoffer Dall
2013-08-23 19:19   ` Christoffer Dall
2013-08-23 19:20 ` [PATCH 2/8] KVM: arm-vgic: Support KVM_CREATE_DEVICE for VGIC Christoffer Dall
2013-08-23 19:20   ` Christoffer Dall
2013-08-23 19:20 ` [PATCH 3/8] KVM: arm-vgic: Set base addr through device API Christoffer Dall
2013-08-23 19:20   ` Christoffer Dall
2013-08-23 19:20 ` [PATCH 4/8] irqchip: arm-gic: Define additional MMIO offsets and masks Christoffer Dall
2013-08-23 19:20   ` Christoffer Dall
2013-08-23 19:20 ` [PATCH 5/8] KVM: arm-vgic: Make vgic mmio functions more generic Christoffer Dall
2013-08-23 19:20   ` Christoffer Dall
2013-08-23 19:20 ` [PATCH 6/8] KVM: arm-vgic: Add vgic reg access from dev attr Christoffer Dall
2013-08-23 19:20   ` Christoffer Dall
2013-08-25 15:21   ` Alexander Graf
2013-08-25 15:21     ` Alexander Graf
2013-09-25 20:38     ` Christoffer Dall
2013-09-25 20:38       ` Christoffer Dall
2013-09-25 20:49       ` Christoffer Dall
2013-09-25 20:49         ` Christoffer Dall
2013-08-23 19:20 ` [PATCH 7/8] KVM: arm-vgic: Add GICD_SPENDSGIR and GICD_CPENDSGIR handlers Christoffer Dall
2013-08-23 19:20   ` Christoffer Dall
2013-08-23 19:20 ` [PATCH 8/8] KVM: arm-vgic: Support CPU interface reg access Christoffer Dall
2013-08-23 19:20   ` Christoffer Dall
2013-08-25 15:24   ` Alexander Graf
2013-08-25 15:24     ` Alexander Graf
2013-09-25 21:30     ` Christoffer Dall
2013-09-25 21:30       ` Christoffer Dall
2013-09-25 22:37       ` Alexander Graf
2013-09-25 22:37         ` Alexander Graf
2013-09-26  0:54         ` Christoffer Dall [this message]
2013-09-26  0:54           ` Christoffer Dall
2013-09-26  1:15           ` Alexander Graf
2013-09-26  1:15             ` Alexander Graf
2013-09-26  1:36             ` Alexander Graf
2013-09-26  1:36               ` Alexander Graf
2013-09-26  1:48               ` Alexander Graf
2013-09-26  1:48                 ` Alexander Graf
2013-09-26  2:49             ` Christoffer Dall
2013-09-26  2:49               ` Christoffer Dall
2013-09-26 10:25               ` Alexander Graf
2013-09-26 10:25                 ` Alexander Graf
2013-09-26 10:47       ` Marc Zyngier
2013-09-26 10:47         ` Marc Zyngier
2013-08-25 15:24 ` [PATCH 0/8] Support VGIC save/restore using device control API Alexander Graf
2013-08-25 15:24   ` Alexander Graf

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20130926005437.GI32311@cbox \
    --to=christoffer.dall@linaro.org \
    --cc=linux-arm-kernel@lists.infradead.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.