| [Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
 Re: [PATCH 07/15] xen/overlay: Enable device tree overlay assignment to running domains
 
To: Jan Beulich <jbeulich@xxxxxxxx>, Julien Grall <julien@xxxxxxx>, "Stefano Stabellini" <sstabellini@xxxxxxxxxx>From: Henry Wang <xin.wang2@xxxxxxx>Date: Mon, 29 Apr 2024 11:36:14 +0800Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=suse.com smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none (0)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=KR2o27fZSEuoKaueE9YEOWjPvoqPgl0eotZZdzHPH3I=; b=bdnZWf7aM4ID5F5gnI5/lsrmA+nMgQGuPt3Ms7PO//ek7jWgarwQLYYQlVpsm76imfgvZ98DCG63lQFUG0JQ0WvITvy+7SCCgnxfmqs72RxpD7yA/3SPJyc4+yqHN++5O5aifcfZHgFjGPqtaUvSqp3KnJO+ZYP+a59314D9AMQxudJusCWBgDLdK8uesWZRVuzMwGXPmbjTUlRW3lmP3juBDGrzbo3mOemRyo19r8W/9hf63eY3SXxMGbG6Jk5Nznfl3vAH8426DopozpWJZk5ugKLR28APuCFYUxGDWMFq0lJthqeV96NTAaXfPgvfy7xUjkgTRk0ejvaRGw05ZA==Arc-seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=XWo+SP4tmkNaEldymWIF370aX4NVqaeh9WP88gy5w9qZ44tDivJbIiqe8+3F7seUYg4hAlNR5v81f4ButcaMXIyfbRmZWyGQ0gAx0WNGlmu4rYSuolYBLbChnDpkPIKl7LfJImsdFOR9MU0wq/CDZu0YnPVGwIvFNehAwi386dLkPhavgJ16DvkqRJTq9QgeJWoVHFQKXi8+Mi/mmIX31n28Uply1KgnEmwu7lvfrhpTW4YhrNOtlkIRkCxgJeAlRXxSRM18PT8ZpHjPabs+P/0jRW5oSAaODQoZbqR9lXSRg76c3n7IVKfuLxwRRM4NxQqmX9fdCpR7xwpcWS8Gaw==Cc: Bertrand Marquis <bertrand.marquis@xxxxxxx>, Michal Orzel	<michal.orzel@xxxxxxx>, Volodymyr Babchuk <Volodymyr_Babchuk@xxxxxxxx>,	Andrew Cooper <andrew.cooper3@xxxxxxxxxx>, George Dunlap	<george.dunlap@xxxxxxxxxx>, <xen-devel@xxxxxxxxxxxxxxxxxxxx>Delivery-date: Mon, 29 Apr 2024 03:36:41 +0000List-id: Xen developer discussion <xen-devel.lists.xenproject.org> 
 
Hi Jan, Julien, Stefano,
On 4/24/2024 2:05 PM, Jan Beulich wrote:
 
On 24.04.2024 05:34, Henry Wang wrote:
 
--- a/xen/include/public/sysctl.h
+++ b/xen/include/public/sysctl.h
@@ -1197,7 +1197,9 @@ struct xen_sysctl_dt_overlay {
  #define XEN_SYSCTL_DT_OVERLAY_ADD                   1
  #define XEN_SYSCTL_DT_OVERLAY_REMOVE                2
      uint8_t overlay_op;                     /* IN: Add or remove. */
-    uint8_t pad[3];                         /* IN: Must be zero. */
+    bool domain_mapping;                    /* IN: True of False. */
+    uint8_t pad[2];                         /* IN: Must be zero. */
+    uint32_t domain_id;
  };
 
If you merely re-purposed padding fields, all would be fine without
bumping the interface version. Yet you don't, albeit for an unclear
reason: Why uint32_t rather than domid_t? And on top of that - why a
separate boolean when you could use e.g. DOMID_INVALID to indicate
"no domain mapping"?
 
I think both of your suggestion make great sense. I will follow the 
suggestion in v2. 
 
That said - anything taking a domain ID is certainly suspicious in a
sysctl. Judging from the description you really mean this to be a
domctl. Anything else will require extra justification.
 
I also think a domctl is better. I had a look at the history of the 
already merged series, it looks like in the first version of merged part 
1 [1], the hypercall was implemented as the domctl in the beginning but 
later in v2 changed to sysctl. I think this makes sense as the scope of 
that time is just to make Xen aware of the device tree node via Xen 
device tree. 
However this is now a problem for the current part where the scope (and 
the end goal) is extended to assign the added device to Linux Dom0/DomU 
via device tree overlays. I am not sure which way is better, should we 
repurposing the sysctl to domctl or maybe add another domctl (I am 
worrying about the duplication because basically we need the same sysctl 
functionality but now with a domid in it)? What do you think? 
@Stefano: Since I am not 100% if I understand the whole story behind 
this feature, would you mind checking if I am providing correct 
information above and sharing your opinions on this? Thank you very much! 
[1] 
https://lore.kernel.org/xen-devel/13240b69-f7bb-6a64-b89c-b7c2cbb7e465@xxxxxxx/ 
Kind regards,
Henry
 
Jan
 
 
 |