syzbot


KCSAN: data-race in __ip6_datagram_connect / __raw_v6_lookup

Status: auto-closed as invalid on 2020/03/28 17:40
Subsystems: net
[Documentation on labels]
First crash: 1559d, last: 1559d
Similar bugs (1)
Kernel Title Repro Cause bisect Fix bisect Count Last Reported Patched Status
upstream KCSAN: data-race in __ip6_datagram_connect / __raw_v6_lookup (2) net 1 1457d 1457d 0/26 auto-closed as invalid on 2020/06/18 13:53

Sample crash report:
==================================================================
BUG: KCSAN: data-race in __ip6_datagram_connect / __raw_v6_lookup

read to 0xffff8880658ad0f8 of 8 bytes by interrupt on cpu 0:
 ipv6_addr_any include/net/ipv6.h:640 [inline]
 __raw_v6_lookup+0xc7/0x2f0 net/ipv6/raw.c:81
 ipv6_raw_deliver net/ipv6/raw.c:178 [inline]
 raw6_local_deliver+0x1c8/0x600 net/ipv6/raw.c:235
 ip6_protocol_deliver_rcu+0x27a/0xbe0 net/ipv6/ip6_input.c:382
 ip6_input_finish+0x30/0x50 net/ipv6/ip6_input.c:473
 NF_HOOK include/linux/netfilter.h:307 [inline]
 NF_HOOK include/linux/netfilter.h:301 [inline]
 ip6_input+0x177/0x190 net/ipv6/ip6_input.c:482
 dst_input include/net/dst.h:442 [inline]
 ip6_rcv_finish+0x110/0x140 net/ipv6/ip6_input.c:76
 NF_HOOK include/linux/netfilter.h:307 [inline]
 NF_HOOK include/linux/netfilter.h:301 [inline]
 ipv6_rcv+0x1a1/0x1b0 net/ipv6/ip6_input.c:306
 __netif_receive_skb_one_core+0xa7/0xe0 net/core/dev.c:5150
 __netif_receive_skb+0x37/0xf0 net/core/dev.c:5264
 process_backlog+0x207/0x4b0 net/core/dev.c:6095
 napi_poll net/core/dev.c:6532 [inline]
 net_rx_action+0x3ae/0xa90 net/core/dev.c:6600
 __do_softirq+0x115/0x33f kernel/softirq.c:292
 do_softirq_own_stack+0x2a/0x40 arch/x86/entry/entry_64.S:1082
 do_softirq.part.0+0x6b/0x80 kernel/softirq.c:337
 do_softirq kernel/softirq.c:329 [inline]
 __local_bh_enable_ip+0x76/0x80 kernel/softirq.c:189
 local_bh_enable include/linux/bottom_half.h:32 [inline]
 rcu_read_unlock_bh include/linux/rcupdate.h:706 [inline]
 ip6_finish_output2+0x730/0xf60 net/ipv6/ip6_output.c:117
 __ip6_finish_output net/ipv6/ip6_output.c:142 [inline]
 __ip6_finish_output+0x2d7/0x330 net/ipv6/ip6_output.c:127
 ip6_finish_output+0x41/0x160 net/ipv6/ip6_output.c:152
 NF_HOOK_COND include/linux/netfilter.h:296 [inline]
 ip6_output+0x108/0x290 net/ipv6/ip6_output.c:175
 dst_output include/net/dst.h:436 [inline]
 ip6_local_out+0x74/0x90 net/ipv6/output_core.c:179
 ip6_send_skb+0x53/0x110 net/ipv6/ip6_output.c:1795
 ip6_push_pending_frames+0x9d/0xc0 net/ipv6/ip6_output.c:1815
 rawv6_push_pending_frames net/ipv6/raw.c:613 [inline]
 rawv6_sendmsg+0x1e59/0x2340 net/ipv6/raw.c:956
 inet_sendmsg+0x6d/0x90 net/ipv4/af_inet.c:807
 sock_sendmsg_nosec net/socket.c:639 [inline]
 sock_sendmsg+0x9f/0xc0 net/socket.c:659
 ____sys_sendmsg+0x212/0x4d0 net/socket.c:2330
 ___sys_sendmsg+0xb5/0x100 net/socket.c:2384
 __sys_sendmmsg+0x123/0x350 net/socket.c:2474
 __do_sys_sendmmsg net/socket.c:2503 [inline]
 __se_sys_sendmmsg net/socket.c:2500 [inline]
 __x64_sys_sendmmsg+0x64/0x80 net/socket.c:2500
 do_syscall_64+0xcc/0x3a0 arch/x86/entry/common.c:294
 entry_SYSCALL_64_after_hwframe+0x44/0xa9

write to 0xffff8880658ad0f8 of 16 bytes by task 10740 on cpu 1:
 __ip6_datagram_connect+0x521/0x9f0 net/ipv6/datagram.c:238
 ip6_datagram_connect+0x39/0x60 net/ipv6/datagram.c:271
 ip6_datagram_connect_v6_only+0x54/0x80 net/ipv6/datagram.c:283
 inet_dgram_connect+0xcf/0x1a0 net/ipv4/af_inet.c:571
 __sys_connect_file+0xf4/0x100 net/socket.c:1844
 __sys_connect+0x121/0x150 net/socket.c:1861
 __do_sys_connect net/socket.c:1872 [inline]
 __se_sys_connect net/socket.c:1869 [inline]
 __x64_sys_connect+0x4c/0x60 net/socket.c:1869
 do_syscall_64+0xcc/0x3a0 arch/x86/entry/common.c:294
 entry_SYSCALL_64_after_hwframe+0x44/0xa9

Reported by Kernel Concurrency Sanitizer on:
CPU: 1 PID: 10740 Comm: syz-executor.5 Not tainted 5.5.0-rc1-syzkaller #0
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
==================================================================

Crashes (1):
Time Kernel Commit Syzkaller Config Log Report Syz repro C repro VM info Assets (help?) Manager Title
2020/01/18 17:31 https://github.com/google/ktsan.git kcsan 245a43005292 3de7aabb .config console log report ci2-upstream-kcsan-gce
* Struck through repros no longer work on HEAD.