From nobody Wed Jan 15 12:05:10 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 169440516866198.17627731306743; Sun, 10 Sep 2023 21:06:08 -0700 (PDT) Received: from list by lists.xenproject.org with outflank-mailman.598913.934142 (Exim 4.92) (envelope-from ) id 1qfYBD-0007sE-Ll; Mon, 11 Sep 2023 04:05:43 +0000 Received: by outflank-mailman (output) from mailman id 598913.934142; Mon, 11 Sep 2023 04:05:43 +0000 Received: from localhost ([127.0.0.1] helo=lists.xenproject.org) by lists.xenproject.org with esmtp (Exim 4.92) (envelope-from ) id 1qfYBD-0007rB-HT; Mon, 11 Sep 2023 04:05:43 +0000 Received: by outflank-mailman (input) for mailman id 598913; Mon, 11 Sep 2023 04:05:42 +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 1qfYBC-0005n2-Jz for xen-devel@lists.xenproject.org; Mon, 11 Sep 2023 04:05:42 +0000 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by se1-gles-flk1.inumbo.com (Halon) with ESMTP id 77c85679-5058-11ee-9b0d-b553b5be7939; Mon, 11 Sep 2023 06:05:39 +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 DD97BD75; Sun, 10 Sep 2023 21:06:15 -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 C0CFE3F67D; Sun, 10 Sep 2023 21:05:35 -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: 77c85679-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 06/10] xen/arm: remove shm holes for extended regions Date: Mon, 11 Sep 2023 12:04:38 +0800 Message-Id: <20230911040442.2541398-7-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: 1694405170574100001 Content-Type: text/plain; charset="utf-8" Static shared memory acts as reserved memory in guest, so it shall be excluded from extended regions. Extended regions are taken care of under three different scenarios: normal DomU, direct-map domain with iommu on, and direct-map domain with iommu off. For normal DomU, we create a new function "remove_shm_holes_for_domU", to firstly transfer original outputs into the format of "struct rangeset", then use "remove_shm_from_rangeset" to remove static shm from them. For direct-map domain with iommu on, after we get guest shm info from "kinf= o", we use "remove_shm_from_rangeset" to remove static shm. For direct-map domain with iommu off, as static shm has already been taken care of through reserved memory banks, we do nothing. Signed-off-by: Penny Zheng --- v1 -> v2: - new commit --- v2 -> v3: - error out non-zero res before remove_shm_holes_for_domU - rebase --- v3 -> v4: rebase and no change --- xen/arch/arm/domain_build.c | 97 ++++++++++++++++++++++++++++++++++++- 1 file changed, 96 insertions(+), 1 deletion(-) diff --git a/xen/arch/arm/domain_build.c b/xen/arch/arm/domain_build.c index 2eae50d78b..02d903be78 100644 --- a/xen/arch/arm/domain_build.c +++ b/xen/arch/arm/domain_build.c @@ -1974,6 +1974,32 @@ static int __init handle_pci_range(const struct dt_d= evice_node *dev, return 0; } =20 +static int __init remove_shm_from_rangeset(const struct kernel_info *kinfo, + struct rangeset *rangeset) +{ + unsigned int i; + + /* Remove static shared memory regions */ + for ( i =3D 0; i < kinfo->shminfo.nr_banks; i++ ) + { + struct membank membank =3D kinfo->shminfo.bank[i].membank; + paddr_t start, end; + int res; + + start =3D membank.start; + end =3D membank.start + membank.size - 1; + res =3D rangeset_remove_range(rangeset, start, end); + if ( res ) + { + printk(XENLOG_ERR "Failed to remove: %#"PRIpaddr"->%#"PRIpaddr= "\n", + start, end); + return -EINVAL; + } + } + + return 0; +} + /* * Find the holes in the Host DT which can be exposed to Dom0 as extended * regions for the special memory mappings. In order to calculate regions @@ -1982,6 +2008,8 @@ static int __init handle_pci_range(const struct dt_de= vice_node *dev, * - MMIO * - Host RAM * - PCI aperture + * - Static shared memory regions, which are described by special property + * "xen,static-shm" */ static int __init find_memory_holes(const struct kernel_info *kinfo, struct meminfo *ext_regions) @@ -2058,6 +2086,14 @@ static int __init find_memory_holes(const struct ker= nel_info *kinfo, } } =20 + /* Remove static shared memory regions */ + if ( kinfo->shminfo.nr_banks !=3D 0 ) + { + res =3D remove_shm_from_rangeset(kinfo, mem_holes); + if ( res ) + goto out; + } + start =3D 0; end =3D (1ULL << p2m_ipa_bits) - 1; res =3D rangeset_report_ranges(mem_holes, PFN_DOWN(start), PFN_DOWN(en= d), @@ -2073,6 +2109,62 @@ out: return res; } =20 +static int __init remove_shm_holes_for_domU(const struct kernel_info *kinf= o, + struct meminfo *orig_ext) +{ + struct rangeset *guest_holes; + unsigned int i =3D 0, tail; + int res; + paddr_t start, end; + + /* No static shared memory region. */ + if ( kinfo->shminfo.nr_banks =3D=3D 0 ) + return 0; + + dt_dprintk("Remove static shared memory holes for extended regions of = DomU\n"); + + guest_holes =3D rangeset_new(NULL, NULL, 0); + if ( !guest_holes ) + return -ENOMEM; + + for ( ; i < orig_ext->nr_banks; i++ ) + { + start =3D orig_ext->bank[i].start; + end =3D start + orig_ext->bank[i].size - 1; + + res =3D rangeset_add_range(guest_holes, start, end); + if ( res ) + { + printk(XENLOG_ERR "Failed to add: %#"PRIpaddr"->%#"PRIpaddr"\n= ", + start, end); + goto out; + } + } + + /* Remove static shared memory regions */ + res =3D remove_shm_from_rangeset(kinfo, guest_holes); + if ( res ) + goto out; + + tail =3D orig_ext->nr_banks - 1; + start =3D orig_ext->bank[0].start; + end =3D orig_ext->bank[tail].start + orig_ext->bank[tail].size - 1; + + /* Reset original extended regions to hold new value */ + orig_ext->nr_banks =3D 0; + res =3D rangeset_report_ranges(guest_holes, start, end, + add_ext_regions, orig_ext); + if ( res ) + orig_ext->nr_banks =3D 0; + else if ( !orig_ext->nr_banks ) + res =3D -ENOENT; + +out: + rangeset_destroy(guest_holes); + + return res; +} + static int __init find_domU_holes(const struct kernel_info *kinfo, struct meminfo *ext_regions) { @@ -2100,7 +2192,10 @@ static int __init find_domU_holes(const struct kerne= l_info *kinfo, res =3D 0; } =20 - return res; + if ( res ) + return res; + + return remove_shm_holes_for_domU(kinfo, ext_regions); } =20 static int __init make_hypervisor_node(struct domain *d, --=20 2.25.1