====================================================== [ INFO: possible circular locking dependency detected ] 4.4.118-g5f7f76a #24 Not tainted ------------------------------------------------------- syz-executor4/5488 is trying to acquire lock: (&mm->mmap_sem){++++++}, at: [] __might_fault+0xe4/0x1d0 mm/memory.c:3809 but task is already holding lock: (ashmem_mutex){+.+.+.}, at: [] ashmem_pin_unpin drivers/staging/android/ashmem.c:701 [inline] (ashmem_mutex){+.+.+.}, at: [] ashmem_ioctl+0x367/0xfa0 drivers/staging/android/ashmem.c:778 which lock already depends on the new lock. the existing dependency chain (in reverse order) is: : [] lock_acquire+0x15e/0x460 kernel/locking/lockdep.c:3592 [] __mutex_lock_common kernel/locking/mutex.c:521 [inline] [] mutex_lock_nested+0xbb/0x850 kernel/locking/mutex.c:621 [] ashmem_mmap+0x53/0x400 drivers/staging/android/ashmem.c:366 [] mmap_region+0x94f/0x1250 mm/mmap.c:1664 [] do_mmap+0x4fd/0x9d0 mm/mmap.c:1441 [] do_mmap_pgoff include/linux/mm.h:1915 [inline] [] vm_mmap_pgoff+0x16e/0x1c0 mm/util.c:296 [] SYSC_mmap_pgoff mm/mmap.c:1491 [inline] [] SyS_mmap_pgoff+0x33f/0x560 mm/mmap.c:1449 [] SYSC_mmap arch/x86/kernel/sys_x86_64.c:95 [inline] [] SyS_mmap+0x16/0x20 arch/x86/kernel/sys_x86_64.c:86 [] entry_SYSCALL_64_fastpath+0x1c/0x98 [] check_prev_add kernel/locking/lockdep.c:1853 [inline] [] check_prevs_add kernel/locking/lockdep.c:1958 [inline] [] validate_chain kernel/locking/lockdep.c:2144 [inline] [] __lock_acquire+0x371f/0x4b50 kernel/locking/lockdep.c:3213 [] lock_acquire+0x15e/0x460 kernel/locking/lockdep.c:3592 [] __might_fault+0x14a/0x1d0 mm/memory.c:3810 [] copy_from_user arch/x86/include/asm/uaccess.h:724 [inline] [] ashmem_pin_unpin drivers/staging/android/ashmem.c:706 [inline] [] ashmem_ioctl+0x3b4/0xfa0 drivers/staging/android/ashmem.c:778 [] vfs_ioctl fs/ioctl.c:43 [inline] [] do_vfs_ioctl+0x7aa/0xee0 fs/ioctl.c:607 [] SYSC_ioctl fs/ioctl.c:622 [inline] [] SyS_ioctl+0x8f/0xc0 fs/ioctl.c:613 [] entry_SYSCALL_64_fastpath+0x1c/0x98 other info that might help us debug this: Possible unsafe locking scenario: CPU0 CPU1 ---- ---- lock(ashmem_mutex); lock(&mm->mmap_sem); lock(ashmem_mutex); lock(&mm->mmap_sem); *** DEADLOCK *** 1 lock held by syz-executor4/5488: #0: (ashmem_mutex){+.+.+.}, at: [] ashmem_pin_unpin drivers/staging/android/ashmem.c:701 [inline] #0: (ashmem_mutex){+.+.+.}, at: [] ashmem_ioctl+0x367/0xfa0 drivers/staging/android/ashmem.c:778 stack backtrace: CPU: 1 PID: 5488 Comm: syz-executor4 Not tainted 4.4.118-g5f7f76a #24 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011 0000000000000000 bbfacfb9ddc4e8b6 ffff8801c4acf9b8 ffffffff81d0402d ffffffff8519fe60 ffffffff8519fe60 ffffffff851bee80 ffff8800ac03e8f8 ffff8800ac03e000 ffff8801c4acfa00 ffffffff81233ba1 ffff8800ac03e8f8 Call Trace: [] __dump_stack lib/dump_stack.c:15 [inline] [] dump_stack+0xc1/0x124 lib/dump_stack.c:51 [] print_circular_bug+0x271/0x310 kernel/locking/lockdep.c:1226 [] check_prev_add kernel/locking/lockdep.c:1853 [inline] [] check_prevs_add kernel/locking/lockdep.c:1958 [inline] [] validate_chain kernel/locking/lockdep.c:2144 [inline] [] __lock_acquire+0x371f/0x4b50 kernel/locking/lockdep.c:3213 [] lock_acquire+0x15e/0x460 kernel/locking/lockdep.c:3592 [] __might_fault+0x14a/0x1d0 mm/memory.c:3810 [] copy_from_user arch/x86/include/asm/uaccess.h:724 [inline] [] ashmem_pin_unpin drivers/staging/android/ashmem.c:706 [inline] [] ashmem_ioctl+0x3b4/0xfa0 drivers/staging/android/ashmem.c:778 [] vfs_ioctl fs/ioctl.c:43 [inline] [] do_vfs_ioctl+0x7aa/0xee0 fs/ioctl.c:607 [] SYSC_ioctl fs/ioctl.c:622 [inline] [] SyS_ioctl+0x8f/0xc0 fs/ioctl.c:613 [] entry_SYSCALL_64_fastpath+0x1c/0x98 PF_BRIDGE: RTM_NEWNEIGH with invalid ifindex audit: type=1400 audit(1519661425.435:14): avc: denied { set_context_mgr } for pid=5565 comm="syz-executor6" scontext=unconfined_u:system_r:insmod_t:s0-s0:c0.c1023 tcontext=unconfined_u:system_r:insmod_t:s0-s0:c0.c1023 tclass=binder permissive=1 binder: 5565:5574 BC_ACQUIRE_DONE u0000000000000000 node 1 cookie mismatch 0000000000000003 != 0000000000000000 binder: 5565:5574 BC_REQUEST_DEATH_NOTIFICATION invalid ref 0 binder: 5565:5574 BC_CLEAR_DEATH_NOTIFICATION invalid ref 1 capability: warning: `syz-executor4' uses 32-bit capabilities (legacy support in use) binder: 5565:5595 unknown command 1075929871 binder: 5565:5595 ioctl c0306201 20008fd0 returned -22 binder: 5565:5574 BC_ACQUIRE_DONE u0000000000000000 node 1 cookie mismatch 0000000000000004 != 0000000000000000 binder: 5565:5574 got reply transaction with no transaction stack binder: 5565:5574 transaction failed 29201/-71, size 72-16 line 2921 binder: BINDER_SET_CONTEXT_MGR already set binder: 5565:5600 ioctl 40046207 0 returned -16 binder: 5565:5595 unknown command 1818587951 binder: 5565:5595 ioctl c0306201 20008fd0 returned -22 binder: undelivered TRANSACTION_ERROR: 29201 IPVS: length: 421 != 8 IPVS: length: 421 != 8 mmap: syz-executor2 (6195) uses deprecated remap_file_pages() syscall. See Documentation/vm/remap_file_pages.txt. audit_printk_skb: 3 callbacks suppressed audit: type=1400 audit(1519661428.245:16): avc: denied { setopt } for pid=6474 comm="syz-executor2" scontext=unconfined_u:system_r:insmod_t:s0-s0:c0.c1023 tcontext=unconfined_u:system_r:insmod_t:s0-s0:c0.c1023 tclass=netlink_generic_socket permissive=1 IPVS: length: 24 != 8 audit: type=1401 audit(1519661429.385:17): op=setxattr invalid_context="$+ppp1*nodevselfGPL]securityprocnodevmime_type)" audit: type=1401 audit(1519661429.425:18): op=setxattr invalid_context="$+ppp1*nodevselfGPL]securityprocnodevmime_type)" IPVS: Creating netns size=2552 id=9 pktgen: kernel_thread() failed for cpu 0 pktgen: Cannot create thread for cpu 0 (-4) pktgen: kernel_thread() failed for cpu 1 pktgen: Cannot create thread for cpu 1 (-4) pktgen: Initialization failed for all threads IPVS: length: 178 != 24 IPVS: length: 178 != 24 binder: 8438:8443 transaction failed 29189/-22, size 40-8 line 3005 binder: 8438:8452 transaction failed 29189/-22, size 40-8 line 3005 binder: undelivered TRANSACTION_ERROR: 29189 binder: undelivered TRANSACTION_ERROR: 29189 audit: type=1400 audit(1519661434.565:19): avc: denied { call } for pid=8469 comm="syz-executor2" scontext=unconfined_u:system_r:insmod_t:s0-s0:c0.c1023 tcontext=unconfined_u:system_r:insmod_t:s0-s0:c0.c1023 tclass=binder permissive=1 binder: 8469:8472 got transaction with too large buffer binder: 8469:8472 transaction failed 29201/-22, size 40-8 line 3287 binder: BINDER_SET_CONTEXT_MGR already set binder: 8469:8489 ioctl 40046207 0 returned -16 binder: undelivered TRANSACTION_ERROR: 29201