syzbot


KCSAN: data-race in virtqueue_disable_cb / virtqueue_enable_cb_delayed

Status: closed as invalid on 2019/11/19 13:54
Subsystems: virt
[Documentation on labels]
First crash: 1657d, last: 1645d
Similar bugs (7)
Kernel Title Repro Cause bisect Fix bisect Count Last Reported Patched Status
upstream KCSAN: data-race in virtqueue_disable_cb / virtqueue_enable_cb_delayed (3) virt 1 1359d 1359d 0/26 auto-closed as invalid on 2020/09/20 20:51
upstream KCSAN: data-race in virtqueue_disable_cb / virtqueue_enable_cb_delayed (5) virt 3 703d 752d 0/26 auto-closed as invalid on 2022/07/09 17:31
upstream KCSAN: data-race in virtqueue_disable_cb / virtqueue_enable_cb_delayed (2) virt 3 1532d 1605d 0/26 auto-closed as invalid on 2020/05/05 19:05
upstream KCSAN: data-race in virtqueue_disable_cb / virtqueue_enable_cb_delayed (8) virt 2 321d 340d 0/26 auto-obsoleted due to no activity on 2023/07/25 21:20
upstream KCSAN: data-race in virtqueue_disable_cb / virtqueue_enable_cb_delayed (6) virt 1 544d 544d 0/26 auto-obsoleted due to no activity on 2022/12/15 06:15
upstream KCSAN: data-race in virtqueue_disable_cb / virtqueue_enable_cb_delayed (7) virt 1 399d 399d 0/26 auto-obsoleted due to no activity on 2023/05/09 11:44
upstream KCSAN: data-race in virtqueue_disable_cb / virtqueue_enable_cb_delayed (4) virt 1 1266d 1247d 0/26 auto-closed as invalid on 2020/12/23 03:08

Sample crash report:
==================================================================
BUG: KCSAN: data-race in virtqueue_disable_cb / virtqueue_enable_cb_delayed

read to 0xffff88821aa8aaf0 of 2 bytes by interrupt on cpu 0:
 virtqueue_enable_cb_delayed_split drivers/virtio/virtio_ring.c:794 [inline]
 virtqueue_enable_cb_delayed+0x1dc/0x4d0 drivers/virtio/virtio_ring.c:2006
 start_xmit+0xb0f/0xbe0 drivers/net/virtio_net.c:1565
 __netdev_start_xmit include/linux/netdevice.h:4413 [inline]
 netdev_start_xmit include/linux/netdevice.h:4427 [inline]
 xmit_one net/core/dev.c:3199 [inline]
 dev_hard_start_xmit+0xef/0x430 net/core/dev.c:3215
 sch_direct_xmit+0x2b3/0x900 net/sched/sch_generic.c:313
 __dev_xmit_skb net/core/dev.c:3400 [inline]
 __dev_queue_xmit+0x19a3/0x1b40 net/core/dev.c:3761
 dev_queue_xmit+0x21/0x30 net/core/dev.c:3825
 neigh_hh_output include/net/neighbour.h:500 [inline]
 neigh_output include/net/neighbour.h:509 [inline]
 ip_finish_output2+0x836/0xe40 net/ipv4/ip_output.c:228
 __ip_finish_output net/ipv4/ip_output.c:308 [inline]
 __ip_finish_output+0x23a/0x490 net/ipv4/ip_output.c:290
 ip_finish_output+0x41/0x160 net/ipv4/ip_output.c:318
 NF_HOOK_COND include/linux/netfilter.h:294 [inline]
 ip_output+0xdf/0x210 net/ipv4/ip_output.c:432
 dst_output include/net/dst.h:436 [inline]
 ip_local_out+0x74/0x90 net/ipv4/ip_output.c:125
 __ip_queue_xmit+0x3a8/0xa40 net/ipv4/ip_output.c:532
 ip_queue_xmit+0x45/0x60 include/net/ip.h:237
 __tcp_transmit_skb+0xe81/0x1d60 net/ipv4/tcp_output.c:1169
 __tcp_send_ack+0x246/0x300 net/ipv4/tcp_output.c:3696
 tcp_send_ack+0x34/0x40 net/ipv4/tcp_output.c:3702
 __tcp_ack_snd_check+0xd9/0x4f0 net/ipv4/tcp_input.c:5243
 tcp_rcv_established+0xce9/0xf50 net/ipv4/tcp_input.c:5674
 tcp_v4_do_rcv+0x3b5/0x520 net/ipv4/tcp_ipv4.c:1564
 tcp_v4_rcv+0x19ec/0x1bd0 net/ipv4/tcp_ipv4.c:1945
 ip_protocol_deliver_rcu+0x4d/0x420 net/ipv4/ip_input.c:204
 ip_local_deliver_finish+0x110/0x140 net/ipv4/ip_input.c:231
 NF_HOOK include/linux/netfilter.h:305 [inline]
 NF_HOOK include/linux/netfilter.h:299 [inline]
 ip_local_deliver+0x133/0x210 net/ipv4/ip_input.c:252
 dst_input include/net/dst.h:442 [inline]
 ip_rcv_finish+0x121/0x160 net/ipv4/ip_input.c:413
 NF_HOOK include/linux/netfilter.h:305 [inline]
 NF_HOOK include/linux/netfilter.h:299 [inline]
 ip_rcv+0x18f/0x1a0 net/ipv4/ip_input.c:523
 __netif_receive_skb_one_core+0xa7/0xe0 net/core/dev.c:4929
 __netif_receive_skb+0x37/0xf0 net/core/dev.c:5043
 netif_receive_skb_internal+0x59/0x190 net/core/dev.c:5133
 napi_skb_finish net/core/dev.c:5596 [inline]
 napi_gro_receive+0x28f/0x330 net/core/dev.c:5629
 receive_buf+0x284/0x30b0 drivers/net/virtio_net.c:1061
 virtnet_receive drivers/net/virtio_net.c:1323 [inline]
 virtnet_poll+0x436/0x7d0 drivers/net/virtio_net.c:1428
 napi_poll net/core/dev.c:6311 [inline]
 net_rx_action+0x3ae/0xa90 net/core/dev.c:6379
 __do_softirq+0x115/0x33f kernel/softirq.c:292
 invoke_softirq kernel/softirq.c:373 [inline]
 irq_exit+0xbb/0xe0 kernel/softirq.c:413
 exiting_irq arch/x86/include/asm/apic.h:536 [inline]
 do_IRQ+0xa6/0x180 arch/x86/kernel/irq.c:263
 ret_from_intr+0x0/0x19

