input: syz1 as /devices/virtual/input/input61 ====================================================== [ INFO: possible circular locking dependency detected ] 4.4.157+ #101 Not tainted ------------------------------------------------------- syz-executor5/16333 is trying to acquire lock: (sel_mutex){+.+.+.}, at: [] sel_commit_bools_write+0x87/0x250 security/selinux/selinuxfs.c:1142 but task is already holding lock: (&pipe->mutex/1){+.+.+.}, at: [] pipe_lock_nested fs/pipe.c:65 [inline] (&pipe->mutex/1){+.+.+.}, at: [] pipe_lock+0x5e/0x70 fs/pipe.c:73 which lock already depends on the new lock. the existing dependency chain (in reverse order) is: [] lock_acquire+0x15e/0x450 kernel/locking/lockdep.c:3592 [] __mutex_lock_common kernel/locking/mutex.c:521 [inline] [] mutex_lock_nested+0xbb/0x840 kernel/locking/mutex.c:621 [] __pipe_lock fs/pipe.c:86 [inline] [] fifo_open+0x15c/0x9e0 fs/pipe.c:896 [] do_dentry_open+0x38d/0xbd0 fs/open.c:749 [] vfs_open+0x12a/0x210 fs/open.c:862 [] do_last fs/namei.c:3222 [inline] [] path_openat+0x50c/0x39a0 fs/namei.c:3359 [] do_filp_open+0x197/0x270 fs/namei.c:3393 [] do_open_execat+0x10f/0x6f0 fs/exec.c:800 [] do_execveat_common.isra.15+0x6a1/0x1f00 fs/exec.c:1573 [] do_execve fs/exec.c:1679 [inline] [] SYSC_execve fs/exec.c:1760 [inline] [] SyS_execve+0x42/0x50 fs/exec.c:1755 [] return_from_execve+0x0/0x23 [] lock_acquire+0x15e/0x450 kernel/locking/lockdep.c:3592 input: syz1 as /devices/virtual/input/input62 [] __mutex_lock_common kernel/locking/mutex.c:521 [inline] [] mutex_lock_killable_nested+0xcc/0x980 kernel/locking/mutex.c:641 [] lock_trace+0x44/0xc0 fs/proc/base.c:448 [] proc_pid_syscall+0xa9/0x260 fs/proc/base.c:669 [] proc_single_show+0xfd/0x170 fs/proc/base.c:791 [] seq_read+0x4b6/0x12b0 fs/seq_file.c:240 [] __vfs_read+0x11c/0x3d0 fs/read_write.c:432 [] vfs_read+0x130/0x360 fs/read_write.c:454 [] SYSC_read fs/read_write.c:569 [inline] [] SyS_read+0xd9/0x1c0 fs/read_write.c:562 [] entry_SYSCALL_64_fastpath+0x1e/0x9a [] lock_acquire+0x15e/0x450 kernel/locking/lockdep.c:3592 [] __mutex_lock_common kernel/locking/mutex.c:521 [inline] [] mutex_lock_nested+0xbb/0x840 kernel/locking/mutex.c:621 [] seq_read+0xdd/0x12b0 fs/seq_file.c:178 [] proc_reg_read+0xfd/0x180 fs/proc/inode.c:202 [] do_loop_readv_writev+0x148/0x1e0 fs/read_write.c:680 [] do_readv_writev+0x581/0x6f0 fs/read_write.c:810 [] vfs_readv+0x78/0xb0 fs/read_write.c:834 [] kernel_readv fs/splice.c:586 [inline] [] default_file_splice_read+0x4fb/0x8d0 fs/splice.c:662 [] do_splice_to+0xf7/0x140 fs/splice.c:1154 [] splice_direct_to_actor+0x242/0x830 fs/splice.c:1226 [] do_splice_direct+0x1a3/0x270 fs/splice.c:1337 [] do_sendfile+0x4e4/0xb80 fs/read_write.c:1227 [] SYSC_sendfile64 fs/read_write.c:1282 [inline] [] SyS_sendfile64+0xc3/0x150 fs/read_write.c:1274 [] entry_SYSCALL_64_fastpath+0x1e/0x9a [] lock_acquire+0x15e/0x450 kernel/locking/lockdep.c:3592 [] percpu_down_read include/linux/percpu-rwsem.h:26 [inline] [] __sb_start_write+0x1ae/0x310 fs/super.c:1221 [] sb_start_write include/linux/fs.h:1515 [inline] [] ext4_run_li_request fs/ext4/super.c:2674 [inline] [] ext4_lazyinit_thread+0x1a7/0x750 fs/ext4/super.c:2773 [] kthread+0x268/0x300 kernel/kthread.c:211 [] ret_from_fork+0x55/0x80 arch/x86/entry/entry_64.S:510 [] lock_acquire+0x15e/0x450 kernel/locking/lockdep.c:3592 [] __mutex_lock_common kernel/locking/mutex.c:521 [inline] [] mutex_lock_nested+0xbb/0x840 kernel/locking/mutex.c:621 [] ext4_register_li_request+0x304/0x6c0 fs/ext4/super.c:2961 [] ext4_remount+0x1368/0x1bb0 fs/ext4/super.c:4909 [] do_remount_sb2+0x428/0x7d0 fs/super.c:771 [] do_remount fs/namespace.c:2335 [inline] [] do_mount+0x101e/0x28f0 fs/namespace.c:2848 [] SYSC_mount fs/namespace.c:3051 [inline] [] SyS_mount+0x191/0x1c0 fs/namespace.c:3029 [] entry_SYSCALL_64_fastpath+0x1e/0x9a [] lock_acquire+0x15e/0x450 kernel/locking/lockdep.c:3592 [] __mutex_lock_common kernel/locking/mutex.c:521 [inline] [] mutex_lock_nested+0xbb/0x840 kernel/locking/mutex.c:621 [] ext4_register_li_request+0x87/0x6c0 fs/ext4/super.c:2934 [] ext4_remount+0x1368/0x1bb0 fs/ext4/super.c:4909 [] do_remount_sb2+0x428/0x7d0 fs/super.c:771 [] do_remount fs/namespace.c:2335 [inline] [] do_mount+0x101e/0x28f0 fs/namespace.c:2848 [] SYSC_mount fs/namespace.c:3051 [inline] [] SyS_mount+0x191/0x1c0 fs/namespace.c:3029 [] entry_SYSCALL_64_fastpath+0x1e/0x9a [] lock_acquire+0x15e/0x450 kernel/locking/lockdep.c:3592 [] down_read+0x42/0x60 kernel/locking/rwsem.c:22 [] iterate_supers+0xe1/0x260 fs/super.c:537 [] selinux_complete_init+0x2f/0x31 security/selinux/hooks.c:6154 [] security_load_policy+0x886/0x9b0 security/selinux/ss/services.c:2060 [] sel_write_load+0x191/0xfc0 security/selinux/selinuxfs.c:535 [] __vfs_write+0x11c/0x3e0 fs/read_write.c:489 [] vfs_write+0x17e/0x4e0 fs/read_write.c:538 [] SYSC_write fs/read_write.c:585 [inline] [] SyS_write+0xd9/0x1c0 fs/read_write.c:577 [] entry_SYSCALL_64_fastpath+0x1e/0x9a [] 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+0x3b6e/0x5ba0 kernel/locking/lockdep.c:3213 [] lock_acquire+0x15e/0x450 kernel/locking/lockdep.c:3592 [] __mutex_lock_common kernel/locking/mutex.c:521 [inline] [] mutex_lock_nested+0xbb/0x840 kernel/locking/mutex.c:621 [] sel_commit_bools_write+0x87/0x250 security/selinux/selinuxfs.c:1142 [] __vfs_write+0x11c/0x3e0 fs/read_write.c:489 [] __kernel_write+0xf0/0x320 fs/read_write.c:511 [] write_pipe_buf+0x15d/0x1f0 fs/splice.c:1074 [] splice_from_pipe_feed fs/splice.c:776 [inline] [] __splice_from_pipe+0x364/0x790 fs/splice.c:901 [] splice_from_pipe+0xf9/0x170 fs/splice.c:936 [] default_file_splice_write+0x3c/0x80 fs/splice.c:1086 [] do_splice_from fs/splice.c:1128 [inline] [] do_splice fs/splice.c:1404 [inline] [] SYSC_splice fs/splice.c:1707 [inline] [] SyS_splice+0xde1/0x1430 fs/splice.c:1690 [] entry_SYSCALL_64_fastpath+0x1e/0x9a other info that might help us debug this: Chain exists of: Possible unsafe locking scenario: CPU0 CPU1 ---- ---- lock(&pipe->mutex/1); lock(&sig->cred_guard_mutex); lock(&pipe->mutex/1); lock(sel_mutex); *** DEADLOCK *** 2 locks held by syz-executor5/16333: #0: (sb_writers#3){.+.+.+}, at: [] file_start_write include/linux/fs.h:2541 [inline] #0: (sb_writers#3){.+.+.+}, at: [] do_splice fs/splice.c:1403 [inline] #0: (sb_writers#3){.+.+.+}, at: [] SYSC_splice fs/splice.c:1707 [inline] #0: (sb_writers#3){.+.+.+}, at: [] SyS_splice+0xfaa/0x1430 fs/splice.c:1690 #1: (&pipe->mutex/1){+.+.+.}, at: [] pipe_lock_nested fs/pipe.c:65 [inline] #1: (&pipe->mutex/1){+.+.+.}, at: [] pipe_lock+0x5e/0x70 fs/pipe.c:73 stack backtrace: CPU: 1 PID: 16333 Comm: syz-executor5 Not tainted 4.4.157+ #101 0000000000000000 d22638176ee442a2 ffff8801cecb7608 ffffffff81a559fd ffffffff83aac9d0 ffffffff83ab3420 ffffffff83aaeb90 ffff8801cee48910 ffff8801cee48000 ffff8801cecb7650 ffffffff813924cf 0000000000000002 Call Trace: [] __dump_stack lib/dump_stack.c:15 [inline] [] dump_stack+0xc1/0x124 lib/dump_stack.c:51 [] print_circular_bug.cold.34+0x2f7/0x432 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+0x3b6e/0x5ba0 kernel/locking/lockdep.c:3213 [] lock_acquire+0x15e/0x450 kernel/locking/lockdep.c:3592 [] __mutex_lock_common kernel/locking/mutex.c:521 [inline] [] mutex_lock_nested+0xbb/0x840 kernel/locking/mutex.c:621 [] sel_commit_bools_write+0x87/0x250 security/selinux/selinuxfs.c:1142 [] __vfs_write+0x11c/0x3e0 fs/read_write.c:489 [] __kernel_write+0xf0/0x320 fs/read_write.c:511 [] write_pipe_buf+0x15d/0x1f0 fs/splice.c:1074 [] splice_from_pipe_feed fs/splice.c:776 [inline] [] __splice_from_pipe+0x364/0x790 fs/splice.c:901 [] splice_from_pipe+0xf9/0x170 fs/splice.c:936 [] default_file_splice_write+0x3c/0x80 fs/splice.c:1086 [] do_splice_from fs/splice.c:1128 [inline] [] do_splice fs/splice.c:1404 [inline] [] SYSC_splice fs/splice.c:1707 [inline] [] SyS_splice+0xde1/0x1430 fs/splice.c:1690 [] entry_SYSCALL_64_fastpath+0x1e/0x9a audit: type=1400 audit(1537609341.836:71): avc: denied { create } for pid=16832 comm="syz-executor5" scontext=unconfined_u:system_r:insmod_t:s0-s0:c0.c1023 tcontext=unconfined_u:system_r:insmod_t:s0-s0:c0.c1023 tclass=netlink_scsitransport_socket permissive=1