fc2a85cb02ef.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. #include "../config-host.h"
  2. /* SPDX-License-Identifier: MIT */
  3. // https://syzkaller.appspot.com/bug?id=1f2ecd7a23dba87e5ca3505ec44514a462cfe8c0
  4. // autogenerated by syzkaller (https://github.com/google/syzkaller)
  5. #include <errno.h>
  6. #include <fcntl.h>
  7. #include <stdarg.h>
  8. #include <stdbool.h>
  9. #include <stdint.h>
  10. #include <stdio.h>
  11. #include <stdlib.h>
  12. #include <string.h>
  13. #include <sys/socket.h>
  14. #include <sys/types.h>
  15. #include <sys/mman.h>
  16. #include <unistd.h>
  17. #include "liburing.h"
  18. #include "helpers.h"
  19. #include "../src/syscall.h"
  20. static bool write_file(const char* file, const char* what, ...)
  21. {
  22. char buf[1024];
  23. va_list args;
  24. va_start(args, what);
  25. vsnprintf(buf, sizeof(buf), what, args);
  26. va_end(args);
  27. buf[sizeof(buf) - 1] = 0;
  28. int len = strlen(buf);
  29. int fd = open(file, O_WRONLY | O_CLOEXEC);
  30. if (fd == -1)
  31. return false;
  32. if (write(fd, buf, len) != len) {
  33. int err = errno;
  34. close(fd);
  35. errno = err;
  36. return false;
  37. }
  38. close(fd);
  39. return true;
  40. }
  41. static int inject_fault(int nth)
  42. {
  43. int fd;
  44. fd = open("/proc/thread-self/fail-nth", O_RDWR);
  45. if (fd == -1)
  46. exit(1);
  47. char buf[16];
  48. sprintf(buf, "%d", nth + 1);
  49. if (write(fd, buf, strlen(buf)) != (ssize_t)strlen(buf))
  50. exit(1);
  51. return fd;
  52. }
  53. static int setup_fault(void)
  54. {
  55. static struct {
  56. const char* file;
  57. const char* val;
  58. bool fatal;
  59. } files[] = {
  60. {"/sys/kernel/debug/failslab/ignore-gfp-wait", "N", true},
  61. {"/sys/kernel/debug/failslab/verbose", "0", false},
  62. {"/sys/kernel/debug/fail_futex/ignore-private", "N", false},
  63. {"/sys/kernel/debug/fail_page_alloc/verbose", "0", false},
  64. {"/sys/kernel/debug/fail_page_alloc/ignore-gfp-highmem", "N", false},
  65. {"/sys/kernel/debug/fail_page_alloc/ignore-gfp-wait", "N", false},
  66. {"/sys/kernel/debug/fail_page_alloc/min-order", "0", false},
  67. };
  68. unsigned i;
  69. for (i = 0; i < sizeof(files) / sizeof(files[0]); i++) {
  70. if (!write_file(files[i].file, files[i].val)) {
  71. if (files[i].fatal)
  72. return 1;
  73. }
  74. }
  75. return 0;
  76. }
  77. static uint64_t r[2] = {0xffffffffffffffff, 0xffffffffffffffff};
  78. int main(int argc, char *argv[])
  79. {
  80. if (argc > 1)
  81. return T_EXIT_SKIP;
  82. mmap((void *) 0x20000000ul, 0x1000000ul, 3ul, MAP_ANON|MAP_PRIVATE, -1, 0);
  83. if (setup_fault()) {
  84. printf("Test needs failslab/fail_futex/fail_page_alloc enabled, skipped\n");
  85. return T_EXIT_SKIP;
  86. }
  87. intptr_t res = 0;
  88. *(uint32_t*)0x20000000 = 0;
  89. *(uint32_t*)0x20000004 = 0;
  90. *(uint32_t*)0x20000008 = 0;
  91. *(uint32_t*)0x2000000c = 0;
  92. *(uint32_t*)0x20000010 = 0;
  93. *(uint32_t*)0x20000014 = 0;
  94. *(uint32_t*)0x20000018 = 0;
  95. *(uint32_t*)0x2000001c = 0;
  96. *(uint32_t*)0x20000020 = 0;
  97. *(uint32_t*)0x20000024 = 0;
  98. *(uint32_t*)0x20000028 = 0;
  99. *(uint32_t*)0x2000002c = 0;
  100. *(uint32_t*)0x20000030 = 0;
  101. *(uint32_t*)0x20000034 = 0;
  102. *(uint32_t*)0x20000038 = 0;
  103. *(uint32_t*)0x2000003c = 0;
  104. *(uint32_t*)0x20000040 = 0;
  105. *(uint32_t*)0x20000044 = 0;
  106. *(uint64_t*)0x20000048 = 0;
  107. *(uint32_t*)0x20000050 = 0;
  108. *(uint32_t*)0x20000054 = 0;
  109. *(uint32_t*)0x20000058 = 0;
  110. *(uint32_t*)0x2000005c = 0;
  111. *(uint32_t*)0x20000060 = 0;
  112. *(uint32_t*)0x20000064 = 0;
  113. *(uint32_t*)0x20000068 = 0;
  114. *(uint32_t*)0x2000006c = 0;
  115. *(uint64_t*)0x20000070 = 0;
  116. res = __sys_io_uring_setup(0x6a6, (struct io_uring_params *) 0x20000000ul);
  117. if (res != -1)
  118. r[0] = res;
  119. res = socket(0x11ul, 2ul, 0x300ul);
  120. if (res != -1)
  121. r[1] = res;
  122. *(uint32_t*)0x20000080 = r[1];
  123. inject_fault(1);
  124. __sys_io_uring_register(r[0], 2ul, (const void *) 0x20000080ul, 1ul);
  125. return T_EXIT_PASS;
  126. }