]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
riscv: shstk: use the new common vm_mmap_shadow_stack() helper
authorCatalin Marinas <catalin.marinas@arm.com>
Wed, 25 Feb 2026 16:14:00 +0000 (16:14 +0000)
committerAndrew Morton <akpm@linux-foundation.org>
Sun, 5 Apr 2026 20:53:05 +0000 (13:53 -0700)
Replace part of the allocate_shadow_stack() content with a call to
vm_mmap_shadow_stack().  There is no functional change.

Link: https://lkml.kernel.org/r/20260225161404.3157851-4-catalin.marinas@arm.com
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
Tested-by: Deepak Gupta <debug@rivosinc.com>
Reviewed-by: David Hildenbrand (Arm) <david@kernel.org>
Cc: Paul Walmsley <pjw@kernel.org>
Cc: Palmer Dabbelt <palmer@dabbelt.com>
Cc: Albert Ou <aou@eecs.berkeley.edu>
Cc: Alexandre Ghiti <alex@ghiti.fr>
Cc: "Borislav Petkov (AMD)" <bp@alien8.de>
Cc: Dave Hansen <dave.hansen@linux.intel.com>
Cc: "Edgecombe, Rick P" <rick.p.edgecombe@intel.com>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: "Liam R. Howlett" <Liam.Howlett@oracle.com>
Cc: Lorenzo Stoakes <lorenzo.stoakes@oracle.com>
Cc: Mark Brown <broonie@kernel.org>
Cc: Michal Hocko <mhocko@suse.com>
Cc: Mike Rapoport <rppt@kernel.org>
Cc: Suren Baghdasaryan <surenb@google.com>
Cc: Thomas Gleixner <tglx@kernel.org>
Cc: Vlastimil Babka <vbabka@suse.cz>
Cc: Will Deacon <will@kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
arch/riscv/kernel/usercfi.c

index 1adba746f164e52d657d28c7a24a023f7e5c74d3..7e57f54dc5b21df5ab23d170f28b21293159431e 100644 (file)
@@ -230,17 +230,7 @@ int restore_user_shstk(struct task_struct *tsk, unsigned long shstk_ptr)
 static unsigned long allocate_shadow_stack(unsigned long addr, unsigned long size,
                                           unsigned long token_offset, bool set_tok)
 {
-       int flags = MAP_ANONYMOUS | MAP_PRIVATE;
-       struct mm_struct *mm = current->mm;
-       unsigned long populate;
-
-       if (addr)
-               flags |= MAP_FIXED_NOREPLACE;
-
-       mmap_write_lock(mm);
-       addr = do_mmap(NULL, addr, size, PROT_READ, flags,
-                      VM_SHADOW_STACK | VM_WRITE, 0, &populate, NULL);
-       mmap_write_unlock(mm);
+       addr = vm_mmap_shadow_stack(addr, size, 0);
 
        if (!set_tok || IS_ERR_VALUE(addr))
                goto out;