]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
selftests/memfd: run sysctl tests when PID namespace support is enabled
authorIsaac J. Manjarres <isaacmanjarres@google.com>
Thu, 5 Dec 2024 19:29:41 +0000 (11:29 -0800)
committerAndrew Morton <akpm@linux-foundation.org>
Thu, 19 Dec 2024 03:04:41 +0000 (19:04 -0800)
The sysctl tests for vm.memfd_noexec rely on the kernel to support PID
namespaces (i.e.  the kernel is built with CONFIG_PID_NS=y).  If the
kernel the test runs on does not support PID namespaces, the first sysctl
test will fail when attempting to spawn a new thread in a new PID
namespace, abort the test, preventing the remaining tests from being run.

This is not desirable, as not all kernels need PID namespaces, but can
still use the other features provided by memfd.  Therefore, only run the
sysctl tests if the kernel supports PID namespaces.  Otherwise, skip those
tests and emit an informative message to let the user know why the sysctl
tests are not being run.

Link: https://lkml.kernel.org/r/20241205192943.3228757-1-isaacmanjarres@google.com
Fixes: 11f75a01448f ("selftests/memfd: add tests for MFD_NOEXEC_SEAL MFD_EXEC")
Signed-off-by: Isaac J. Manjarres <isaacmanjarres@google.com>
Reviewed-by: Jeff Xu <jeffxu@google.com>
Cc: Suren Baghdasaryan <surenb@google.com>
Cc: Kalesh Singh <kaleshsingh@google.com>
Cc: <stable@vger.kernel.org> [6.6+]
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
tools/testing/selftests/memfd/memfd_test.c

index 95af2d78fd318ce1e76334ddc7afb4e6e46dc45d..0a0b555160280848d615e4dc2ea5d4c66f102785 100644 (file)
@@ -9,6 +9,7 @@
 #include <fcntl.h>
 #include <linux/memfd.h>
 #include <sched.h>
+#include <stdbool.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <signal.h>
@@ -1557,6 +1558,11 @@ static void test_share_fork(char *banner, char *b_suffix)
        close(fd);
 }
 
+static bool pid_ns_supported(void)
+{
+       return access("/proc/self/ns/pid", F_OK) == 0;
+}
+
 int main(int argc, char **argv)
 {
        pid_t pid;
@@ -1591,8 +1597,12 @@ int main(int argc, char **argv)
        test_seal_grow();
        test_seal_resize();
 
-       test_sysctl_simple();
-       test_sysctl_nested();
+       if (pid_ns_supported()) {
+               test_sysctl_simple();
+               test_sysctl_nested();
+       } else {
+               printf("PID namespaces are not supported; skipping sysctl tests\n");
+       }
 
        test_share_dup("SHARE-DUP", "");
        test_share_mmap("SHARE-MMAP", "");