[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [XEN v2] GICv3: Emulate GICR_PENDBASER correctly for 32 bit guests
- To: Ayan Kumar Halder <ayankuma@xxxxxxx>
- From: Bertrand Marquis <Bertrand.Marquis@xxxxxxx>
- Date: Tue, 25 Oct 2022 07:40:31 +0000
- Accept-language: en-GB, en-US
- Arc-authentication-results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 63.35.35.123) smtp.rcpttodomain=lists.xenproject.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=armh.onmicrosoft.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com])
- Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none
- Arc-message-signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=9ewpeZm/XYWzq/mwsQYghhUBYp76satYddO2KlgcCB8=; b=AKLGZR2c2IM6mWGYHQn+UfYjorikLGEBWJpc2ZjU9Gwxr7jheahWmuLbsQLYZLIsJ7yiVuptUKEgonIu8qe7+JDhBVo2kvavmI5Io7Q4pItvV71wfuabAokNkPimRWIIXVKnOCBFVoL6lwHreJB9LC5j25Yk/XbKzeDT5dm1F6tCPMkXIV5MUJftv3Kpw+XFMLvdMrbW7dih3fryXnZahYiWK+59NSNMJe7tdp//1blIiTvUNv+mXs2VQTfuIk3uDWN2WNIoXisDhVNKUO2lkozlMs5DIclDc3C3oJ+aUOO3papG+GJyosv3sDEuQzf5xod1GVBAfVHPQziADFvtGw==
- Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=9ewpeZm/XYWzq/mwsQYghhUBYp76satYddO2KlgcCB8=; b=KCzLMmh2YOSRejxVQxhx+2hyn6y03pDVGdW9b5ygJ7t7u7SlfxsSS5UMZSa1eSFTDGtoqNwZL5h1CuAjQbPqwSUM3xZsa0NdwE2qtdOI980i7KBxipSr+2/6jp1cdsmm39TwdTUKzzMJhggCncB9v+4UsLpAJJfbtVEWBYelK6q76A2EoQhUVsEy+ZB2+/FspWqM9Hvw6C004m3nD5LJT6lj0Vaw981Xq9GWDeqLIzUODl5TX5iZiGWksMeLJfDha+gUkQw6kkBnue01XTCy/0u3XPLRJUeqwvrniBUAU64dHnUHvJg6wFETRuF5QjQggE+4TD4b6K/crt6qzux5Hg==
- Arc-seal: i=2; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=pass; b=MBuHBkQZnmRCL1IP/Ma9ibELJnkuwAnZ7guGSMxQdno1jleXgt89CTLxmz09yq6Fj/FiwOTEBgfm8UlvaAMfJVYrE4EltO0pIA+onA5FtI0SSOtjryKMNDcdheMW1HOYi8LfhuSTFRK7v1j6vD+JEOA1univavFSgtXfKOMs5QjBK7cwHXOHuRM/gqbD0V1WPBtwIu94vAHjnYB5XijvfPutjP8ARKgDCxJqmuLPMXsf22LA6ggd12ZtdFIiRJaUtMxvTT2AMq0uX7QHLkurmoZJVgInzKc1dz/MPz7YQAkgVGmVhUsXQZK9SElgOSOQ1NLz+x/MFpTLD7W4yd2XSw==
- Arc-seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=J4oW2FOS1JMhYqD/qCIDo2eHVHXmoPOVMSQYSEDgld9QI4clDi537ZRedMMWcjz2GXFC7oT0vhDZjGfPoL6+DqSVsaRUH+5sDyfdwm+qrf/hvHWRjjk17SJlUyPluTwNR4xpKXe5AF9ndB3fvciM82NPY0IuPs84c/C1iJFW9Dt+Wlqo6oQrUsB+3Pv6Y8y25z1GF8/gU4qsyLgRs5IE8UgVzIHNsJ7+QDpb4LSCJJhr/OtOV7lkd1+eOAoyv6jb+LfcO+FW4BvhjiOQyl8KLtFyBNGWyExYGFbPS+lwSsXx4NcK0dkHAECH3jxVs7ecUHzrAZiWAdi79fz4mR6vyw==
- Authentication-results-original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com;
- Cc: Xen-devel <xen-devel@xxxxxxxxxxxxxxxxxxxx>, "sstabellini@xxxxxxxxxx" <sstabellini@xxxxxxxxxx>, "stefanos@xxxxxxxxxx" <stefanos@xxxxxxxxxx>, "julien@xxxxxxx" <julien@xxxxxxx>, "Volodymyr_Babchuk@xxxxxxxx" <Volodymyr_Babchuk@xxxxxxxx>, Andre Przywara <Andre.Przywara@xxxxxxx>
- Delivery-date: Tue, 25 Oct 2022 07:40:57 +0000
- List-id: Xen developer discussion <xen-devel.lists.xenproject.org>
- Nodisclaimer: true
- Original-authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com;
- Thread-index: AQHY598RF0NcPOhi1keCFg9FvX7Ft64eul4A
- Thread-topic: [XEN v2] GICv3: Emulate GICR_PENDBASER correctly for 32 bit guests
Hi Ayan,
> On 24 Oct 2022, at 20:30, Ayan Kumar Halder <ayankuma@xxxxxxx> wrote:
>
> If a guest is running in 32 bit mode and it tries to access
> "GICR_PENDBASER + 4" mmio reg, it will be trapped to Xen. vreg_reg64_extract()
> will return the value stored "v->arch.vgic.rdist_pendbase + 4".
> This will be stored in a 32bit register.
>
> The 32bit register is then modified bitwise with a mask (ie
> GICR_PENDBASER_PTZ,
> it clears the 62nd bit) which is greater than 32 bits. This will give an
> incorrect result.
>
> The correct thing to do here is to store the value of
> "v->arch.vgic.rdist_pendbase" in a temporary 64 bit variable. This variable is
> then modified bitwise with GICR_PENDBASER_PTZ mask. It is then passed to
> vreg_reg64_extract() which will extract 32 bits from the given offset.
>
> Fixes: fe7fa1332dabd9ce4 ("ARM: vGICv3: handle virtual LPI pending and
> property tables")
> Signed-off-by: Ayan Kumar Halder <ayankuma@xxxxxxx>
Looks good to me to.
Reviewed-by: Bertrand Marquis <bertrand.marquis@xxxxxxx>
Cheers
Bertrand
> ---
>
> Changes from:-
>
> v1 - 1. Extracted this fix from "[RFC PATCH v1 05/12] Arm: GICv3: Emulate
> GICR_PENDBASER and GICR_PROPBASER on AArch32" into a separate patch with an
> appropriate commit message.
>
> xen/arch/arm/vgic-v3.c | 6 ++++--
> 1 file changed, 4 insertions(+), 2 deletions(-)
>
> diff --git a/xen/arch/arm/vgic-v3.c b/xen/arch/arm/vgic-v3.c
> index 0c23f6df9d..7930ab6330 100644
> --- a/xen/arch/arm/vgic-v3.c
> +++ b/xen/arch/arm/vgic-v3.c
> @@ -250,14 +250,16 @@ static int __vgic_v3_rdistr_rd_mmio_read(struct vcpu
> *v, mmio_info_t *info,
> case VREG64(GICR_PENDBASER):
> {
> unsigned long flags;
> + uint64_t val;
>
> if ( !v->domain->arch.vgic.has_its )
> goto read_as_zero_64;
> if ( !vgic_reg64_check_access(dabt) ) goto bad_width;
>
> spin_lock_irqsave(&v->arch.vgic.lock, flags);
> - *r = vreg_reg64_extract(v->arch.vgic.rdist_pendbase, info);
> - *r &= ~GICR_PENDBASER_PTZ; /* WO, reads as 0 */
> + val = v->arch.vgic.rdist_pendbase;
> + val &= ~GICR_PENDBASER_PTZ; /* WO, reads as 0 */
> + *r = vreg_reg64_extract(val, info);
> spin_unlock_irqrestore(&v->arch.vgic.lock, flags);
> return 1;
> }
> --
> 2.17.1
>
|