====================================================== [ INFO: possible circular locking dependency detected ] 4.9.109-ga4230be #48 Not tainted ------------------------------------------------------- syz-executor7/7984 is trying to acquire lock: (sk_lock-AF_INET){+.+.+.}, at: [] lock_sock include/net/sock.h:1404 [inline] (sk_lock-AF_INET){+.+.+.}, at: [] do_ip_setsockopt.isra.13+0x12a/0x2b10 net/ipv4/ip_sockglue.c:636 but task is already holding lock: (rtnl_mutex){+.+.+.}, at: [] rtnl_lock+0x17/0x20 net/core/rtnetlink.c:70 which lock already depends on the new lock. the existing dependency chain (in reverse order) is: lock_acquire+0x130/0x3e0 kernel/locking/lockdep.c:3756 __mutex_lock_common kernel/locking/mutex.c:521 [inline] mutex_lock_nested+0xc0/0x870 kernel/locking/mutex.c:621 rtnl_lock+0x17/0x20 net/core/rtnetlink.c:70 mrtsock_destruct+0x3b/0x1e0 net/ipv4/ipmr.c:1231 ip_ra_control+0x2c2/0x420 net/ipv4/ip_sockglue.c:360 do_ip_setsockopt.isra.13+0x15ff/0x2b10 net/ipv4/ip_sockglue.c:1137 ip_setsockopt+0x3a/0xb0 net/ipv4/ip_sockglue.c:1240 raw_setsockopt+0xb7/0xd0 net/ipv4/raw.c:833 sock_common_setsockopt+0x9a/0xe0 net/core/sock.c:2706 SYSC_setsockopt net/socket.c:1772 [inline] SyS_setsockopt+0x166/0x260 net/socket.c:1751 do_syscall_64+0x1a6/0x490 arch/x86/entry/common.c:282 entry_SYSCALL_64_after_swapgs+0x5d/0xdb check_prev_add kernel/locking/lockdep.c:1828 [inline] check_prevs_add kernel/locking/lockdep.c:1938 [inline] validate_chain kernel/locking/lockdep.c:2265 [inline] __lock_acquire+0x3019/0x4070 kernel/locking/lockdep.c:3345 lock_acquire+0x130/0x3e0 kernel/locking/lockdep.c:3756 lock_sock_nested+0xc6/0x120 net/core/sock.c:2511 lock_sock include/net/sock.h:1404 [inline] do_ip_setsockopt.isra.13+0x12a/0x2b10 net/ipv4/ip_sockglue.c:636 ip_setsockopt+0x3a/0xb0 net/ipv4/ip_sockglue.c:1240 udp_setsockopt+0x4a/0x90 net/ipv4/udp.c:2091 sock_common_setsockopt+0x9a/0xe0 net/core/sock.c:2706 SYSC_setsockopt net/socket.c:1772 [inline] SyS_setsockopt+0x166/0x260 net/socket.c:1751 do_syscall_64+0x1a6/0x490 arch/x86/entry/common.c:282 entry_SYSCALL_64_after_swapgs+0x5d/0xdb other info that might help us debug this: Possible unsafe locking scenario: CPU0 CPU1 ---- ---- lock(rtnl_mutex); lock(sk_lock-AF_INET); lock(rtnl_mutex); lock(sk_lock-AF_INET); *** DEADLOCK *** 1 lock held by syz-executor7/7984: #0: (rtnl_mutex){+.+.+.}, at: [] rtnl_lock+0x17/0x20 net/core/rtnetlink.c:70 stack backtrace: CPU: 0 PID: 7984 Comm: syz-executor7 Not tainted 4.9.109-ga4230be #48 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011 ffff8801b5a37758 ffffffff81eb3e29 ffffffff855e79b0 ffffffff8559cef0 ffffffff855e79b0 ffff8801c93950e8 ffff8801c9394800 ffff8801b5a377a0 ffffffff814262d4 0000000000000001 00000000c9394800 0000000000000001 Call Trace: [] __dump_stack lib/dump_stack.c:15 [inline] [] dump_stack+0xc1/0x128 lib/dump_stack.c:51 [] print_circular_bug.cold.51+0x1bd/0x27d kernel/locking/lockdep.c:1202 [] check_prev_add kernel/locking/lockdep.c:1828 [inline] [] check_prevs_add kernel/locking/lockdep.c:1938 [inline] [] validate_chain kernel/locking/lockdep.c:2265 [inline] [] __lock_acquire+0x3019/0x4070 kernel/locking/lockdep.c:3345 [] lock_acquire+0x130/0x3e0 kernel/locking/lockdep.c:3756 [] lock_sock_nested+0xc6/0x120 net/core/sock.c:2511 [] lock_sock include/net/sock.h:1404 [inline] [] do_ip_setsockopt.isra.13+0x12a/0x2b10 net/ipv4/ip_sockglue.c:636 [] ip_setsockopt+0x3a/0xb0 net/ipv4/ip_sockglue.c:1240 [] udp_setsockopt+0x4a/0x90 net/ipv4/udp.c:2091 [] sock_common_setsockopt+0x9a/0xe0 net/core/sock.c:2706 [] SYSC_setsockopt net/socket.c:1772 [inline] [] SyS_setsockopt+0x166/0x260 net/socket.c:1751 [] do_syscall_64+0x1a6/0x490 arch/x86/entry/common.c:282 [] entry_SYSCALL_64_after_swapgs+0x5d/0xdb netlink: 11 bytes leftover after parsing attributes in process `syz-executor4'. netlink: 11 bytes leftover after parsing attributes in process `syz-executor4'. netlink: 11 bytes leftover after parsing attributes in process `syz-executor4'. SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=8075 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=8075 comm=syz-executor2 netlink: 11 bytes leftover after parsing attributes in process `syz-executor4'. EXT2-fs (loop2): error: can't find an ext2 filesystem on dev loop2. SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=8121 comm=syz-executor3 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=8135 comm=syz-executor1 EXT2-fs (loop2): error: can't find an ext2 filesystem on dev loop2. SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=8148 comm=syz-executor3 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=8166 comm=syz-executor3 netlink: 11 bytes leftover after parsing attributes in process `syz-executor4'. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. netlink: 4256 bytes leftover after parsing attributes in process `syz-executor2'. netlink: 4256 bytes leftover after parsing attributes in process `syz-executor2'. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=8536 comm=syz-executor5 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=8562 comm=syz-executor5 EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=8625 comm=syz-executor5 EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. SELinux: unrecognized netlink message: protocol=0 nlmsg_type=39474 sclass=netlink_route_socket pig=8691 comm=syz-executor2 EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. SELinux: unrecognized netlink message: protocol=0 nlmsg_type=43923 sclass=netlink_route_socket pig=8980 comm=syz-executor2 EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=9057 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=0 sclass=netlink_route_socket pig=9057 comm=syz-executor2 EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop3): error: can't find an ext2 filesystem on dev loop3. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. SELinux: unrecognized netlink message: protocol=0 nlmsg_type=60 sclass=netlink_route_socket pig=9235 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=60 sclass=netlink_route_socket pig=9242 comm=syz-executor2 EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. SELinux: unrecognized netlink message: protocol=0 nlmsg_type=65535 sclass=netlink_route_socket pig=9266 comm=syz-executor2 EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. EXT2-fs (loop6): error: can't find an ext2 filesystem on dev loop6. selinux_nlmsg_perm: 6 callbacks suppressed SELinux: unrecognized netlink message: protocol=0 nlmsg_type=256 sclass=netlink_route_socket pig=10046 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=256 sclass=netlink_route_socket pig=10046 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=31 sclass=netlink_route_socket pig=10186 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=18657 sclass=netlink_route_socket pig=10288 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=158 sclass=netlink_route_socket pig=10313 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=158 sclass=netlink_route_socket pig=10317 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=40478 sclass=netlink_route_socket pig=10343 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=51691 sclass=netlink_route_socket pig=10368 comm=syz-executor2 SELinux: unrecognized netlink message: protocol=0 nlmsg_type=29677 sclass=netlink_route_socket pig=10438 comm=syz-executor2 nla_parse: 10 callbacks suppressed netlink: 12 bytes leftover after parsing attributes in process `syz-executor2'. netlink: 12 bytes leftover after parsing attributes in process `syz-executor2'.