| [Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
 Re: [PATCH v3 42/52] xen/mpu: implement setup_virt_paging for MPU system
 
To: Ayan Kumar Halder <ayankuma@xxxxxxx>, <xen-devel@xxxxxxxxxxxxxxxxxxxx>From: Penny Zheng <penny.zheng@xxxxxxx>Date: Wed, 5 Jul 2023 18:20:28 +0800Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 40.67.248.234) smtp.rcpttodomain=amd.com smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=none (message not signed); arc=noneArc-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=Sqve7jRIF2F2L+4fzmXf8o3N3GXZG2uKad+g8Ckc4AA=; b=b+JKO4pdWGQ80AOJF2SZihhjTOdpgmbTKZ0M978FxO5XdMjxPP9u4xadzXpsZtBMbD2KnWoaqu2gjcr9BxGXwjXbzxieU+ZxBFHBXRGRIxLdcvwBMg9fQ2Sx5hPLFBFLHKKAyvC9CN/YzlF1iqJCiUyVi4JDgq61k/Ax1twj16fbw55xvT4yz+8ZQUIVWaRiyv64RREayYzk0OnI9r7fIQwrlWCJ9vwZ8BQpObICk4/vGw+/2Zvm6YN1Gs6YPFp1eE8qQ8YUxz/0Gr8KTh5Lf+XzGhBvQD+2/s1yaD2htF7CpKRl//6pZvMq953xbTNNdEiR3CzJ/NtWkUUn6tS6iw==Arc-seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=oCkuLjakX4nDSMtaUMJ6LhFC7s1LJ7i9NHHHjNju0mNTJCvfxfktYqaSgc4j2/zokyqfbRZPrQGP9PYooWmR7j+LPPc4k4c2EsbqzB0GULQrEmmvTM6RHKTlR/eSNDkVJEHjz4Y01KyjlW6AZ3t566vEWnbYqtuxI8lKefaFuXua6opNxz0cNjRXFsEyhyxuGv3s9Pp3p/Qg84Fj3RdT88Aq3ewNMfXGxOJNvevu/tb4/+HDEf7wE4kf1QBOinO6248FnwhnaI5y0hplLkRv90ErVwy4pPEd6AIAkLK2vxdPgOwNFBowOkaEgU1L/mAfu4ZC+uIlQRUznB9HyXPkog==Cc: Stefano Stabellini <sstabellini@xxxxxxxxxx>, Julien Grall	<julien@xxxxxxx>, Bertrand Marquis <bertrand.marquis@xxxxxxx>, "Volodymyr Babchuk" <Volodymyr_Babchuk@xxxxxxxx>, Wei Chen <wei.chen@xxxxxxx>Delivery-date: Wed, 05 Jul 2023 10:21:08 +0000List-id: Xen developer discussion <xen-devel.lists.xenproject.org>Nodisclaimer: true 
 
Hi Ayan
On 2023/7/5 01:49, Ayan Kumar Halder wrote:
 
Hi Penny,
Most of these are specific to ARM_64, thus we can add "#ifdef 
CONFIG_ARM_64" as follows :-
 
Yes, you're right.
 
On 26/06/2023 04:34, Penny Zheng wrote:
 CAUTION: This message has originated from an External Source. Please 
use proper judgment and caution when opening attachments, clicking 
links, or responding to this email.
For MMU system, setup_virt_paging is used to configure stage 2 address
translation regime, like IPA bits, VMID allocator set up, etc.
Some could be inherited in MPU system, like VMID allocator set up, etc.
For MPU system, we could have the following memory translation regime:
- PMSAv8-64 at both EL1/EL0 and EL2
- VMSAv8-64 at EL1/EL0 and PMSAv8-64 at EL2
The default option will be the second, unless the platform could not 
support,
which could be checked against MSA_frac bit in Memory Model Feature 
Register 0( 
ID_AA64MMFR0_EL1).
Signed-off-by: Penny Zheng <penny.zheng@xxxxxxx>
Signed-off-by: Wei Chen <wei.chen@xxxxxxx>
---
v3:
- no change
---
  xen/arch/arm/Makefile                 |  1 +
  xen/arch/arm/include/asm/cpufeature.h |  7 ++
  xen/arch/arm/include/asm/p2m.h        |  8 +++
  xen/arch/arm/include/asm/processor.h  | 13 ++++
  xen/arch/arm/mpu/p2m.c                | 92 +++++++++++++++++++++++++++
  5 files changed, 121 insertions(+)
  create mode 100644 xen/arch/arm/mpu/p2m.c
