From c2770e51b402d25fa1bdc9b9e3a12d23bbc11935 Mon Sep 17 00:00:00 2001 From: Andrew Cooper Date: Thu, 28 Apr 2022 18:00:41 +0100 Subject: [PATCH] x86/mm: Move base_disallow_mask into __ro_after_init base_disallow_mask is calculated once in arch_init_memory() and doesn't change thereafter. Write-protect it at runtime. Signed-off-by: Andrew Cooper Reviewed-by: Jan Beulich --- xen/arch/x86/mm.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/xen/arch/x86/mm.c b/xen/arch/x86/mm.c index 0ecea0f707..95795567f2 100644 --- a/xen/arch/x86/mm.c +++ b/xen/arch/x86/mm.c @@ -150,7 +150,8 @@ bool __read_mostly machine_to_phys_mapping_valid; struct rangeset *__read_mostly mmio_ro_ranges; -static uint32_t base_disallow_mask; +static uint32_t __ro_after_init base_disallow_mask; + /* Global bit is allowed to be set on L1 PTEs. Intended for user mappings. */ #define L1_DISALLOW_MASK ((base_disallow_mask | _PAGE_GNTTAB) & ~_PAGE_GLOBAL) -- 2.39.5