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

Re: [PATCH v6 2/3] xen/arm32: Create the same boot-time MPU regions as arm64


  • To: Ayan Kumar Halder <ayankuma@xxxxxxx>, Ayan Kumar Halder <ayan.kumar.halder@xxxxxxx>, xen-devel@xxxxxxxxxxxxxxxxxxxx
  • From: "Orzel, Michal" <michal.orzel@xxxxxxx>
  • Date: Mon, 14 Apr 2025 14:06:00 +0200
  • Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=amd.com; dmarc=pass action=none header.from=amd.com; dkim=pass header.d=amd.com; arc=none
  • 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=EkUYjbZyUBb/mXB+lZuHjunoIC3RntRvcNqu4J+48uA=; b=YXCrEXAbPCKZhjm3gE0ahCxYwr5UgrZ9PiluCZHkc4CPA0f6YqvaSUrdc9EVusYGvxTLtPep6S1fgALX7NcgRmKvFHccAx3hB59gyxfFVBmo7xU6i2XCW7ggKd8n9WU73HcyQJVjqFp5wSNhZvqKuDzdcAO1WZafGaq4KWLf+ZzcEWlA5IU8+4sb9X6cNJXsxHz/iK76bbWt6wl3B7ES1ecym4KUKyvc6jWiLEEBL89O3O9QOzGqMkbLBQ/OaR91j8YWBPUj787G8qtJaM9DyUGE8VJyc8LTOmWElkcAr8YDaZ3UIJkBSsolPSMQ0f9jVCBxDXm0dG83SJ6NOzGuQg==
  • Arc-seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=gLBdcMg+vedskUeWEqoNMr+qQhr6SV5DHM19tYxLuVAOyS+5SwrvPwZrpQ5tl+Q1YopvcK62uI/n0WI9adUCBR/J1iHLh21YEZ2ujSK2FC5KyWwEdg36+exkHjWlRLgHp5xVoz1v8Tyle24zTNvs55uvjVhnhsckDfNNMe5ZjXDJ62uL9gCxx7H2YDR9Uskj6O9hi3I1ZEEs0I3wbF+WuS/ZfLQFWQB6pse4y74tzkw2cSWrbY2AX2eJ8nsYP72CB5w6TNWmswEQu46cNdVebJmxjGib0tWcj2m4G56l6OqaxIMdxZDGMZJbj0xe+fVPMhISWCbRmQLNm7VY9hO+Pw==
  • Authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=amd.com;
  • Cc: Stefano Stabellini <sstabellini@xxxxxxxxxx>, Julien Grall <julien@xxxxxxx>, Bertrand Marquis <bertrand.marquis@xxxxxxx>, Volodymyr Babchuk <Volodymyr_Babchuk@xxxxxxxx>, Luca Fancellu <luca.fancellu@xxxxxxx>
  • Delivery-date: Mon, 14 Apr 2025 12:06:12 +0000
  • List-id: Xen developer discussion <xen-devel.lists.xenproject.org>


