[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <433B5132A1535C98+20250415134933.531084-1-wangyuli@uniontech.com>
Date: Tue, 15 Apr 2025 21:49:33 +0800
From: WangYuli <wangyuli@...ontech.com>
To: corbet@....net,
chenhuacai@...nel.org,
kernel@...0n.name
Cc: akpm@...ux-foundation.org,
jeffxu@...omium.org,
lorenzo.stoakes@...cle.com,
Liam.Howlett@...cle.com,
kees@...nel.org,
wangyuli@...ontech.com,
hca@...ux.ibm.com,
linux-doc@...r.kernel.org,
linux-kernel@...r.kernel.org,
loongarch@...ts.linux.dev,
xry111@...111.site,
tglx@...utronix.de,
thomas.weissschuh@...utronix.de,
Jason@...c4.com,
zhanjun@...ontech.com,
niecheng1@...ontech.com,
guanwentao@...ontech.com
Subject: [PATCH] mseal sysmap: enable LoongArch
Provide support for CONFIG_MSEAL_SYSTEM_MAPPINGS on LoongArch,
covering the vdso.
Tested-by: Yuli Wang <wangyuli@...ontech.com>
Signed-off-by: Yuli Wang <wangyuli@...ontech.com>
---
Documentation/userspace-api/mseal.rst | 2 +-
arch/loongarch/Kconfig | 1 +
arch/loongarch/kernel/vdso.c | 4 +++-
3 files changed, 5 insertions(+), 2 deletions(-)
diff --git a/Documentation/userspace-api/mseal.rst b/Documentation/userspace-api/mseal.rst
index 1dabfc29be0d..ef733f69003d 100644
--- a/Documentation/userspace-api/mseal.rst
+++ b/Documentation/userspace-api/mseal.rst
@@ -144,7 +144,7 @@ Use cases
architecture.
The following architectures currently support this feature: x86-64, arm64,
- and s390.
+ loongarch and s390.
WARNING: This feature breaks programs which rely on relocating
or unmapping system mappings. Known broken software at the time
diff --git a/arch/loongarch/Kconfig b/arch/loongarch/Kconfig
index 067c0b994648..54ed5b59a690 100644
--- a/arch/loongarch/Kconfig
+++ b/arch/loongarch/Kconfig
@@ -69,6 +69,7 @@ config LOONGARCH
select ARCH_SUPPORTS_INT128 if CC_HAS_INT128
select ARCH_SUPPORTS_LTO_CLANG
select ARCH_SUPPORTS_LTO_CLANG_THIN
+ select ARCH_SUPPORTS_MSEAL_SYSTEM_MAPPINGS
select ARCH_SUPPORTS_NUMA_BALANCING
select ARCH_SUPPORTS_RT
select ARCH_USE_BUILTIN_BSWAP
diff --git a/arch/loongarch/kernel/vdso.c b/arch/loongarch/kernel/vdso.c
index 10cf1608c7b3..7b888d9085a0 100644
--- a/arch/loongarch/kernel/vdso.c
+++ b/arch/loongarch/kernel/vdso.c
@@ -105,7 +105,9 @@ int arch_setup_additional_pages(struct linux_binprm *bprm, int uses_interp)
vdso_addr = data_addr + VVAR_SIZE;
vma = _install_special_mapping(mm, vdso_addr, info->size,
- VM_READ | VM_EXEC | VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC,
+ VM_READ | VM_EXEC |
+ VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC |
+ VM_SEALED_SYSMAP,
&info->code_mapping);
if (IS_ERR(vma)) {
ret = PTR_ERR(vma);
--
2.49.0
Powered by blists - more mailing lists