From nobody Wed Jan 15 11:58:26 2025 Delivered-To: importer@patchew.org Received-SPF: pass (zohomail.com: domain of lists.xenproject.org designates 192.237.175.120 as permitted sender) client-ip=192.237.175.120; envelope-from=xen-devel-bounces@lists.xenproject.org; helo=lists.xenproject.org; Authentication-Results: mx.zohomail.com; spf=pass (zohomail.com: domain of lists.xenproject.org designates 192.237.175.120 as permitted sender) smtp.mailfrom=xen-devel-bounces@lists.xenproject.org; dmarc=fail(p=none dis=none) header.from=arm.com Return-Path: Received: from lists.xenproject.org (lists.xenproject.org [192.237.175.120]) by mx.zohomail.com with SMTPS id 1694405155822482.32724451547165; Sun, 10 Sep 2023 21:05:55 -0700 (PDT) Received: from list by lists.xenproject.org with outflank-mailman.598905.934101 (Exim 4.92) (envelope-from ) id 1qfYAy-0006JT-5d; Mon, 11 Sep 2023 04:05:28 +0000 Received: by outflank-mailman (output) from mailman id 598905.934101; Mon, 11 Sep 2023 04:05:28 +0000 Received: from localhost ([127.0.0.1] helo=lists.xenproject.org) by lists.xenproject.org with esmtp (Exim 4.92) (envelope-from ) id 1qfYAy-0006JK-2n; Mon, 11 Sep 2023 04:05:28 +0000 Received: by outflank-mailman (input) for mailman id 598905; Mon, 11 Sep 2023 04:05:27 +0000 Received: from se1-gles-flk1-in.inumbo.com ([94.247.172.50] helo=se1-gles-flk1.inumbo.com) by lists.xenproject.org with esmtp (Exim 4.92) (envelope-from ) id 1qfYAx-0005n2-08 for xen-devel@lists.xenproject.org; Mon, 11 Sep 2023 04:05:27 +0000 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by se1-gles-flk1.inumbo.com (Halon) with ESMTP id 6ef891a7-5058-11ee-9b0d-b553b5be7939; Mon, 11 Sep 2023 06:05:24 +0200 (CEST) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 2C334D75; Sun, 10 Sep 2023 21:06:01 -0700 (PDT) Received: from a011292.shanghai.arm.com (a011292.shanghai.arm.com [10.169.190.94]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id B67A33F67D; Sun, 10 Sep 2023 21:05:20 -0700 (PDT) X-Outflank-Mailman: Message body and most headers restored to incoming version X-BeenThere: xen-devel@lists.xenproject.org List-Id: Xen developer discussion List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Errors-To: xen-devel-bounces@lists.xenproject.org Precedence: list Sender: "Xen-devel" X-Inumbo-ID: 6ef891a7-5058-11ee-9b0d-b553b5be7939 From: Penny Zheng To: xen-devel@lists.xenproject.org Cc: michal.orzel@amd.com, wei.chen@arm.com, Penny Zheng , Stefano Stabellini , Julien Grall , Bertrand Marquis , Volodymyr Babchuk , Penny Zheng Subject: [PATCH v4 02/10] xen/arm: re-define a set of data structures for static shared memory region Date: Mon, 11 Sep 2023 12:04:34 +0800 Message-Id: <20230911040442.2541398-3-Penny.Zheng@arm.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20230911040442.2541398-1-Penny.Zheng@arm.com> References: <20230911040442.2541398-1-Penny.Zheng@arm.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-ZM-MESSAGEID: 1694405157179100005 Content-Type: text/plain; charset="utf-8" This commit introduces a set of separate data structures to deal with static shared memory at different stages. In boot-time host device tree parsing, we introduce a new structure "struct shm_node" and a new field "shm_info" in bootinfo to describe and store parsed shm info. only SHMID and "nr_borrowers", which describes the number of borrower domai= n, are considered here for per shm node. We also introduce a new local global data "shm_data" in bootfdt.c, in which, reserved memory bank is recorded together with shm node, to assist doing shm node verification. In order to apply above changes in acquire_nr_borrower_domain, we now use S= HMID to iterate "shminfo" to find requested shm node, then acquiring the informa= tion of "nr_borrowers". In the last, a new anonymized structure "shminfo", which is a array of compound structure that contains SHMID and a "struct membank membank" describing shared memory regions in guest address space, is created in "kin= fo" when dealing with domain information. Signed-off-by: Penny Zheng --- v1 -> v2: - As the original "struct shm_membank" was making reserving memory more complex and actually memory information could be still got from host Device\ Tree when dealing with domain construction, we introduce a new simple struc= ture "struct shm_node" in bootinfo to only store SHMID and "nr_borrowers" - Further restrict the scope of the local variable "struct meminfo *mem =3D &bootinfo.reserved_mem" - Introduce a new local global data "shm_data" in bootfdt.c. In which, rese= rved memory bank is recorded together with the shm node, to assist doing shm node verification. - Define a set of local variables that point to "shm_data.shm_nodes[i].membank->start", etc, to make the code more readable. - Use SHMID to iterate "shminfo" to find requested shm node, as we no longer store host memory bank info in shm node. - A new anonymized structure, which is a array of compound structure that contains SHMID and a "struct membank membank", describing shared memory reg= ion in guest, is introduced in "kinfo". --- v2 -> v3: - rebase and no changes --- v3 -> v4: rebase and no change --- xen/arch/arm/bootfdt.c | 57 ++++++++++++++++++------ xen/arch/arm/domain_build.c | 74 +++++++++++++++---------------- xen/arch/arm/include/asm/kernel.h | 9 +++- xen/arch/arm/include/asm/setup.h | 21 +++++++-- 4 files changed, 104 insertions(+), 57 deletions(-) diff --git a/xen/arch/arm/bootfdt.c b/xen/arch/arm/bootfdt.c index 2673ad17a1..66ad3ab3db 100644 --- a/xen/arch/arm/bootfdt.c +++ b/xen/arch/arm/bootfdt.c @@ -16,6 +16,16 @@ #include #include =20 +#ifdef CONFIG_STATIC_SHM +static __initdata struct { + unsigned int nr_nodes; + struct { + const struct shm_node *node; + const struct membank *membank; + } shm_nodes[NR_MEM_BANKS]; +} shm_data; +#endif + static bool __init device_tree_node_matches(const void *fdt, int node, const char *match) { @@ -409,7 +419,6 @@ static int __init process_shm_node(const void *fdt, int= node, const struct fdt_property *prop, *prop_id, *prop_role; const __be32 *cell; paddr_t paddr, gaddr, size; - struct meminfo *mem =3D &bootinfo.reserved_mem; unsigned int i; int len; bool owner =3D false; @@ -481,17 +490,21 @@ static int __init process_shm_node(const void *fdt, i= nt node, return -EINVAL; } =20 - for ( i =3D 0; i < mem->nr_banks; i++ ) + for ( i =3D 0; i < shm_data.nr_nodes; i++ ) { + paddr_t bank_start =3D shm_data.shm_nodes[i].membank->start; + paddr_t bank_size =3D shm_data.shm_nodes[i].membank->size; + const char *bank_id =3D shm_data.shm_nodes[i].node->shm_id; + /* * Meet the following check: * 1) The shm ID matches and the region exactly match * 2) The shm ID doesn't match and the region doesn't overlap * with an existing one */ - if ( paddr =3D=3D mem->bank[i].start && size =3D=3D mem->bank[i].s= ize ) + if ( paddr =3D=3D bank_start && size =3D=3D bank_size ) { - if ( strncmp(shm_id, mem->bank[i].shm_id, MAX_SHM_ID_LENGTH) = =3D=3D 0 ) + if ( strncmp(shm_id, bank_id, MAX_SHM_ID_LENGTH) =3D=3D 0 ) break; else { @@ -503,9 +516,9 @@ static int __init process_shm_node(const void *fdt, int= node, else { paddr_t end =3D paddr + size; - paddr_t bank_end =3D mem->bank[i].start + mem->bank[i].size; + paddr_t bank_end =3D bank_start + bank_size; =20 - if ( (end <=3D paddr) || (bank_end <=3D mem->bank[i].start) ) + if ( (end <=3D paddr) || (bank_end <=3D bank_start) ) { printk("fdt: static shared memory region %s overflow\n", s= hm_id); return -EINVAL; @@ -515,7 +528,7 @@ static int __init process_shm_node(const void *fdt, int= node, return -EINVAL; else { - if ( strcmp(shm_id, mem->bank[i].shm_id) !=3D 0 ) + if ( strcmp(shm_id, bank_id) !=3D 0 ) continue; else { @@ -527,16 +540,32 @@ static int __init process_shm_node(const void *fdt, i= nt node, } } =20 - if ( i =3D=3D mem->nr_banks ) + if ( (i =3D=3D shm_data.nr_nodes) && (i =3D=3D bootinfo.shminfo.nr_nod= es) ) { - if ( i < NR_MEM_BANKS ) + struct meminfo *mem =3D &bootinfo.reserved_mem; + + if ( (i < NR_MEM_BANKS) && (mem->nr_banks < NR_MEM_BANKS) ) { /* Static shared memory shall be reserved from any other use. = */ - safe_strcpy(mem->bank[mem->nr_banks].shm_id, shm_id); - mem->bank[mem->nr_banks].start =3D paddr; - mem->bank[mem->nr_banks].size =3D size; - mem->bank[mem->nr_banks].type =3D MEMBANK_STATIC_DOMAIN; + struct membank *membank =3D &mem->bank[mem->nr_banks]; + struct shm_node *shm_node =3D &bootinfo.shminfo.node[i]; + + membank->start =3D paddr; + membank->size =3D size; + membank->type =3D MEMBANK_STATIC_DOMAIN; mem->nr_banks++; + + /* Record static shared memory node info in bootinfo.shminfo */ + safe_strcpy(shm_node->shm_id, shm_id); + bootinfo.shminfo.nr_nodes++; + + /* + * Reserved memory bank is recorded together with shm + * node info in shm_data, to assist doing shm node verificatio= n. + */ + shm_data.shm_nodes[i].node =3D shm_node; + shm_data.shm_nodes[i].membank =3D membank; + shm_data.nr_nodes++; } else { @@ -549,7 +578,7 @@ static int __init process_shm_node(const void *fdt, int= node, * to calculate the reference count. */ if ( !owner ) - mem->bank[i].nr_shm_borrowers++; + bootinfo.shminfo.node[i].nr_shm_borrowers++; =20 return 0; } diff --git a/xen/arch/arm/domain_build.c b/xen/arch/arm/domain_build.c index c532fa882c..4901664682 100644 --- a/xen/arch/arm/domain_build.c +++ b/xen/arch/arm/domain_build.c @@ -774,28 +774,25 @@ static void __init assign_static_memory_11(struct dom= ain *d, } =20 #ifdef CONFIG_STATIC_SHM -static int __init acquire_nr_borrower_domain(struct domain *d, - paddr_t pbase, paddr_t psize, +static int __init acquire_nr_borrower_domain(const char *shm_id, unsigned long *nr_borrowers) { - unsigned int bank; + struct shm_node *shm_node; + unsigned int i; =20 - /* Iterate reserved memory to find requested shm bank. */ - for ( bank =3D 0 ; bank < bootinfo.reserved_mem.nr_banks; bank++ ) + /* Iterate to find requested static shared memory node. */ + for ( i =3D 0; i < bootinfo.shminfo.nr_nodes; i++ ) { - paddr_t bank_start =3D bootinfo.reserved_mem.bank[bank].start; - paddr_t bank_size =3D bootinfo.reserved_mem.bank[bank].size; + shm_node =3D &bootinfo.shminfo.node[i]; =20 - if ( (pbase =3D=3D bank_start) && (psize =3D=3D bank_size) ) - break; + if ( strcmp(shm_id, shm_node->shm_id) =3D=3D 0 ) + { + *nr_borrowers =3D shm_node->nr_shm_borrowers; + return 0; + } } =20 - if ( bank =3D=3D bootinfo.reserved_mem.nr_banks ) - return -ENOENT; - - *nr_borrowers =3D bootinfo.reserved_mem.bank[bank].nr_shm_borrowers; - - return 0; + return -EINVAL; } =20 /* @@ -859,7 +856,7 @@ static mfn_t __init acquire_shared_memory_bank(struct d= omain *d, =20 static int __init assign_shared_memory(struct domain *d, paddr_t pbase, paddr_t psize, - paddr_t gbase) + paddr_t gbase, const char *shm_id) { mfn_t smfn; int ret =3D 0; @@ -893,7 +890,7 @@ static int __init assign_shared_memory(struct domain *d, * Get the right amount of references per page, which is the number of * borrower domains. */ - ret =3D acquire_nr_borrower_domain(d, pbase, psize, &nr_borrowers); + ret =3D acquire_nr_borrower_domain(shm_id, &nr_borrowers); if ( ret ) return ret; =20 @@ -929,13 +926,16 @@ static int __init append_shm_bank_to_domain(struct ke= rnel_info *kinfo, paddr_t start, paddr_t size, const char *shm_id) { - if ( kinfo->shm_mem.nr_banks >=3D NR_MEM_BANKS ) + unsigned int nr_banks =3D kinfo->shminfo.nr_banks; + struct membank *membank =3D &kinfo->shminfo.bank[nr_banks].membank; + + if ( nr_banks >=3D NR_MEM_BANKS ) return -ENOMEM; =20 - kinfo->shm_mem.bank[kinfo->shm_mem.nr_banks].start =3D start; - kinfo->shm_mem.bank[kinfo->shm_mem.nr_banks].size =3D size; - safe_strcpy(kinfo->shm_mem.bank[kinfo->shm_mem.nr_banks].shm_id, shm_i= d); - kinfo->shm_mem.nr_banks++; + membank->start =3D start; + membank->size =3D size; + safe_strcpy(kinfo->shminfo.bank[nr_banks].shm_id, shm_id); + kinfo->shminfo.nr_banks++; =20 return 0; } @@ -1019,7 +1019,7 @@ static int __init process_shm(struct domain *d, struc= t kernel_info *kinfo, * specified, so they should be assigned to dom_io. */ ret =3D assign_shared_memory(owner_dom_io ? dom_io : d, - pbase, psize, gbase); + pbase, psize, gbase, shm_id); if ( ret ) return ret; } @@ -1405,12 +1405,12 @@ static int __init make_memory_node(const struct dom= ain *d, static int __init make_shm_memory_node(const struct domain *d, void *fdt, int addrcells, int sizecells, - const struct meminfo *mem) + const struct kernel_info *kinfo) { unsigned int i =3D 0; int res =3D 0; =20 - if ( mem->nr_banks =3D=3D 0 ) + if ( kinfo->shminfo.nr_banks =3D=3D 0 ) return -ENOENT; =20 /* @@ -1420,17 +1420,17 @@ static int __init make_shm_memory_node(const struct= domain *d, */ dt_dprintk("Create xen-shmem node\n"); =20 - for ( ; i < mem->nr_banks; i++ ) + for ( ; i < kinfo->shminfo.nr_banks; i++ ) { - uint64_t start =3D mem->bank[i].start; - uint64_t size =3D mem->bank[i].size; + uint64_t start =3D kinfo->shminfo.bank[i].membank.start; + uint64_t size =3D kinfo->shminfo.bank[i].membank.size; const char compat[] =3D "xen,shared-memory-v1"; /* Worst case addrcells + sizecells */ __be32 reg[GUEST_ROOT_ADDRESS_CELLS + GUEST_ROOT_SIZE_CELLS]; __be32 *cells; unsigned int len =3D (addrcells + sizecells) * sizeof(__be32); =20 - res =3D domain_fdt_begin_node(fdt, "xen-shmem", mem->bank[i].start= ); + res =3D domain_fdt_begin_node(fdt, "xen-shmem", start); if ( res ) return res; =20 @@ -1448,7 +1448,7 @@ static int __init make_shm_memory_node(const struct d= omain *d, dt_dprintk("Shared memory bank %u: %#"PRIx64"->%#"PRIx64"\n", i, start, start + size); =20 - res =3D fdt_property_string(fdt, "xen,id", mem->bank[i].shm_id); + res =3D fdt_property_string(fdt, "xen,id", kinfo->shminfo.bank[i].= shm_id); if ( res ) return res; =20 @@ -1473,7 +1473,7 @@ static int __init make_shm_memory_node(const struct d= omain *d, static int __init make_shm_memory_node(const struct domain *d, void *fdt, int addrcells, int sizecells, - const struct meminfo *mem) + const struct kernel_info *kinfo) { ASSERT_UNREACHABLE(); return -EOPNOTSUPP; @@ -1483,13 +1483,13 @@ static int __init make_shm_memory_node(const struct= domain *d, static int __init make_resv_memory_node(const struct domain *d, void *fdt, int addrcells, int sizecells, - const struct meminfo *mem) + const struct kernel_info *kinfo) { int res =3D 0; /* Placeholder for reserved-memory\0 */ const char resvbuf[16] =3D "reserved-memory"; =20 - if ( mem->nr_banks =3D=3D 0 ) + if ( kinfo->shminfo.nr_banks =3D=3D 0 ) /* No shared memory provided. */ return 0; =20 @@ -1511,7 +1511,7 @@ static int __init make_resv_memory_node(const struct = domain *d, if ( res ) return res; =20 - res =3D make_shm_memory_node(d, fdt, addrcells, sizecells, mem); + res =3D make_shm_memory_node(d, fdt, addrcells, sizecells, kinfo); if ( res ) return res; =20 @@ -2470,8 +2470,7 @@ static int __init handle_node(struct domain *d, struc= t kernel_info *kinfo, return res; } =20 - res =3D make_resv_memory_node(d, kinfo->fdt, addrcells, sizecells, - &kinfo->shm_mem); + res =3D make_resv_memory_node(d, kinfo->fdt, addrcells, sizecells,= kinfo); if ( res ) return res; } @@ -3027,8 +3026,7 @@ static int __init prepare_dtb_domU(struct domain *d, = struct kernel_info *kinfo) if ( ret ) goto err; =20 - ret =3D make_resv_memory_node(d, kinfo->fdt, addrcells, sizecells, - &kinfo->shm_mem); + ret =3D make_resv_memory_node(d, kinfo->fdt, addrcells, sizecells, kin= fo); if ( ret ) goto err; =20 diff --git a/xen/arch/arm/include/asm/kernel.h b/xen/arch/arm/include/asm/k= ernel.h index 4617cdc83b..590bc56f6c 100644 --- a/xen/arch/arm/include/asm/kernel.h +++ b/xen/arch/arm/include/asm/kernel.h @@ -38,7 +38,14 @@ struct kernel_info { void *fdt; /* flat device tree */ paddr_t unassigned_mem; /* RAM not (yet) assigned to a bank */ struct meminfo mem; - struct meminfo shm_mem; + /* Static shared memory banks */ + struct { + unsigned int nr_banks; + struct { + char shm_id[MAX_SHM_ID_LENGTH]; + struct membank membank; + } bank[NR_MEM_BANKS]; + } shminfo; =20 /* kernel entry point */ paddr_t entry; diff --git a/xen/arch/arm/include/asm/setup.h b/xen/arch/arm/include/asm/se= tup.h index b8866c20f4..3c5fc23eb1 100644 --- a/xen/arch/arm/include/asm/setup.h +++ b/xen/arch/arm/include/asm/setup.h @@ -50,10 +50,6 @@ struct membank { paddr_t start; paddr_t size; enum membank_type type; -#ifdef CONFIG_STATIC_SHM - char shm_id[MAX_SHM_ID_LENGTH]; - unsigned int nr_shm_borrowers; -#endif }; =20 struct meminfo { @@ -95,6 +91,17 @@ struct bootcmdlines { struct bootcmdline cmdline[MAX_MODULES]; }; =20 +#ifdef CONFIG_STATIC_SHM +/* + * struct shm_node represents a static shared memory node shared between + * multiple domains, identified by the unique SHMID("xen,shm-id"). + */ +struct shm_node { + char shm_id[MAX_SHM_ID_LENGTH]; + unsigned int nr_shm_borrowers; +}; +#endif + struct bootinfo { struct meminfo mem; /* The reserved regions are only used when booting using Device-Tree */ @@ -105,6 +112,12 @@ struct bootinfo { struct meminfo acpi; #endif bool static_heap; +#ifdef CONFIG_STATIC_SHM + struct { + unsigned int nr_nodes; + struct shm_node node[NR_MEM_BANKS]; + } shminfo; +#endif }; =20 struct map_range_data --=20 2.25.1