====================================== | [ 57.163231][ C2] #6: ffffffff949447e0 (rcu_read_lock){....}-{1:2}, at: netif_receive_skb_internal (./include/linux/rcupdate.h:298 (discriminator 16) ./include/linux/rcupdate.h:750 (discriminator 16) net/core/dev.c:5729 (discriminator 16)) | [ 57.163803][ C2] #7: ffffffff949447e0 (rcu_read_lock){....}-{1:2}, at: ip_local_deliver_finish (./include/linux/rcupdate.h:298 ./include/linux/rcupdate.h:750 net/ipv4/ip_input.c:232) | [ 57.164346][ C2] | [ 57.164346][ C2] stack backtrace: [ 57.165047][ C2] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS rel-1.16.3-0-ga6ed6b701f0a-prebuilt.qemu.org 04/01/2014 [ 57.165708][ C2] Call Trace: [ 57.165886][ C2] [ 57.166039][ C2] dump_stack_lvl (lib/dump_stack.c:107) [ 57.166283][ C2] validate_chain (kernel/locking/lockdep.c:3859) [ 57.166529][ C2] ? __pfx_validate_chain (kernel/locking/lockdep.c:3825) [ 57.166834][ C2] ? hlock_class (./arch/x86/include/asm/bitops.h:227 ./arch/x86/include/asm/bitops.h:239 ./include/asm-generic/bitops/instrumented-non-atomic.h:142 kernel/locking/lockdep.c:228) [ 57.167077][ C2] ? mark_lock (kernel/locking/lockdep.c:4656 (discriminator 3)) [ 57.167300][ C2] __lock_acquire (kernel/locking/lockdep.c:5137) [ 57.167567][ C2] ? lock_downgrade (kernel/locking/lockdep.c:5656) [ 57.167840][ C2] ? mark_lock (kernel/locking/lockdep.c:4656 (discriminator 3)) [ 57.168091][ C2] lock_acquire.part.0 (kernel/locking/lockdep.c:467 kernel/locking/lockdep.c:5756) [ 57.168360][ C2] ? tcp_v4_rcv (./include/linux/skbuff.h:1619 ./include/net/tcp.h:2510 net/ipv4/tcp_ipv4.c:2326) [ 57.168621][ C2] ? __pfx_lock_acquire.part.0 (kernel/locking/lockdep.c:5719) [ 57.168932][ C2] ? __pfx_sk_filter_trim_cap (net/core/filter.c:130) [ 57.169231][ C2] ? lock_acquire (./include/trace/events/lock.h:24 kernel/locking/lockdep.c:5725) [ 57.169489][ C2] ? tcp_v4_rcv (./include/linux/skbuff.h:1619 ./include/net/tcp.h:2510 net/ipv4/tcp_ipv4.c:2326) [ 57.169745][ C2] _raw_spin_lock_nested (kernel/locking/spinlock.c:379) [ 57.170034][ C2] ? tcp_v4_rcv (./include/linux/skbuff.h:1619 ./include/net/tcp.h:2510 net/ipv4/tcp_ipv4.c:2326) [ 57.170301][ C2] tcp_v4_rcv (./include/linux/skbuff.h:1619 ./include/net/tcp.h:2510 net/ipv4/tcp_ipv4.c:2326) [ 57.170546][ C2] ? __pfx_tcp_v4_rcv (net/ipv4/tcp_ipv4.c:2162) [ 57.170819][ C2] ? __pfx_raw_v4_input (net/ipv4/raw.c:165) [ 57.171085][ C2] ? __pfx_lock_acquire.part.0 (kernel/locking/lockdep.c:5719) [ 57.171380][ C2] ip_protocol_deliver_rcu (net/ipv4/ip_input.c:207 (discriminator 8)) [ 57.171674][ C2] ip_local_deliver_finish (./include/linux/rcupdate.h:779 net/ipv4/ip_input.c:234) [ 57.172028][ C2] ip_local_deliver (./include/linux/netfilter.h:314 ./include/linux/netfilter.h:308 net/ipv4/ip_input.c:254) [ 57.172286][ C2] ? __pfx_ip_local_deliver (net/ipv4/ip_input.c:243) [ 57.172578][ C2] ? tcp_v4_early_demux (./include/linux/skbuff.h:1163 net/ipv4/tcp_ipv4.c:1988) [ 57.172864][ C2] ? ip_rcv_finish_core.constprop.0 (./include/linux/skbuff.h:1131 ./include/linux/skbuff.h:1183 net/ipv4/ip_input.c:390) [ 57.173198][ C2] ip_rcv (./include/net/dst.h:460 net/ipv4/ip_input.c:449 ./include/linux/netfilter.h:314 ./include/linux/netfilter.h:308 net/ipv4/ip_input.c:569) [ 57.173409][ C2] ? __pfx_ip_rcv (net/ipv4/ip_input.c:562) [ 57.173655][ C2] ? lock_acquire.part.0 (kernel/locking/lockdep.c:467 kernel/locking/lockdep.c:5756) [ 57.173951][ C2] ? netif_receive_skb_internal (./include/linux/rcupdate.h:298 (discriminator 16) ./include/linux/rcupdate.h:750 (discriminator 16) net/core/dev.c:5729 (discriminator 16)) [ 57.174278][ C2] ? __pfx_ip_rcv (net/ipv4/ip_input.c:562) [ 57.174512][ C2] __netif_receive_skb_one_core (net/core/dev.c:5542 (discriminator 4)) [ 57.174848][ C2] ? __pfx___netif_receive_skb_one_core (net/core/dev.c:5535) [ 57.175219][ C2] ? mark_held_locks (kernel/locking/lockdep.c:4274) [ 57.175471][ C2] ? lock_acquire (./include/trace/events/lock.h:24 kernel/locking/lockdep.c:5725) [ 57.175754][ C2] ? netif_receive_skb_internal (./include/linux/rcupdate.h:298 (discriminator 16) ./include/linux/rcupdate.h:750 (discriminator 16) net/core/dev.c:5729 (discriminator 16)) [ 57.176078][ C2] netif_receive_skb_internal (net/core/dev.c:5742) [ 57.176392][ C2] ? __pfx_netif_receive_skb_internal (net/core/dev.c:5721) [ 57.176740][ C2] ? __copy_skb_header (./include/net/dst.h:290 net/core/skbuff.c:1420) [ 57.177027][ C2] ? __skb_clone (./arch/x86/include/asm/atomic.h:53 (discriminator 4) ./include/linux/atomic/atomic-arch-fallback.h:992 (discriminator 4) ./include/linux/atomic/atomic-instrumented.h:436 (discriminator 4) net/core/skbuff.c:1491 (discriminator 4)) [ 57.177293][ C2] netif_receive_skb (net/core/dev.c:5801) [ 57.177544][ C2] tcf_mirred_to_dev (net/sched/act_mirred.c:251 net/sched/act_mirred.c:326) act_mirred [ 57.177882][ C2] ? __pfx_tcf_skbedit_act (net/sched/act_skbedit.c:43) act_skbedit [ 57.178219][ C2] tcf_mirred_act (net/sched/act_mirred.c:461 (discriminator 2)) act_mirred [ 57.178546][ C2] tcf_action_exec.part.0 (./include/net/tc_wrapper.h:130 net/sched/act_api.c:1100) [ 57.178882][ C2] fl_classify (net/sched/cls_flower.c:345) cls_flower [ 57.179203][ C2] ? __pfx_fl_classify (net/sched/cls_flower.c:316) cls_flower [ 57.179533][ C2] ? mark_lock (kernel/locking/lockdep.c:4656 (discriminator 3)) [ 57.179769][ C2] ? __pfx_check_irq_usage (kernel/locking/lockdep.c:2790) [ 57.180051][ C2] ? __bfs (kernel/locking/lockdep.c:1787) [ 57.180268][ C2] ? __pfx_hlock_conflict (kernel/locking/lockdep.c:2016) [ 57.180547][ C2] ? hlock_class (./arch/x86/include/asm/bitops.h:227 ./arch/x86/include/asm/bitops.h:239 ./include/asm-generic/bitops/instrumented-non-atomic.h:142 kernel/locking/lockdep.c:228) [ 57.180803][ C2] ? check_path.constprop.0 (kernel/locking/lockdep.c:2145) [ 57.181088][ C2] ? check_noncircular (kernel/locking/lockdep.c:2172) [ 57.181357][ C2] ? __pfx_check_noncircular (kernel/locking/lockdep.c:2163) [ 57.181649][ C2] ? hlock_class (./arch/x86/include/asm/bitops.h:227 ./arch/x86/include/asm/bitops.h:239 ./include/asm-generic/bitops/instrumented-non-atomic.h:142 kernel/locking/lockdep.c:228) [ 57.181894][ C2] ? check_prev_add (kernel/locking/lockdep.c:3172) [ 57.182157][ C2] __tcf_classify (./include/net/tc_wrapper.h:197 net/sched/cls_api.c:1734) [ 57.182402][ C2] tcf_classify (net/sched/cls_api.c:1830) [ 57.182646][ C2] ? __pfx_tcf_classify (net/sched/cls_api.c:1779) [ 57.182918][ C2] ? __dev_queue_xmit (./include/linux/bottom_half.h:20 ./include/linux/rcupdate.h:802 net/core/dev.c:4284) [ 57.183198][ C2] ? lock_acquire.part.0 (kernel/locking/lockdep.c:467 kernel/locking/lockdep.c:5756) [ 57.183471][ C2] ? __dev_queue_xmit (./include/linux/bottom_half.h:20 ./include/linux/rcupdate.h:802 net/core/dev.c:4284) [ 57.183771][ C2] tc_run (net/core/dev.c:3945) [ 57.184002][ C2] ? __pfx_tc_run (net/core/dev.c:3929) [ 57.184248][ C2] ? lock_acquire (./include/trace/events/lock.h:24 kernel/locking/lockdep.c:5725) [ 57.184490][ C2] ? __dev_queue_xmit (./include/linux/bottom_half.h:20 ./include/linux/rcupdate.h:802 net/core/dev.c:4284) [ 57.184766][ C2] __dev_queue_xmit (net/core/dev.c:4069 net/core/dev.c:4301) [ 57.185043][ C2] ? mark_held_locks (kernel/locking/lockdep.c:4274) [ 57.185305][ C2] ? lockdep_hardirqs_on_prepare.part.0 (kernel/locking/lockdep.c:4292 kernel/locking/lockdep.c:4359) [ 57.185664][ C2] ? __pfx___dev_queue_xmit (net/core/dev.c:4268) [ 57.185962][ C2] ? neigh_hh_output (./include/linux/seqlock.h:74 ./include/linux/seqlock.h:772 ./include/net/neighbour.h:496) [ 57.186238][ C2] ip_finish_output2 (./include/net/neighbour.h:540 net/ipv4/ip_output.c:235) [ 57.186530][ C2] ? __pfx_ip_finish_output2 (net/ipv4/ip_output.c:199) [ 57.186839][ C2] ? __ip_finish_output (./include/linux/skbuff.h:1619 ./include/linux/skbuff.h:4884 net/ipv4/ip_output.c:307 net/ipv4/ip_output.c:295) [ 57.187133][ C2] ip_output (./include/linux/netfilter.h:303 net/ipv4/ip_output.c:433) [ 57.187357][ C2] ? __pfx_ip_output (net/ipv4/ip_output.c:427) [ 57.187634][ C2] ? __pfx_lock_acquire.part.0 (kernel/locking/lockdep.c:5719) [ 57.187960][ C2] ? ip_local_out (./include/linux/skbuff.h:1131 ./include/net/dst.h:450 net/ipv4/ip_output.c:129) [ 57.188211][ C2] __ip_queue_xmit (net/ipv4/ip_output.c:535 (discriminator 4)) [ 57.188468][ C2] ? __create_object (mm/kmemleak.c:756) [ 57.188734][ C2] __tcp_transmit_skb (net/ipv4/tcp_output.c:1462 (discriminator 4)) [ 57.189007][ C2] ? __pfx___tcp_transmit_skb (net/ipv4/tcp_output.c:1283) [ 57.189316][ C2] ? __tcp_send_ack.part.0 (./include/linux/skbuff.h:1296 net/ipv4/tcp_output.c:4206) [ 57.189608][ C2] tcp_rcv_state_process (net/ipv4/tcp_input.c:6874) [ 57.189923][ C2] ? tcp_v4_rcv (./include/linux/skbuff.h:1619 ./include/net/tcp.h:2510 net/ipv4/tcp_ipv4.c:2326) [ 57.190179][ C2] ? hlock_class (./arch/x86/include/asm/bitops.h:227 ./arch/x86/include/asm/bitops.h:239 ./include/asm-generic/bitops/instrumented-non-atomic.h:142 kernel/locking/lockdep.c:228) [ 57.190426][ C2] ? __lock_acquired (kernel/locking/lockdep.c:339 kernel/locking/lockdep.c:5991) [ 57.190722][ C2] ? __pfx_tcp_rcv_state_process (net/ipv4/tcp_input.c:6620) [ 57.191023][ C2] ? __pfx___lock_acquired (kernel/locking/lockdep.c:5959) [ 57.191306][ C2] ? __pfx_do_raw_spin_trylock (kernel/locking/spinlock_debug.c:122) [ 57.191598][ C2] tcp_v4_do_rcv (net/ipv4/tcp_ipv4.c:1929) [ 57.191916][ C2] tcp_v4_rcv (net/ipv4/tcp_ipv4.c:2329) [ 57.192184][ C2] ? __pfx_tcp_v4_rcv (net/ipv4/tcp_ipv4.c:2162) [ 57.192464][ C2] ? __pfx_raw_v4_input (net/ipv4/raw.c:165) [ 57.192751][ C2] ? __pfx_lock_acquire.part.0 (kernel/locking/lockdep.c:5719) [ 57.193051][ C2] ip_protocol_deliver_rcu (net/ipv4/ip_input.c:207 (discriminator 8)) [ 57.193354][ C2] ip_local_deliver_finish (./include/linux/rcupdate.h:779 net/ipv4/ip_input.c:234) [ 57.193651][ C2] ip_local_deliver (./include/linux/netfilter.h:314 ./include/linux/netfilter.h:308 net/ipv4/ip_input.c:254) [ 57.193921][ C2] ? __pfx_ip_local_deliver (net/ipv4/ip_input.c:243) [ 57.194212][ C2] ? tcp_v4_early_demux (./include/linux/skbuff.h:1163 net/ipv4/tcp_ipv4.c:1988) [ 57.194497][ C2] ? ip_rcv_finish_core.constprop.0 (./include/linux/skbuff.h:1131 ./include/linux/skbuff.h:1183 net/ipv4/ip_input.c:390) [ 57.194860][ C2] ip_rcv (./include/net/dst.h:460 net/ipv4/ip_input.c:449 ./include/linux/netfilter.h:314 ./include/linux/netfilter.h:308 net/ipv4/ip_input.c:569) [ 57.195087][ C2] ? __pfx_ip_rcv (net/ipv4/ip_input.c:562) [ 57.195340][ C2] ? lock_acquire.part.0 (kernel/locking/lockdep.c:467 kernel/locking/lockdep.c:5756) [ 57.195641][ C2] ? process_backlog (./include/linux/rcupdate.h:298 ./include/linux/rcupdate.h:750 net/core/dev.c:5983) [ 57.195909][ C2] ? __pfx_ip_rcv (net/ipv4/ip_input.c:562) [ 57.196176][ C2] __netif_receive_skb_one_core (net/core/dev.c:5542 (discriminator 4)) [ 57.196485][ C2] ? __pfx___netif_receive_skb_one_core (net/core/dev.c:5535) [ 57.196835][ C2] ? __pfx_do_raw_spin_trylock (kernel/locking/spinlock_debug.c:122) [ 57.197145][ C2] ? lock_acquire (./include/trace/events/lock.h:24 kernel/locking/lockdep.c:5725) [ 57.197410][ C2] ? process_backlog (./include/linux/rcupdate.h:298 ./include/linux/rcupdate.h:750 net/core/dev.c:5983) [ 57.197664][ C2] process_backlog (./include/linux/rcupdate.h:779 net/core/dev.c:5985) [ 57.197932][ C2] __napi_poll.constprop.0 (net/core/dev.c:6584) [ 57.198225][ C2] net_rx_action (net/core/dev.c:6653 net/core/dev.c:6786) [ 57.198469][ C2] ? __pfx_net_rx_action (net/core/dev.c:6750) [ 57.198759][ C2] ? kvm_clock_get_cycles (./arch/x86/include/asm/preempt.h:94 arch/x86/kernel/kvmclock.c:80 arch/x86/kernel/kvmclock.c:86) [ 57.199044][ C2] ? ktime_get (kernel/time/timekeeping.c:195 (discriminator 4) kernel/time/timekeeping.c:289 (discriminator 4) kernel/time/timekeeping.c:388 (discriminator 4) kernel/time/timekeeping.c:848 (discriminator 4)) [ 57.199272][ C2] ? hrtimer_interrupt (kernel/time/hrtimer.c:1827) [ 57.199556][ C2] ? hrtimer_interrupt (kernel/time/hrtimer.c:1827) [ 57.199904][ C2] __do_softirq (kernel/softirq.c:553) [ 57.200160][ C2] ? tcp_recvmsg (net/ipv4/tcp.c:2580) [ 57.200407][ C2] do_softirq (kernel/softirq.c:454 kernel/softirq.c:441) [ 57.200635][ C2] [ 57.200809][ C2] [ 57.200966][ C2] __local_bh_enable_ip (kernel/softirq.c:381) [ 57.201253][ C2] tcp_recvmsg (net/ipv4/tcp.c:2580) [ 57.201475][ C2] ? __pfx_tcp_recvmsg (net/ipv4/tcp.c:2564) [ 57.201750][ C2] ? core_sys_select (./arch/x86/include/asm/smap.h:33 ./arch/x86/include/asm/uaccess_64.h:120 ./arch/x86/include/asm/uaccess_64.h:133 ./include/linux/uaccess.h:138 fs/select.c:404 fs/select.c:401 fs/select.c:693) [ 57.202025][ C2] ? __pfx_core_sys_select (fs/select.c:627) [ 57.202309][ C2] inet_recvmsg (net/ipv4/af_inet.c:884 (discriminator 8)) [ 57.202553][ C2] ? __pfx_inet_recvmsg (net/ipv4/af_inet.c:874) [ 57.202831][ C2] ? __fget_light (./include/linux/atomic/atomic-arch-fallback.h:479 ./include/linux/atomic/atomic-instrumented.h:50 fs/file.c:1145) [ 57.203086][ C2] ? sockfd_lookup_light (net/socket.c:558) [ 57.203390][ C2] __sys_recvfrom (net/socket.c:1046 net/socket.c:1068 net/socket.c:2242) [ 57.203658][ C2] ? __pfx___sys_recvfrom (net/socket.c:2223) [ 57.203970][ C2] ? __pfx___lock_release (kernel/locking/lockdep.c:5406) [ 57.204251][ C2] ? do_pselect.constprop.0 (fs/select.c:764) [ 57.204557][ C2] ? __pfx_do_pselect.constprop.0 (fs/select.c:732) [ 57.204890][ C2] ? restore_fpregs_from_fpstate (arch/x86/kernel/fpu/xstate.h:202 arch/x86/kernel/fpu/core.c:181) [ 57.205230][ C2] ? __pfx_restore_fpregs_from_fpstate (arch/x86/kernel/fpu/core.c:137) [ 57.205583][ C2] __x64_sys_recvfrom (net/socket.c:2256) [ 57.205855][ C2] ? lockdep_hardirqs_on_prepare.part.0 (kernel/locking/lockdep.c:4300 kernel/locking/lockdep.c:4359) [ 57.206210][ C2] do_syscall_64 (arch/x86/entry/common.c:52 arch/x86/entry/common.c:83) [ 57.206460][ C2] entry_SYSCALL_64_after_hwframe (arch/x86/entry/entry_64.S:129) [ 57.206790][ C2] RIP: 0033:0x7fc19e2174c0 [ 57.207022][ C2] Code: 84 00 00 00 00 00 0f 1f 40 00 f3 0f 1e fa 41 89 ca 64 8b 04 25 18 00 00 00 85 c0 75 1d 45 31 c9 45 31 c0 b8 2d 00 00 00 0f 05 <48> 3d 00 f0 ff ff 77 68 c3 0f 1f 80 00 00 00 00 41 54 48 83 ec 20 All code ======== 0: 84 00 test %al,(%rax) 2: 00 00 add %al,(%rax) 4: 00 00 add %al,(%rax) 6: 0f 1f 40 00 nopl 0x0(%rax) a: f3 0f 1e fa endbr64 e: 41 89 ca mov %ecx,%r10d 11: 64 8b 04 25 18 00 00 mov %fs:0x18,%eax 18: 00 19: 85 c0 test %eax,%eax 1b: 75 1d jne 0x3a 1d: 45 31 c9 xor %r9d,%r9d 20: 45 31 c0 xor %r8d,%r8d 23: b8 2d 00 00 00 mov $0x2d,%eax 28: 0f 05 syscall 2a:* 48 3d 00 f0 ff ff cmp $0xfffffffffffff000,%rax <-- trapping instruction 30: 77 68 ja 0x9a 32: c3 ret 33: 0f 1f 80 00 00 00 00 nopl 0x0(%rax) 3a: 41 54 push %r12 3c: 48 83 ec 20 sub $0x20,%rsp Code starting with the faulting instruction =========================================== 0: 48 3d 00 f0 ff ff cmp $0xfffffffffffff000,%rax 6: 77 68 ja 0x70 8: c3 ret 9: 0f 1f 80 00 00 00 00 nopl 0x0(%rax) 10: 41 54 push %r12 12: 48 83 ec 20 sub $0x20,%rsp [ 57.208032][ C2] RSP: 002b:00007ffdd9477f58 EFLAGS: 00000246 ORIG_RAX: 000000000000002d [ 57.208460][ C2] RAX: ffffffffffffffda RBX: 000056394474aa20 RCX: 00007fc19e2174c0 [ 57.208869][ C2] RDX: 0000000000002000 RSI: 00007ffdd9477fe0 RDI: 0000000000000008 [ 57.209298][ C2] RBP: 00007ffdd9477fe0 R08: 0000000000000000 R09: 0000000000000000 [ 57.209721][ C2] R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000000008 Finger prints: dump_stack_lvl:validate_chain:__lock_acquire:_raw_spin_lock_nested