diff --git a/xen/arch/arm/Makefile b/xen/arch/arm/Makefile
index feb49640a0..9f4b11b069 100644
--- a/xen/arch/arm/Makefile
+++ b/xen/arch/arm/Makefile
@@ -47,6 +47,7 @@ obj-y += mmu/p2m.o
  else
  obj-y += mpu/mm.o
  obj-y += mpu/setup.o
+obj-y += mpu/p2m.o
  endif
  obj-y += mm.o
  obj-y += monitor.o
diff --git a/xen/arch/arm/include/asm/cpufeature.h 
b/xen/arch/arm/include/asm/cpufeature.h 
index 894f278a4a..cbaf41881b 100644
--- a/xen/arch/arm/include/asm/cpufeature.h
+++ b/xen/arch/arm/include/asm/cpufeature.h
@@ -250,6 +250,12 @@ struct cpuinfo_arm {
              unsigned long tgranule_16K:4;
              unsigned long tgranule_64K:4;
              unsigned long tgranule_4K:4;
+#ifdef CONFIG_HAS_MPU
+            unsigned long __res:16;
+            unsigned long msa:4;
+            unsigned long msa_frac:4;
+            unsigned long __res0:8;
+#else
              unsigned long tgranule_16k_2:4;
              unsigned long tgranule_64k_2:4;
              unsigned long tgranule_4k_2:4;
@@ -257,6 +263,7 @@ struct cpuinfo_arm {
              unsigned long __res0:8;
              unsigned long fgt:4;
              unsigned long ecv:4;
+#endif
              /* MMFR1 */
              unsigned long hafdbs:4;
diff --git a/xen/arch/arm/include/asm/p2m.h 
b/xen/arch/arm/include/asm/p2m.h
index f62d632830..d9c91d4a98 100644
--- a/xen/arch/arm/include/asm/p2m.h
+++ b/xen/arch/arm/include/asm/p2m.h
@@ -16,8 +16,16 @@ extern unsigned int p2m_ipa_bits;
  extern unsigned int p2m_root_order;
  extern unsigned int p2m_root_level;
+#ifdef CONFIG_HAS_MPU
+/*
+ * A 4KB Page is enough for stage 2 translation in MPU system, which 
could 
+ * store at most 255 EL2 MPU memory regions.
+ */
+#define P2M_ROOT_ORDER 0
+#else
  #define P2M_ROOT_ORDER    p2m_root_order
  #define P2M_ROOT_LEVEL p2m_root_level
+#endif
  #define MAX_VMID_8_BIT  (1UL << 8)
  #define MAX_VMID_16_BIT (1UL << 16)
diff --git a/xen/arch/arm/include/asm/processor.h 
b/xen/arch/arm/include/asm/processor.h 
index 685f9b18fd..fe761ce50f 100644
--- a/xen/arch/arm/include/asm/processor.h
+++ b/xen/arch/arm/include/asm/processor.h
@@ -389,6 +389,12 @@
  #define VTCR_RES1       (_AC(1,UL)<<31)
+#ifdef CONFIG_HAS_MPU
 
&& ARM_64 /* As these are specific to ID_AA64MMFR0EL1 */
 
Will do
 
+#define VTCR_MSA_VMSA   (_AC(0x1,UL)<<31)
+#define VTCR_MSA_PMSA   ~(_AC(0x1,UL)<<31)
+#define NSA_SEL2        ~(_AC(0x1,UL)<<30)
+#endif
+
  /* HCPTR Hyp. Coprocessor Trap Register */
  #define HCPTR_TAM       ((_AC(1,U)<<30))
#define HCPTR_TTA       ((_AC(1,U)<<20))        /* Trap trace 
registers */ 
@@ -449,6 +455,13 @@
  #define MM64_VMID_16_BITS_SUPPORT   0x2
  #endif
+#ifdef CONFIG_HAS_MPU
 
&& ARM_64 /* As these are specific to ID_AA64MMFR0EL1 */
 
Will do
 
+#define MM64_MSA_PMSA_SUPPORT       0xf
+#define MM64_MSA_FRAC_NONE_SUPPORT  0x0
+#define MM64_MSA_FRAC_PMSA_SUPPORT  0x1
+#define MM64_MSA_FRAC_VMSA_SUPPORT  0x2
+#endif
+
  #ifndef __ASSEMBLY__
  extern register_t __cpu_logical_map[];
diff --git a/xen/arch/arm/mpu/p2m.c b/xen/arch/arm/mpu/p2m.c
new file mode 100644
index 0000000000..04c44825cb
--- /dev/null
+++ b/xen/arch/arm/mpu/p2m.c
@@ -0,0 +1,92 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+#include <xen/lib.h>
+#include <xen/mm-frame.h>
+#include <xen/sched.h>
+#include <xen/warning.h>
+
+#include <asm/p2m.h>
+#include <asm/processor.h>
+#include <asm/sysregs.h>
+
+void __init setup_virt_paging(void)
+{
+    uint64_t val = 0;
+    bool p2m_vmsa = true;
+
+    /* PA size */
+    const unsigned int pa_range_info[] = { 32, 36, 40, 42, 44, 48, 
52, 0, /* Invalid */ };
 
As this file is common between ARM_32 and ARM_64 and the following is 
specific to ARM_64, please add 
#ifdef CONFIG_ARM_64
 
Will do
 
 
+
+    /*
+     * Restrict "p2m_ipa_bits" if needed. As P2M table is always 
configured 
+     * with IPA bits == PA bits, compare against "pabits".
+     */
+    if ( pa_range_info[system_cpuinfo.mm64.pa_range] < p2m_ipa_bits )
+        p2m_ipa_bits = pa_range_info[system_cpuinfo.mm64.pa_range];
+
+    /* In ARMV8R, hypervisor in secure EL2. */
+    val &= NSA_SEL2;
+
+    /*
+     * The MSA and MSA_frac fields in the ID_AA64MMFR0_EL1 register
+     * identify the memory system configurations supported at EL1.
+     * In Armv8-R AArch64, the only permitted value for 
ID_AA64MMFR0_EL1.MSA is
+     * 0b1111. When ID_AA64MMFR0_EL1.MSA_frac is 0b0010, the stage 1 
of the 
+     * Secure EL1&0 translation regime can enable PMSAv8-64 or VMSAv8-64
+     * architecture.
+     */
+    if ( system_cpuinfo.mm64.msa == MM64_MSA_PMSA_SUPPORT )
+    {
+        if ( system_cpuinfo.mm64.msa_frac == 
MM64_MSA_FRAC_NONE_SUPPORT )
+            goto fault;
+
+        if ( system_cpuinfo.mm64.msa_frac != 
MM64_MSA_FRAC_VMSA_SUPPORT ) 
+        {
+            p2m_vmsa = false;
+            warning_add("Be aware of that there is no support for 
VMSAv8-64 at EL1 on this platform.\n");
+        }
+    }
+    else
+        goto fault;
+
+    /*
+     * If PE supports both PMSAv8-64 and VMSAv8-64 at EL1, then 
VTCR_EL2.MSA
+     * determines the memory system architecture enabled at stage 1 
of the 
+     * Secure EL1&0 translation regime.
+     *
+     * Normally, we set the initial VTCR_EL2.MSA value VMSAv8-64 
support, 
+     * unless this platform only supports PMSAv8-64.
+     */
+    if ( !p2m_vmsa )
+        val &= VTCR_MSA_PMSA;
+    else
+        val |= VTCR_MSA_VMSA;
+
+    /*
+     * cpuinfo sanitization makes sure we support 16bits VMID only if
+     * all cores are supporting it.
+     */
+    if ( system_cpuinfo.mm64.vmid_bits == MM64_VMID_16_BITS_SUPPORT )
+        max_vmid = MAX_VMID_16_BIT;
+
+    /* Set the VS bit only if 16 bit VMID is supported. */
+    if ( MAX_VMID == MAX_VMID_16_BIT )
+        val |= VTCR_VS;
+
 
#endif
- Ayan
 
+    p2m_vmid_allocator_init();
+
+    WRITE_SYSREG(val, VTCR_EL2);
+
+    return;
+
+fault:
+    panic("Hardware with no PMSAv8-64 support in any translation 
regime.\n"); 
+}
+
+/*
+ * Local variables:
+ * mode: C
+ * c-file-style: "BSD"
+ * c-basic-offset: 4
+ * indent-tabs-mode: nil
+ * End:
+ */
--
2.25.1
 
 
 |