// https://syzkaller.appspot.com/bug?id=52304f8f4b4e28508d52875f95df5e30417eff1b // autogenerated by syzkaller (http://github.com/google/syzkaller) #define _GNU_SOURCE #include #include #include #include #include static void execute_one(); extern unsigned long long procid; void loop() { while (1) { execute_one(); } } uint64_t r[1] = {0xffffffffffffffff}; unsigned long long procid; void execute_one() { long res = 0; memcpy((void*)0x20000ff4, "/dev/ashmem", 12); res = syscall(__NR_openat, 0xffffffffffffff9c, 0x20000ff4, 0, 0); if (res != -1) r[0] = res; syscall(__NR_ioctl, r[0], 0x40087703, 0x7ffffffffffffc00); syscall(__NR_mmap, 0x20447000, 0x4000, 0, 0x13, r[0], 0); } int main() { syscall(__NR_mmap, 0x20000000, 0x1000000, 3, 0x32, -1, 0); for (procid = 0; procid < 8; procid++) { if (fork() == 0) { for (;;) { loop(); } } } sleep(1000000); return 0; }