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

Re: [PATCH v5 03/10] x86: Replace arch-specific boot_domain with the common one


  • To: Jan Beulich <jbeulich@xxxxxxxx>, Daniel Smith <dpsmith@xxxxxxxxxxxxxxxxxxxx>, Jason Andryuk <jandryuk@xxxxxxxxx>
  • From: Alejandro Vallejo <agarciav@xxxxxxx>
  • Date: Wed, 2 Jul 2025 17:09:14 +0200
  • Arc-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=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=eeBTMrEK3aTP+oGwoX/h0j9uIi2Xm5BPiC+m9qBqLUE=; b=KYj7J6gvQ3Q3Ke0RDs4IQdw/cZQ/KdskXrDDWHk1XN/z/WxUbt0xJdW51VN5zixY3StVnPYptfczgN35KoqoVJ6PGlgI11nr4JJY6wwayYGppQhgcUmxPphwvmPFOz1EK3QSEQ9cDh3MClp7sxlK1a/nGkIJzotJq9X6I1emuzVJyyujmLCZ+g4Go8bIqDlf8bkRwDn5GGDj11eMaEKTGf2ehRsDQshe5hdBn1ggrwrJkBIZ7lYDdz3VuUzNwTXbjWnuKJ2tOjm2/g7NF65bjV0uReXVXpWszgOlu7C16rR+WzzVI7TSQ9xrU/Ebz0dG3NRnMy1SkbjJzfUo9qzXpg==
  • Arc-seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=KW4dBOCGgvw27U7uNuKxdQ5Y1UWLW/SP6PIdK7wZ9l0RJL0ElP62CBRdJHEiAMUICsOLL5SMLOwb+LFBfnsI0v3+61cZooTKsR2ZQ9gy+XmhkgoSYmWg7IT826dzbowleTIXFwFgjgpHJvhJQvAfkn6vsDrYQCSF5lFiKxB+FrbkaHCSf050GjFJKaBqlmgnJ4iw2Jq1j3xJHPlzlvgp9T85xMMQqBprQdkn/tmAFjxT9sDkBfeArVGmSmln7izEYNMD7My6jXMawj7rD4lcbRIAnbLD0whNNyX5CtnJ2LAfvnleeh9DkT4oK9r0btntiZhl9EtSRM45HbH4ZHIeQg==
  • Cc: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>, Roger Pau Monné <roger.pau@xxxxxxxxxx>, Stefano Stabellini <sstabellini@xxxxxxxxxx>, Julien Grall <julien@xxxxxxx>, Bertrand Marquis <bertrand.marquis@xxxxxxx>, Michal Orzel <michal.orzel@xxxxxxx>, <xen-devel@xxxxxxxxxxxxxxxxxxxx>
  • Delivery-date: Wed, 02 Jul 2025 15:09:35 +0000
  • List-id: Xen developer discussion <xen-devel.lists.xenproject.org>

On Wed Jul 2, 2025 at 3:15 PM CEST, Jan Beulich wrote:
> On 01.07.2025 12:56, Alejandro Vallejo wrote:
>> --- a/xen/arch/x86/include/asm/bootfdt.h
>> +++ b/xen/arch/x86/include/asm/bootfdt.h
>> @@ -3,6 +3,12 @@
>>  #define X86_BOOTFDT_H
>>  
>>  #include <xen/types.h>
>> +#include <public/xen.h>
>> +
>> +struct arch_boot_domain
>> +{
>> +    domid_t domid;
>> +};
>>  
>>  struct arch_boot_module
>>  {
>>[...]
>> @@ -1048,11 +1050,11 @@ static struct domain *__init create_dom0(struct 
>> boot_info *bi)
>>          dom0_cfg.flags |= XEN_DOMCTL_CDF_iommu;
>>  
>>      /* Create initial domain.  Not d0 for pvshim. */
>> -    bd->domid = get_initial_domain_id();
>> -    d = domain_create(bd->domid, &dom0_cfg,
>> +    bd->arch.domid = get_initial_domain_id();
>> +    d = domain_create(bd->arch.domid, &dom0_cfg,
>>                        pv_shim ? 0 : CDF_privileged | CDF_hardware);
>>      if ( IS_ERR(d) )
>> -        panic("Error creating d%u: %ld\n", bd->domid, PTR_ERR(d));
>> +        panic("Error creating d%u: %ld\n", bd->arch.domid, PTR_ERR(d));
>
> This being the only place where the (now) arch-specific field is used, why
> does it exist? A local variable would do? And if it's needed for
> (supposedly arch-agnostic) hyperlaunch, then it probably shouldn't be
> arch-specific? Daniel, Jason?
>
> Jan

As for the arch-agnostic side of things, arm needs some extra work to be
able to do it safely. dom0less currently constructs domains immediately after
parsing them, which is problematic for cases where some domains have the prop
and others don't. The domid allocation strategy may preclude further otherwise
good domains from being created just because their domid was stolen by a domain
that didn't actually care about which domid it got.

It'll eventually want to leave the arch-specific area, but I don't want to do
that work now.

Cheers,
Alejandro



 


Rackspace

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