mm: introduce execmem_alloc() and execmem_free()
authorMike Rapoport (IBM) <rppt@kernel.org>
Sun, 5 May 2024 16:06:18 +0000 (19:06 +0300)
committerLuis Chamberlain <mcgrof@kernel.org>
Tue, 14 May 2024 07:31:43 +0000 (00:31 -0700)
commit12af2b83d0b17ec8b379b721dd4a8fbcd5d791f3
treec04ce85d6f0d1c09aec941554f4623719581ce84
parentbc6b94d3ea062454ca889884db99e145efffcb93
mm: introduce execmem_alloc() and execmem_free()

module_alloc() is used everywhere as a mean to allocate memory for code.

Beside being semantically wrong, this unnecessarily ties all subsystems
that need to allocate code, such as ftrace, kprobes and BPF to modules and
puts the burden of code allocation to the modules code.

Several architectures override module_alloc() because of various
constraints where the executable memory can be located and this causes
additional obstacles for improvements of code allocation.

Start splitting code allocation from modules by introducing execmem_alloc()
and execmem_free() APIs.

Initially, execmem_alloc() is a wrapper for module_alloc() and
execmem_free() is a replacement of module_memfree() to allow updating all
call sites to use the new APIs.

Since architectures define different restrictions on placement,
permissions, alignment and other parameters for memory that can be used by
different subsystems that allocate executable memory, execmem_alloc() takes
a type argument, that will be used to identify the calling subsystem and to
allow architectures define parameters for ranges suitable for that
subsystem.

No functional changes.

Signed-off-by: Mike Rapoport (IBM) <rppt@kernel.org>
Acked-by: Masami Hiramatsu (Google) <mhiramat@kernel.org>
Acked-by: Song Liu <song@kernel.org>
Acked-by: Steven Rostedt (Google) <rostedt@goodmis.org>
Signed-off-by: Luis Chamberlain <mcgrof@kernel.org>
16 files changed:
arch/powerpc/kernel/kprobes.c
arch/s390/kernel/ftrace.c
arch/s390/kernel/kprobes.c
arch/s390/kernel/module.c
arch/sparc/net/bpf_jit_comp_32.c
arch/x86/kernel/ftrace.c
arch/x86/kernel/kprobes/core.c
include/linux/execmem.h [new file with mode: 0644]
include/linux/moduleloader.h
kernel/bpf/core.c
kernel/kprobes.c
kernel/module/Kconfig
kernel/module/main.c
mm/Kconfig
mm/Makefile
mm/execmem.c [new file with mode: 0644]