]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
x86/execmem: fix ROX cache usage in Xen PV guests
authorJuergen Gross <jgross@suse.com>
Fri, 3 Jan 2025 06:56:31 +0000 (07:56 +0100)
committerAndrew Morton <akpm@linux-foundation.org>
Mon, 13 Jan 2025 03:03:35 +0000 (19:03 -0800)
The recently introduced ROX cache for modules is assuming large page
support in 64-bit mode without testing the related feature bit.  This
results in breakage when running as a Xen PV guest, as in this mode large
pages are not supported.

Fix that by testing the X86_FEATURE_PSE capability when deciding whether
to enable the ROX cache.

Link: https://lkml.kernel.org/r/20250103065631.26459-1-jgross@suse.com
Fixes: 2e45474ab14f ("execmem: add support for cache of large ROX pages")
Signed-off-by: Juergen Gross <jgross@suse.com>
Reported-by: Marek Marczykowski-Górecki <marmarek@invisiblethingslab.com>
Tested-by: Marek Marczykowski-Górecki <marmarek@invisiblethingslab.com>
Cc: Luis Chamberlain <mcgrof@kernel.org>
Cc: Andy Lutomirski <luto@kernel.org>
Cc: Dave Hansen <dave.hansen@linux.intel.com>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Mike Rapoport (Microsoft) <rppt@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
arch/x86/mm/init.c

index c6d29f283001aee26d98c0b014f284329b605fe6..62aa4d66a032d59191e79d34fc0cdaa4f32f88db 100644 (file)
@@ -1080,7 +1080,8 @@ struct execmem_info __init *execmem_arch_setup(void)
 
        start = MODULES_VADDR + offset;
 
-       if (IS_ENABLED(CONFIG_ARCH_HAS_EXECMEM_ROX)) {
+       if (IS_ENABLED(CONFIG_ARCH_HAS_EXECMEM_ROX) &&
+           cpu_feature_enabled(X86_FEATURE_PSE)) {
                pgprot = PAGE_KERNEL_ROX;
                flags = EXECMEM_KASAN_SHADOW | EXECMEM_ROX_CACHE;
        } else {