anon_inode_test.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. // SPDX-License-Identifier: GPL-2.0
  2. #define _GNU_SOURCE
  3. #define __SANE_USERSPACE_TYPES__
  4. #include <fcntl.h>
  5. #include <stdio.h>
  6. #include <sys/stat.h>
  7. #include "kselftest_harness.h"
  8. #include "wrappers.h"
  9. TEST(anon_inode_no_chown)
  10. {
  11. int fd_context;
  12. fd_context = sys_fsopen("tmpfs", 0);
  13. ASSERT_GE(fd_context, 0);
  14. ASSERT_LT(fchown(fd_context, 1234, 5678), 0);
  15. ASSERT_EQ(errno, EOPNOTSUPP);
  16. EXPECT_EQ(close(fd_context), 0);
  17. }
  18. TEST(anon_inode_no_chmod)
  19. {
  20. int fd_context;
  21. fd_context = sys_fsopen("tmpfs", 0);
  22. ASSERT_GE(fd_context, 0);
  23. ASSERT_LT(fchmod(fd_context, 0777), 0);
  24. ASSERT_EQ(errno, EOPNOTSUPP);
  25. EXPECT_EQ(close(fd_context), 0);
  26. }
  27. TEST(anon_inode_no_exec)
  28. {
  29. int fd_context;
  30. fd_context = sys_fsopen("tmpfs", 0);
  31. ASSERT_GE(fd_context, 0);
  32. char *const empty_argv[] = {NULL};
  33. char *const empty_envp[] = {NULL};
  34. ASSERT_LT(execveat(fd_context, "", empty_argv, empty_envp, AT_EMPTY_PATH), 0);
  35. ASSERT_EQ(errno, EACCES);
  36. EXPECT_EQ(close(fd_context), 0);
  37. }
  38. TEST(anon_inode_no_open)
  39. {
  40. int fd_context;
  41. fd_context = sys_fsopen("tmpfs", 0);
  42. ASSERT_GE(fd_context, 0);
  43. ASSERT_GE(dup2(fd_context, 500), 0);
  44. ASSERT_EQ(close(fd_context), 0);
  45. fd_context = 500;
  46. ASSERT_LT(open("/proc/self/fd/500", 0), 0);
  47. ASSERT_EQ(errno, ENXIO);
  48. EXPECT_EQ(close(fd_context), 0);
  49. }
  50. TEST_HARNESS_MAIN