// https://syzkaller.appspot.com/bug?id=8e030beda49b8e549cfeb17ed369414ed27331e6 // autogenerated by syzkaller (https://github.com/google/syzkaller) #define _GNU_SOURCE #include #include #include #include #include #include #include #include uint64_t r[1] = {0xffffffffffffffff}; int main(void) { syscall(__NR_mmap, /*addr=*/0x1ffffffff000ul, /*len=*/0x1000ul, /*prot=*/0ul, /*flags=MAP_FIXED|MAP_ANONYMOUS|MAP_PRIVATE*/ 0x32ul, /*fd=*/(intptr_t)-1, /*offset=*/0ul); syscall(__NR_mmap, /*addr=*/0x200000000000ul, /*len=*/0x1000000ul, /*prot=PROT_WRITE|PROT_READ|PROT_EXEC*/ 7ul, /*flags=MAP_FIXED|MAP_ANONYMOUS|MAP_PRIVATE*/ 0x32ul, /*fd=*/(intptr_t)-1, /*offset=*/0ul); syscall(__NR_mmap, /*addr=*/0x200001000000ul, /*len=*/0x1000ul, /*prot=*/0ul, /*flags=MAP_FIXED|MAP_ANONYMOUS|MAP_PRIVATE*/ 0x32ul, /*fd=*/(intptr_t)-1, /*offset=*/0ul); const char* reason; (void)reason; intptr_t res = 0; if (write(1, "executing program\n", sizeof("executing program\n") - 1)) { } // mmap$auto arguments: [ // addr: intptr = 0x0 (8 bytes) // len: intptr = 0xe983 (8 bytes) // prot: intptr = 0xdf (8 bytes) // flags: intptr = 0xeb1 (8 bytes) // fd: fd (resource) // off: intptr = 0x8000 (8 bytes) // ] syscall(__NR_mmap, /*addr=*/0ul, /*len=*/0xe983ul, /*prot=*/0xdful, /*flags=*/0xeb1ul, /*fd=*/0x401, /*off=*/0x8000ul); // openat$auto_proc_pid_maps_operations_internal arguments: [ // fd: const = 0xffffffffffffff9c (8 bytes) // file: ptr[in, buffer] { // buffer: {2f 70 72 6f 63 2f 74 68 72 65 61 64 2d 73 65 6c 66 2f 6d 61 // 70 73 00} (length 0x17) // } // flags: open_flags = 0x80101 (4 bytes) // mode: const = 0x0 (2 bytes) // ] // returns fd_proc_pid_maps_operations_internal memcpy((void*)0x200000000000, "/proc/thread-self/maps\000", 23); res = syscall(__NR_openat, /*fd=*/0xffffffffffffff9cul, /*file=*/0x200000000000ul, /*flags=O_NOCTTY|O_CLOEXEC|O_WRONLY*/ 0x80101, /*mode=*/0); if (res != -1) r[0] = res; // ioctl$auto_PROCMAP_QUERY arguments: [ // fd: fd_proc_pid_maps_operations_internal (resource) // cmd: const = 0xc0686611 (4 bytes) // arg: ptr[inout, procmap_query$auto] { // procmap_query$auto { // size: int64 = 0x7f (8 bytes) // query_flags: int64 = 0x3b (8 bytes) // query_addr: int64 = 0x9 (8 bytes) // vma_start: int64 = 0x81 (8 bytes) // vma_end: int64 = 0x6 (8 bytes) // vma_flags: int64 = 0x8001 (8 bytes) // vma_page_size: int64 = 0x7d6 (8 bytes) // vma_offset: int64 = 0x9a (8 bytes) // inode: int64 = 0x1 (8 bytes) // dev_major: int32 = 0xbfaf (4 bytes) // dev_minor: int32 = 0x7 (4 bytes) // vma_name_size: int32 = 0x1 (4 bytes) // build_id_size: int32 = 0x10d9b (4 bytes) // vma_name_addr: int64 = 0x8000000000 (8 bytes) // build_id_addr: int64 = 0x2 (8 bytes) // } // } // ] *(uint64_t*)0x200000000180 = 0x7f; *(uint64_t*)0x200000000188 = 0x3b; *(uint64_t*)0x200000000190 = 9; *(uint64_t*)0x200000000198 = 0x81; *(uint64_t*)0x2000000001a0 = 6; *(uint64_t*)0x2000000001a8 = 0x8001; *(uint64_t*)0x2000000001b0 = 0x7d6; *(uint64_t*)0x2000000001b8 = 0x9a; *(uint64_t*)0x2000000001c0 = 1; *(uint32_t*)0x2000000001c8 = 0xbfaf; *(uint32_t*)0x2000000001cc = 7; *(uint32_t*)0x2000000001d0 = 1; *(uint32_t*)0x2000000001d4 = 0x10d9b; *(uint64_t*)0x2000000001d8 = 0x8000000000; *(uint64_t*)0x2000000001e0 = 2; syscall(__NR_ioctl, /*fd=*/r[0], /*cmd=*/0xc0686611, /*arg=*/0x200000000180ul); return 0; }