On 14/04/2025 13:12, Ayan Kumar Halder wrote:
> Hi Michal,
> 
> On 14/04/2025 09:38, Orzel, Michal wrote:
>>
>> On 11/04/2025 13:04, Ayan Kumar Halder wrote:
>>> Boot-time MPU protection regions (similar to Armv8-R AArch64) are created 
>>> for
>>> Armv8-R AArch32.
>>> Also, defined *_PRBAR macros for arm32. The only difference from arm64 is 
>>> that
>>> XN is 1-bit for arm32.
>>> Defined the system registers and macros in mpu/cpregs.h.
>>>
>>> Introduced WRITE_SYSREG_ASM() to write to system registers in assembly.
>> It really reads odd when you write what patch does in past tense.
> I will change it.
>>
>>> Signed-off-by: Ayan Kumar Halder <ayan.kumar.halder@xxxxxxx>
>>> Reviewed-by: Luca Fancellu <luca.fancellu@xxxxxxx>
>>> ---
>>> Changes from
>>>
>>> v1 -
>>>
>>> 1. enable_mpu() now sets HMAIR{0,1} registers. This is similar to what is
>>> being done in enable_mmu(). All the mm related configurations happen in this
>>> function.
>>>
>>> 2. Fixed some typos.
>>>
>>> v2 -
>>> 1. Include the common prepare_xen_region.inc in head.S.
>>>
>>> 2. Define LOAD_SYSREG()/STORE_SYSREG() for arm32.
>>>
>>> v3 -
>>> 1. Rename STORE_SYSREG() as WRITE_SYSREG_ASM()
>>>
>>> 2. enable_boot_cpu_mm() is defined in head.S
>>>
>>> v4 -
>>> 1. *_PRBAR is moved to arm32/sysregs.h.
>>>
>>> 2. MPU specific CP15 system registers are defined in mpu/cpregs.h.
>>>
>>> v5 -
>>> 1. WRITE_SYSREG_ASM is enclosed within #ifdef __ASSEMBLY__
>>>
>>> 2. enable_mpu() clobbers r0 only.
>>>
>>> 3. Definitions in mpu/cpregs.h in enclosed within ARM_32.
>>>
>>> 4. Removed some #ifdefs and style changes.
>>>
>>>   xen/arch/arm/arm32/Makefile              |   1 +
>>>   xen/arch/arm/arm32/mpu/Makefile          |   1 +
>>>   xen/arch/arm/arm32/mpu/head.S            | 104 +++++++++++++++++++++++
>>>   xen/arch/arm/include/asm/arm32/sysregs.h |   9 ++
>>>   xen/arch/arm/include/asm/cpregs.h        |   2 +
>>>   xen/arch/arm/include/asm/mpu/cpregs.h    |  27 ++++++
>>>   6 files changed, 144 insertions(+)
>>>   create mode 100644 xen/arch/arm/arm32/mpu/Makefile
>>>   create mode 100644 xen/arch/arm/arm32/mpu/head.S
>>>   create mode 100644 xen/arch/arm/include/asm/mpu/cpregs.h
>>>
>>> diff --git a/xen/arch/arm/arm32/Makefile b/xen/arch/arm/arm32/Makefile
>>> index 40a2b4803f..537969d753 100644
>>> --- a/xen/arch/arm/arm32/Makefile
>>> +++ b/xen/arch/arm/arm32/Makefile
>>> @@ -1,5 +1,6 @@
>>>   obj-y += lib/
>>>   obj-$(CONFIG_MMU) += mmu/
>>> +obj-$(CONFIG_MPU) += mpu/
>>>   
>>>   obj-$(CONFIG_EARLY_PRINTK) += debug.o
>>>   obj-y += domctl.o
>>> diff --git a/xen/arch/arm/arm32/mpu/Makefile 
>>> b/xen/arch/arm/arm32/mpu/Makefile
>>> new file mode 100644
>>> index 0000000000..3340058c08
>>> --- /dev/null
>>> +++ b/xen/arch/arm/arm32/mpu/Makefile
>>> @@ -0,0 +1 @@
>>> +obj-y += head.o
>>> diff --git a/xen/arch/arm/arm32/mpu/head.S b/xen/arch/arm/arm32/mpu/head.S
>>> new file mode 100644
>>> index 0000000000..b2c5245e51
>>> --- /dev/null
>>> +++ b/xen/arch/arm/arm32/mpu/head.S
>>> @@ -0,0 +1,104 @@
>>> +/* SPDX-License-Identifier: GPL-2.0-only */
>>> +/*
>>> + * Start-of-day code for an Armv8-R-AArch32 MPU system.
>>> + */
>>> +
>>> +#include <asm/arm32/macros.h>
>>> +#include <asm/arm32/sysregs.h>
>>> +#include <asm/cpregs.h>
>>> +#include <asm/mpu.h>
>>> +#include <asm/mpu/regions.inc>
>>> +#include <asm/page.h>
>>> +
>>> +/*
>>> + * Set up the memory attribute type tables and enable EL2 MPU and data 
>>> cache.
>>> + * If the Background region is enabled, then the MPU uses the default 
>>> memory
>>> + * map as the Background region for generating the memory
>>> + * attributes when MPU is disabled.
>>> + * Since the default memory map of the Armv8-R AArch32 architecture is
>>> + * IMPLEMENTATION DEFINED, we intend to turn off the Background region 
>>> here.
>>> + *
>>> + * Clobbers r0
>>> + */
>>> +FUNC_LOCAL(enable_mpu)
>>> +    /* Set up memory attribute type tables */
>>> +    mov_w r0, MAIR0VAL
>>> +    mcr   CP32(r0, HMAIR0)
>>> +    mov_w r0, MAIR1VAL
>>> +    mcr   CP32(r0, HMAIR1)
>>> +
>>> +    mrc   CP32(r0, HSCTLR)
>>> +    bic   r0, r0, #SCTLR_ELx_BR       /* Disable Background region */
>>> +    orr   r0, r0, #SCTLR_Axx_ELx_M    /* Enable MPU */
>>> +    orr   r0, r0, #SCTLR_Axx_ELx_C    /* Enable D-cache */
>>> +    mcr   CP32(r0, HSCTLR)
>>> +    isb
>>> +
>>> +    ret
>>> +END(enable_mpu)
>>> +
>>> +/*
>>> + * Maps the various sections of Xen (described in xen.lds.S) as different 
>>> MPU
>>> + * regions.
>>> + *
>>> + * Clobbers r0 - r5
>>> + *
>>> + */
>>> +FUNC(enable_boot_cpu_mm)
>>> +    /* Get the number of regions specified in MPUIR_EL2 */
>>> +    mrc   CP32(r5, MPUIR_EL2)
>>> +    and   r5, r5, #NUM_MPU_REGIONS_MASK
>>> +
>>> +    /* x0: region sel */
>>> +    mov   r0, #0
>>> +    /* Xen text section. */
>>> +    mov_w   r1, _stext
>>> +    mov_w   r2, _etext
>>> +    prepare_xen_region r0, r1, r2, r3, r4, r5, attr_prbar=REGION_TEXT_PRBAR
>>> +
>>> +    /* Xen read-only data section. */
>>> +    mov_w   r1, _srodata
>>> +    mov_w   r2, _erodata
>>> +    prepare_xen_region r0, r1, r2, r3, r4, r5, attr_prbar=REGION_RO_PRBAR
>>> +
>>> +    /* Xen read-only after init and data section. (RW data) */
>>> +    mov_w   r1, __ro_after_init_start
>>> +    mov_w   r2, __init_begin
>>> +    prepare_xen_region r0, r1, r2, r3, r4, r5
>>> +
>>> +    /* Xen code section. */
>>> +    mov_w   r1, __init_begin
>>> +    mov_w   r2, __init_data_begin
>>> +    prepare_xen_region r0, r1, r2, r3, r4, r5, attr_prbar=REGION_TEXT_PRBAR
>>> +
>>> +    /* Xen data and BSS section. */
>>> +    mov_w   r1, __init_data_begin
>>> +    mov_w   r2, __bss_end
>>> +    prepare_xen_region r0, r1, r2, r3, r4, r5
>>> +
>>> +#ifdef CONFIG_EARLY_PRINTK
>>> +    /* Xen early UART section. */
>>> +    mov_w   r1, CONFIG_EARLY_UART_BASE_ADDRESS
>>> +    mov_w   r2, (CONFIG_EARLY_UART_BASE_ADDRESS + CONFIG_EARLY_UART_SIZE)
>>> +    prepare_xen_region r0, r1, r2, r3, r4, r5, 
>>> attr_prbar=REGION_DEVICE_PRBAR, attr_prlar=REGION_DEVICE_PRLAR
>>> +#endif
>>> +
>>> +    b    enable_mpu
>>> +END(enable_boot_cpu_mm)
>>> +
>>> +/*
>>> + * We don't yet support secondary CPUs bring-up. Implement a dummy helper 
>>> to
>>> + * please the common code.
>>> + */
>>> +FUNC(enable_secondary_cpu_mm)
>>> +    PRINT("- SMP not enabled yet -\r\n")
>>> +1:  wfe
>>> +    b 1b
>>> +END(enable_secondary_cpu_mm)
>>> +
>>> +/*
>>> + * Local variables:
>>> + * mode: ASM
>>> + * indent-tabs-mode: nil
>>> + * End:
>>> + */
>>> diff --git a/xen/arch/arm/include/asm/arm32/sysregs.h 
>>> b/xen/arch/arm/include/asm/arm32/sysregs.h
>>> index 22871999af..8d7b95d982 100644
>>> --- a/xen/arch/arm/include/asm/arm32/sysregs.h
>>> +++ b/xen/arch/arm/include/asm/arm32/sysregs.h
>>> @@ -20,6 +20,15 @@
>>>    * uses r0 as a placeholder register. */
>>>   #define CMD_CP32(name...)      "mcr " __stringify(CP32(r0, name)) ";"
>>>   
>>> +#define REGION_TEXT_PRBAR       0x18    /* SH=11 AP=10 XN=0 */
>>> +#define REGION_RO_PRBAR         0x1D    /* SH=11 AP=10 XN=1 */
>>> +#define REGION_DATA_PRBAR       0x19    /* SH=11 AP=00 XN=1 */
>>> +#define REGION_DEVICE_PRBAR     0x11    /* SH=10 AP=00 XN=1 */
>>> +
>>> +#ifdef __ASSEMBLY__
>> In previous patch, you had empty lines surrounding the macro.
> I will put a empty line here.
>>
>>> +#define WRITE_SYSREG_ASM(v, name) mcr CP32(v, name)
>> Hmm, for arm64 you surrounded msr within "". Any reason for these style 
>> changes?
> 
> In arm64, it is
> 
> "msr " __stringify(name,) #v
> 
> One needs " " to treat this as string for concatenation. Otherwise, we 
> get an error.
> 
> In the case of arm32, we don't need __stringify().
> 
> Let me know if it makes sense.
It does. Thanks for providing the reasoning.

~Michal




 


Rackspace

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