pidfd_setattr_test.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. // SPDX-License-Identifier: GPL-2.0
  2. #define _GNU_SOURCE
  3. #include <errno.h>
  4. #include <fcntl.h>
  5. #include <limits.h>
  6. #include <linux/types.h>
  7. #include <poll.h>
  8. #include <pthread.h>
  9. #include <sched.h>
  10. #include <signal.h>
  11. #include <stdio.h>
  12. #include <stdlib.h>
  13. #include <string.h>
  14. #include <syscall.h>
  15. #include <sys/prctl.h>
  16. #include <sys/wait.h>
  17. #include <unistd.h>
  18. #include <sys/socket.h>
  19. #include <linux/kcmp.h>
  20. #include <sys/stat.h>
  21. #include <sys/xattr.h>
  22. #include "pidfd.h"
  23. #include "kselftest_harness.h"
  24. FIXTURE(pidfs_setattr)
  25. {
  26. pid_t child_pid;
  27. int child_pidfd;
  28. };
  29. FIXTURE_SETUP(pidfs_setattr)
  30. {
  31. self->child_pid = create_child(&self->child_pidfd, CLONE_NEWUSER | CLONE_NEWPID);
  32. EXPECT_GE(self->child_pid, 0);
  33. if (self->child_pid == 0)
  34. _exit(EXIT_SUCCESS);
  35. }
  36. FIXTURE_TEARDOWN(pidfs_setattr)
  37. {
  38. sys_waitid(P_PID, self->child_pid, NULL, WEXITED);
  39. EXPECT_EQ(close(self->child_pidfd), 0);
  40. }
  41. TEST_F(pidfs_setattr, no_chown)
  42. {
  43. ASSERT_LT(fchown(self->child_pidfd, 1234, 5678), 0);
  44. ASSERT_EQ(errno, EOPNOTSUPP);
  45. }
  46. TEST_F(pidfs_setattr, no_chmod)
  47. {
  48. ASSERT_LT(fchmod(self->child_pidfd, 0777), 0);
  49. ASSERT_EQ(errno, EOPNOTSUPP);
  50. }
  51. TEST_F(pidfs_setattr, no_exec)
  52. {
  53. char *const argv[] = { NULL };
  54. char *const envp[] = { NULL };
  55. ASSERT_LT(execveat(self->child_pidfd, "", argv, envp, AT_EMPTY_PATH), 0);
  56. ASSERT_EQ(errno, EACCES);
  57. }
  58. TEST_HARNESS_MAIN