FAULT_INJECTION: forcing a failure. name fail_page_alloc, interval 1, probability 0, space 0, times 1 CPU: 0 UID: 0 PID: 5320 Comm: syz.0.0 Not tainted syzkaller #0 PREEMPT(full) Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS 1.16.3-debian-1.16.3-2 04/01/2014 Call Trace: dump_stack_lvl+0xe8/0x150 lib/dump_stack.c:120 fail_dump lib/fault-inject.c:73 [inline] should_fail_ex+0x412/0x560 lib/fault-inject.c:174 prepare_alloc_pages+0x22a/0x650 mm/page_alloc.c:5025 __alloc_frozen_pages_noprof+0x12f/0x380 mm/page_alloc.c:5239 alloc_pages_mpol+0x232/0x4a0 mm/mempolicy.c:2484 alloc_frozen_pages_noprof mm/mempolicy.c:2555 [inline] alloc_pages_noprof+0xa8/0x190 mm/mempolicy.c:2575 pagetable_alloc_noprof include/linux/mm.h:3404 [inline] __pte_alloc_one_noprof include/asm-generic/pgalloc.h:76 [inline] pte_alloc_one+0x23/0x370 arch/x86/mm/pgtable.c:18 __pte_alloc+0x25/0x430 mm/memory.c:466 remap_pte_range mm/memory.c:2875 [inline] remap_pmd_range mm/memory.c:2908 [inline] remap_pud_range mm/memory.c:2930 [inline] remap_p4d_range mm/memory.c:2952 [inline] remap_pfn_range_internal mm/memory.c:2999 [inline] remap_pfn_range_notrack mm/memory.c:3015 [inline] remap_pfn_range_track mm/memory.c:3085 [inline] do_remap_pfn_range+0xbe6/0x1250 mm/memory.c:3098 map_range+0x199/0x230 kernel/events/core.c:7210 perf_mmap+0x3f9/0x4b0 kernel/events/core.c:7486 vfs_mmap include/linux/fs.h:2070 [inline] mmap_file mm/internal.h:167 [inline] __mmap_new_file_vma mm/vma.c:2468 [inline] __mmap_new_vma mm/vma.c:2532 [inline] __mmap_region mm/vma.c:2759 [inline] mmap_region+0x18fe/0x2240 mm/vma.c:2837 do_mmap+0xc39/0x10c0 mm/mmap.c:559 vm_mmap_pgoff+0x2c9/0x4f0 mm/util.c:581 ksys_mmap_pgoff+0x51e/0x760 mm/mmap.c:605 do_syscall_x64 arch/x86/entry/syscall_64.c:63 [inline] do_syscall_64+0x14d/0xf80 arch/x86/entry/syscall_64.c:94 entry_SYSCALL_64_after_hwframe+0x77/0x7f RIP: 0033:0x7f59be79c799 Code: ff c3 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 44 00 00 48 89 f8 48 89 f7 48 89 d6 48 89 ca 4d 89 c2 4d 89 c8 4c 8b 4c 24 08 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 c7 c1 e8 ff ff ff f7 d8 64 89 01 48 RSP: 002b:00007f59babf4fe8 EFLAGS: 00000246 ORIG_RAX: 0000000000000009 RAX: ffffffffffffffda RBX: 00007f59bea15fa0 RCX: 00007f59be79c799 RDX: 0000000001000008 RSI: 0000000000002000 RDI: 0000200000ffe000 RBP: 00007f59babf5050 R08: 0000000000000003 R09: 0000000000000000 R10: 0000000000000013 R11: 0000000000000246 R12: 0000000000000002 R13: 00007f59bea16038 R14: 00007f59bea15fa0 R15: 00007ffdf6b3ed98 ============================================ WARNING: possible recursive locking detected syzkaller #0 Not tainted -------------------------------------------- syz.0.0/5320 is trying to acquire lock: ffff888012f3c9e0 (&event->mmap_mutex){+.+.}-{4:4}, at: refcount_dec_and_mutex_lock+0x30/0xa0 lib/refcount.c:118 but task is already holding lock: ffff888012f3c9e0 (&event->mmap_mutex){+.+.}-{4:4}, at: class_mutex_constructor include/linux/mutex.h:253 [inline] ffff888012f3c9e0 (&event->mmap_mutex){+.+.}-{4:4}, at: perf_mmap+0x1bb/0x4b0 kernel/events/core.c:7453 other info that might help us debug this: Possible unsafe locking scenario: CPU0 ---- lock(&event->mmap_mutex); lock(&event->mmap_mutex); *** DEADLOCK *** May be due to missing lock nesting notation 2 locks held by syz.0.0/5320: #0: ffff888011c2c080 (&mm->mmap_lock){++++}-{4:4}, at: mmap_write_lock_killable include/linux/mmap_lock.h:554 [inline] #0: ffff888011c2c080 (&mm->mmap_lock){++++}-{4:4}, at: vm_mmap_pgoff+0x234/0x4f0 mm/util.c:579 #1: ffff888012f3c9e0 (&event->mmap_mutex){+.+.}-{4:4}, at: class_mutex_constructor include/linux/mutex.h:253 [inline] #1: ffff888012f3c9e0 (&event->mmap_mutex){+.+.}-{4:4}, at: perf_mmap+0x1bb/0x4b0 kernel/events/core.c:7453 stack backtrace: CPU: 0 UID: 0 PID: 5320 Comm: syz.0.0 Not tainted syzkaller #0 PREEMPT(full) Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS 1.16.3-debian-1.16.3-2 04/01/2014 Call Trace: dump_stack_lvl+0xe8/0x150 lib/dump_stack.c:120 print_deadlock_bug+0x279/0x290 kernel/locking/lockdep.c:3041 check_deadlock kernel/locking/lockdep.c:3093 [inline] validate_chain kernel/locking/lockdep.c:3895 [inline] __lock_acquire+0x253f/0x2cf0 kernel/locking/lockdep.c:5237 lock_acquire+0xf0/0x2e0 kernel/locking/lockdep.c:5868 __mutex_lock_common kernel/locking/mutex.c:614 [inline] __mutex_lock+0x19f/0x1300 kernel/locking/mutex.c:776 refcount_dec_and_mutex_lock+0x30/0xa0 lib/refcount.c:118 perf_mmap_close+0x953/0xf90 kernel/events/core.c:7064 perf_mmap+0x418/0x4b0 kernel/events/core.c:7488 vfs_mmap include/linux/fs.h:2070 [inline] mmap_file mm/internal.h:167 [inline] __mmap_new_file_vma mm/vma.c:2468 [inline] __mmap_new_vma mm/vma.c:2532 [inline] __mmap_region mm/vma.c:2759 [inline] mmap_region+0x18fe/0x2240 mm/vma.c:2837 do_mmap+0xc39/0x10c0 mm/mmap.c:559 vm_mmap_pgoff+0x2c9/0x4f0 mm/util.c:581 ksys_mmap_pgoff+0x51e/0x760 mm/mmap.c:605 do_syscall_x64 arch/x86/entry/syscall_64.c:63 [inline] do_syscall_64+0x14d/0xf80 arch/x86/entry/syscall_64.c:94 entry_SYSCALL_64_after_hwframe+0x77/0x7f RIP: 0033:0x7f59be79c799 Code: ff c3 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 44 00 00 48 89 f8 48 89 f7 48 89 d6 48 89 ca 4d 89 c2 4d 89 c8 4c 8b 4c 24 08 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 c7 c1 e8 ff ff ff f7 d8 64 89 01 48 RSP: 002b:00007f59babf4fe8 EFLAGS: 00000246 ORIG_RAX: 0000000000000009 RAX: ffffffffffffffda RBX: 00007f59bea15fa0 RCX: 00007f59be79c799 RDX: 0000000001000008 RSI: 0000000000002000 RDI: 0000200000ffe000 RBP: 00007f59babf5050 R08: 0000000000000003 R09: 0000000000000000 R10: 0000000000000013 R11: 0000000000000246 R12: 0000000000000002 R13: 00007f59bea16038 R14: 00007f59bea15fa0 R15: 00007ffdf6b3ed98