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

Re: [PATCH] xen/device-tree: Allow exact match for overlapping regions


  • To: Luca Fancellu <Luca.Fancellu@xxxxxxx>, Michal Orzel <michal.orzel@xxxxxxx>
  • From: Grygorii Strashko <grygorii_strashko@xxxxxxxx>
  • Date: Thu, 7 Nov 2024 11:42:16 +0200
  • Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=epam.com; dmarc=pass action=none header.from=epam.com; dkim=pass header.d=epam.com; arc=none
  • Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; 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=LFiayGjTBRcI7cQ0abKObLDf+rLXE69e44c4qw3gLHU=; b=JO3Nl23BCXMJKTehje+UCT69j4YQMpFt9tyKx7bTb6qbWjWmSxEhNLynrKm05/ui1V7gNMxMxQ84arY3dESYwZemislK4lfU6RSjntZyP/97kgq7BkFNfMxekmQvuoC2yqjK1vL4f2xfPFeDbRktAcGGIeos7tNAGL7E/UuBBkN8/ki/cJnEdDp6Z5E1IBHWrqvPQBCOQmEU8YNd2IDbUngaPamNnM/eE6Pja2H6Dox+6zWH0/NI7y0qO7RxJ3gboLXvBMG7Z/rtNprzVlJ+YoIxhzNKMEctG6Dg+Lq58hzCNHAJPRWznpyyGmVqABAOCGSmL6M4ENS0KNv+nZb53Q==
  • Arc-seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=JM7M/jZ4xo1bf+kazui9cGGZ6hmQ09CvRlkGyeQNf+nX11UwnKFqrZ73oEjXt7ldNK5AF8udwide8AvJsyPH29mqtHfoKfh+Ykmv5IE7l7o1qLsEztq/+3J0sYF+khlHD5SiOHBQ4T6i7mbxtVLlvS9eI7t/Wqh8GjVPFHbFcMBiacYQ7W5LRZRDHWbGSSWLCufAbPgVb6c4Xp8Z3lG0eOA6kJSrJBcauJAX0d2biOAMf00a9Rj1XjTFBfZaZm4eQGU7g/sFC3QCB1YMaOxaBCcdYL/V4ZxNdA18n/p8GXt0A1cFDdb4FApK2WmxiVV3XpLrejfzPO1edWV8mp7dxA==
  • Authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=epam.com;
  • Cc: "xen-devel@xxxxxxxxxxxxxxxxxxxx" <xen-devel@xxxxxxxxxxxxxxxxxxxx>, Stefano Stabellini <sstabellini@xxxxxxxxxx>, Julien Grall <julien@xxxxxxx>, Bertrand Marquis <Bertrand.Marquis@xxxxxxx>, Volodymyr Babchuk <Volodymyr_Babchuk@xxxxxxxx>, Shawn Anastasio <sanastasio@xxxxxxxxxxxxxxxxxxxxx>
  • Delivery-date: Thu, 07 Nov 2024 09:42:29 +0000
  • List-id: Xen developer discussion <xen-devel.lists.xenproject.org>



On 06.11.24 17:16, Luca Fancellu wrote:
Hi Michal,

So we have 2 separate issues. I don't particularly like the concept of 
introducing MEMBANK_NONE
and the changes below look a bit too much for me, given that for boot modules 
we can only have
/memreserve/ matching initrd.

Shawn patch fixes the first issue. AFAICT the second issue can be fixed by 
below simple patch:
diff --git a/xen/common/device-tree/bootfdt.c b/xen/common/device-tree/bootfdt.c
index 927f59c64b0d..d8bd8c44bd35 100644
--- a/xen/common/device-tree/bootfdt.c
+++ b/xen/common/device-tree/bootfdt.c
@@ -586,6 +586,10 @@ size_t __init boot_fdt_info(const void *fdt, paddr_t paddr)

     add_boot_module(BOOTMOD_FDT, paddr, fdt_totalsize(fdt), false);

+    ret = device_tree_for_each_node(fdt, 0, early_scan_node, NULL);
+    if ( ret )
+        panic("Early FDT parsing failed (%d)\n", ret);
+
     nr_rsvd = fdt_num_mem_rsv(fdt);
     if ( nr_rsvd < 0 )
         panic("Parsing FDT memory reserve map failed (%d)\n", nr_rsvd);
@@ -594,10 +598,14 @@ size_t __init boot_fdt_info(const void *fdt, paddr_t 
paddr)
     {
         struct membank *bank;
         paddr_t s, sz;
+        const struct bootmodule *mod = 
boot_module_find_by_kind(BOOTMOD_RAMDISK);

         if ( fdt_get_mem_rsv_paddr(device_tree_flattened, i, &s, &sz) < 0 )
             continue;

+        if ( mod && (mod->start == s) && (mod->size == sz) )
+            continue;

Ok I see, we skip the /memreserve/ entry if it matches the ramdisk, fair enough, I 
don’t have
a strong opinion on how we do that, the important thing is just to unblock the 
users experiencing
this issue.

Don't know if my opinion would matter here, but Luca's patch looks more generic 
and logically solid for me.
While handling only "ramdisk" somewhere in the middle  - looks more like a hack.

Any way, it's up to you.

BR,
-grygorii



 


Rackspace

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