[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH 1/2] domain: fix misaligned unmap address in unmap_guest_area()


  • To: Roger Pau Monne <roger.pau@xxxxxxxxxx>
  • From: Henry Wang <Henry.Wang@xxxxxxx>
  • Date: Fri, 6 Oct 2023 09:18:15 +0000
  • Accept-language: zh-CN, en-US
  • 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=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=DPzvR52As8AvAcdqiEFW9+Zvx3a5JHzYz23vhbnaoSI=; b=R1kqe/XHiPX8E8o8cbO+p+V+rxuG755kxlbf8YMYRlGWlxfJBQFVM1rKctAOOBSWU/gJtWktdIasWSw55gMkEqVk0ZSiiz0kyS28dvrCP7FEUALI8frOUwlf3Mn/v+GEJebDTzE1zSl+1GoZLydh8+YAwCgrk6S6Hojd9avxBRUbQh9YpE2jKBCkyS7PvSv7PDRSBcmNxqv/TGb2qBZWGLCAyeW5A+TBVoJIwCsmebaF8i9G4+BjJrLgw8Y+weoUZxmQ9tORXH+KmXDyz963WH5TSCZt9OPVDVokmNznsIEBY5ioEIPBIuTFCsL/6MpUfstpSwZVf2KIyE6DrQxZqA==
  • Arc-seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=Z9/rI49OEFFD3q5Gw7fDu5hYRc+QdvjQUDKD3bfJ5AXTV9aNKRrTnkeBm4n0tE2qlEE3/il2plgIyZtODRAbfAoHq4TtxHJT58stAvR8oTkshnddv+vMqcx9/+kriMY+W7KNj3h07XwqIP4pZiNjGWGa3DKDw6y6QT1JG6VoSGvX1cyh7ZI4dJ1oXeqMmZYVYDGcWj7Fr+gUXLSLkzzO2X2I8vPjtffo/SiW6T0f8f1gGonng4aidOd4K2y5XepMVpVfn6BU6fjNU1Bmj13NTNOYNQZOSIZjK/wYEcT77o67ov3ZUnwK+HJIiidGBQWydYbErcpa1WO9U0S//Llcbw==
  • 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>, Andrew Cooper <andrew.cooper3@xxxxxxxxxx>, George Dunlap <george.dunlap@xxxxxxxxxx>, Jan Beulich <jbeulich@xxxxxxxx>, Julien Grall <julien@xxxxxxx>, Stefano Stabellini <sstabellini@xxxxxxxxxx>, Wei Liu <wl@xxxxxxx>
  • Delivery-date: Fri, 06 Oct 2023 09:18:58 +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: AQHZ+DXYlqgh1jA6/kuitcOo78sZGrA8e5kA
  • Thread-topic: [PATCH 1/2] domain: fix misaligned unmap address in unmap_guest_area()

Hi Roger,

> On Oct 6, 2023, at 17:13, Roger Pau Monne <roger.pau@xxxxxxxxxx> wrote:
> 
> unmap_domain_page_global() expects the provided address to be page aligned, or
> else some of the called functions will trigger assertions, like
> modify_xen_mappings() on x86 or destroy_xen_mappings() on Arm.
> 
> The following assert has been reported by osstest arm 32bit tests:
> 
> (XEN) Assertion 'IS_ALIGNED(s, PAGE_SIZE)' failed at arch/arm/mm.c:1243
> (XEN) ----[ Xen-4.18-rc  arm32  debug=y  Not tainted ]----
> (XEN) CPU:    0
> (XEN) PC:     00271a38 destroy_xen_mappings+0x50/0x5c
> [...]
> (XEN) Xen call trace:
> (XEN)    [<00271a38>] destroy_xen_mappings+0x50/0x5c (PC)
> (XEN)    [<00235aa8>] vunmap+0x30/0x1a0 (LR)
> (XEN)    [<0026ad88>] unmap_domain_page_global+0x10/0x20
> (XEN)    [<00208e38>] unmap_guest_area+0x90/0xec
> (XEN)    [<00208f98>] domain_kill+0x104/0x180
> (XEN)    [<00239e3c>] do_domctl+0x8ac/0x14fc
> (XEN)    [<0027ae34>] do_trap_guest_sync+0x570/0x66c
> (XEN)    [<002019f0>] arch/arm/arm32/entry.o#return_from_trap+0/0x4
> 
> Fixes: eadc288cbb0d ('domain: map/unmap GADDR based shared guest areas')
> Signed-off-by: Roger Pau Monné <roger.pau@xxxxxxxxxx>

Release-acked-by: Henry Wang <Henry.Wang@xxxxxxx>

Kind regards,
Henry

> ---
> unmap_domain_page_global() and vunmap() should likely have the same alignment
> asserts, as not all paths lead to detecting the misalignment of the provided
> linear address.  Will do a separate patch.
> ---
> xen/common/domain.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/xen/common/domain.c b/xen/common/domain.c
> index b8281d7cff9d..2dcc64e659cc 100644
> --- a/xen/common/domain.c
> +++ b/xen/common/domain.c
> @@ -1634,7 +1634,7 @@ void unmap_guest_area(struct vcpu *v, struct guest_area 
> *area)
> 
>     if ( pg )
>     {
> -        unmap_domain_page_global(map);
> +        unmap_domain_page_global((void *)((unsigned long)map & PAGE_MASK));
>         put_page_and_type(pg);
>     }
> }
> -- 
> 2.42.0
> 


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.