write to 0xffff88821aa8aaf0 of 2 bytes by interrupt on cpu 1:
 virtqueue_disable_cb_split drivers/virtio/virtio_ring.c:741 [inline]
 virtqueue_disable_cb+0xe9/0x130 drivers/virtio/virtio_ring.c:1925
 skb_xmit_done+0x6a/0x110 drivers/net/virtio_net.c:343
 vring_interrupt drivers/virtio/virtio_ring.c:2046 [inline]
 vring_interrupt+0x1a1/0x1c0 drivers/virtio/virtio_ring.c:2032
 __handle_irq_event_percpu+0x9a/0x430 kernel/irq/handle.c:149
 handle_irq_event_percpu+0x4b/0xe0 kernel/irq/handle.c:189
 handle_irq_event+0x85/0xca kernel/irq/handle.c:206
 handle_edge_irq+0x1a4/0x4a0 kernel/irq/chip.c:830
 generic_handle_irq_desc include/linux/irqdesc.h:156 [inline]
 do_IRQ+0xa1/0x180 arch/x86/kernel/irq.c:250
 ret_from_intr+0x0/0x19
 skb_network_protocol+0x0/0x2a0 net/core/dev.c:3247
 validate_xmit_skb+0x49/0x870 net/core/dev.c:3257
 __dev_queue_xmit+0xd04/0x1b40 net/core/dev.c:3784
 dev_queue_xmit+0x21/0x30 net/core/dev.c:3825
 __bpf_tx_skb net/core/filter.c:2060 [inline]
 __bpf_redirect_common net/core/filter.c:2099 [inline]
 __bpf_redirect+0x4b4/0x710 net/core/filter.c:2106
 ____bpf_clone_redirect net/core/filter.c:2139 [inline]
 bpf_clone_redirect+0x1a5/0x1f0 net/core/filter.c:2111
 bpf_prog_bb15b996d00816f9+0x662/0x1000
 bpf_test_run+0x1c3/0x490 net/bpf/test_run.c:44
 bpf_prog_test_run_skb+0x4da/0x840 net/bpf/test_run.c:310
 bpf_prog_test_run kernel/bpf/syscall.c:2117 [inline]
 __do_sys_bpf+0x1664/0x2b90 kernel/bpf/syscall.c:2893
 __se_sys_bpf kernel/bpf/syscall.c:2834 [inline]
 __x64_sys_bpf+0x4c/0x60 kernel/bpf/syscall.c:2834
 do_syscall_64+0xcc/0x370 arch/x86/entry/common.c:290
 entry_SYSCALL_64_after_hwframe+0x44/0xa9

Reported by Kernel Concurrency Sanitizer on:
CPU: 1 PID: 30571 Comm: syz-executor.5 Not tainted 5.4.0-rc6+ #0
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
==================================================================

Crashes (2):
Time Kernel Commit Syzkaller Config Log Report Syz repro C repro VM info Assets (help?) Manager Title
2019/11/05 16:38 https://github.com/google/ktsan.git kcsan 94c006602e13 af5c522d .config console log report ci2-upstream-kcsan-gce
2019/10/24 17:28 https://github.com/google/ktsan.git kcsan 05f2236801fe d01bb02a .config console log report ci2-upstream-kcsan-gce
* Struck through repros no longer work on HEAD.