====================================== | xx__-> echo $? | 0 | xx__-> [ 31.786710][ C0] BUG: spinlock bad magic on CPU#0, tc/302 | [ 31.786999][ C0] lock: noop_qdisc+0x240/0x300, .magic: 00000000, .owner: tc/302, .owner_cpu: 0 [ 31.787725][ C0] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS rel-1.16.3-0-ga6ed6b701f0a-prebuilt.qemu.org 04/01/2014 [ 31.788208][ C0] Call Trace: [ 31.788376][ C0] [ 31.788495][ C0] dump_stack_lvl (lib/dump_stack.c:122) [ 31.788723][ C0] do_raw_spin_unlock (kernel/locking/spinlock_debug.c:100 kernel/locking/spinlock_debug.c:141) [ 31.788941][ C0] _raw_spin_unlock (./arch/x86/include/asm/preempt.h:94 ./include/linux/spinlock_api_smp.h:143 kernel/locking/spinlock.c:186) [ 31.789159][ C0] net_tx_action (./include/net/sch_generic.h:226 ./include/net/sch_generic.h:217 ./include/net/pkt_sched.h:128 ./include/net/pkt_sched.h:124 net/core/dev.c:5323) [ 31.789375][ C0] handle_softirqs (kernel/softirq.c:554) [ 31.789594][ C0] ? dev_deactivate_many (./include/linux/bottom_half.h:33 ./include/linux/netdevice.h:4448 net/sched/sch_generic.c:571 net/sched/sch_generic.c:1363) [ 31.789817][ C0] do_softirq (kernel/softirq.c:455 kernel/softirq.c:442) [ 31.789977][ C0] [ 31.790091][ C0] [ 31.790201][ C0] __local_bh_enable_ip (kernel/softirq.c:382) [ 31.790418][ C0] dev_deactivate_many (net/sched/sch_generic.c:1356) [ 31.790634][ C0] ? __pfx___lock_release (kernel/locking/lockdep.c:5411) [ 31.790848][ C0] dev_deactivate (./include/linux/list.h:111 ./include/linux/list.h:215 ./include/linux/list.h:229 net/sched/sch_generic.c:1398) [ 31.791061][ C0] ? __pfx_dev_deactivate (net/sched/sch_generic.c:1393) [ 31.791275][ C0] qdisc_graft (net/sched/sch_api.c:1137) [ 31.791495][ C0] ? qdisc_create (net/sched/sch_api.c:1257) [ 31.791713][ C0] ? __pfx_qdisc_graft (net/sched/sch_api.c:1105) [ 31.791927][ C0] ? __pfx_qdisc_create (net/sched/sch_api.c:1257) [ 31.792151][ C0] tc_modify_qdisc (net/sched/sch_api.c:1789) [ 31.792368][ C0] ? trace_contention_end (./include/trace/events/lock.h:122 (discriminator 52)) [ 31.792583][ C0] ? __pfx_tc_modify_qdisc (net/sched/sch_api.c:1604) [ 31.792801][ C0] ? __mutex_lock (./arch/x86/include/asm/preempt.h:94 kernel/locking/mutex.c:618 kernel/locking/mutex.c:752) [ 31.793019][ C0] ? trace_lock_acquire (./include/trace/events/lock.h:24 (discriminator 52)) [ 31.793248][ C0] rtnetlink_rcv_msg (net/core/rtnetlink.c:6647) [ 31.793465][ C0] ? __pfx_rtnetlink_rcv_msg (net/core/rtnetlink.c:6541) [ 31.793681][ C0] ? 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:227) [ 31.793900][ C0] ? mark_lock (kernel/locking/lockdep.c:4655 (discriminator 3)) [ 31.794057][ C0] ? __lock_acquire (kernel/locking/lockdep.c:5142) [ 31.794267][ C0] netlink_rcv_skb (net/netlink/af_netlink.c:2550) [ 31.794488][ C0] ? __pfx_rtnetlink_rcv_msg (net/core/rtnetlink.c:6541) [ 31.794707][ C0] ? __pfx_netlink_rcv_skb (net/netlink/af_netlink.c:2527) [ 31.794929][ C0] ? netlink_deliver_tap (./include/linux/rcupdate.h:336 ./include/linux/rcupdate.h:869 net/netlink/af_netlink.c:340) [ 31.795142][ C0] ? netlink_deliver_tap (./include/linux/rcupdate.h:336 ./include/linux/rcupdate.h:869 ./include/net/netns/generic.h:48 net/netlink/af_netlink.c:333) [ 31.795363][ C0] netlink_unicast (net/netlink/af_netlink.c:1331 net/netlink/af_netlink.c:1357) [ 31.795581][ C0] ? __pfx_netlink_unicast (net/netlink/af_netlink.c:1342) [ 31.795793][ C0] ? find_held_lock (kernel/locking/lockdep.c:5249) [ 31.796007][ C0] netlink_sendmsg (net/netlink/af_netlink.c:1901) [ 31.796226][ C0] ? __pfx_netlink_sendmsg (net/netlink/af_netlink.c:1820) [ 31.796445][ C0] ? __might_fault (mm/memory.c:6388 mm/memory.c:6381) [ 31.796658][ C0] ? __import_iovec (lib/iov_iter.c:1263 lib/iov_iter.c:1279) [ 31.796881][ C0] ____sys_sendmsg (net/socket.c:730 net/socket.c:745 net/socket.c:2597) [ 31.797102][ C0] ? __pfx_____sys_sendmsg (net/socket.c:2543) [ 31.797319][ C0] ? __pfx_copy_msghdr_from_user (net/socket.c:2523) [ 31.797598][ C0] ___sys_sendmsg (net/socket.c:2653) [ 31.797811][ C0] ? __pfx____sys_sendmsg (net/socket.c:2640) [ 31.798031][ C0] ? kfree (mm/slub.c:4583) [ 31.798199][ C0] ? ___sys_recvmsg (net/socket.c:2848) [ 31.798417][ C0] ? __pfx____sys_recvmsg (net/socket.c:2848) [ 31.798634][ C0] ? reacquire_held_locks (kernel/locking/lockdep.c:5284) [ 31.798850][ C0] ? do_user_addr_fault (./include/linux/rcupdate.h:326 ./include/linux/rcupdate.h:838 ./include/linux/mm.h:713 arch/x86/mm/fault.c:1340) [ 31.799073][ C0] ? __fget_light (./include/linux/atomic/atomic-arch-fallback.h:479 ./include/linux/atomic/atomic-instrumented.h:50 fs/file.c:1145) [ 31.799293][ C0] __sys_sendmsg (./include/linux/file.h:34 net/socket.c:2682) [ 31.799510][ C0] ? __pfx___sys_sendmsg (net/socket.c:2668) [ 31.799726][ C0] ? __pfx___up_read (kernel/locking/rwsem.c:1339) [ 31.799953][ C0] do_syscall_64 (arch/x86/entry/common.c:52 arch/x86/entry/common.c:83) [ 31.800170][ C0] entry_SYSCALL_64_after_hwframe (arch/x86/entry/entry_64.S:130) [ 31.800437][ C0] RIP: 0033:0x7fc38fcc17b7 [ 31.800665][ C0] Code: 0a 00 f7 d8 64 89 02 48 c7 c0 ff ff ff ff eb b9 0f 1f 00 f3 0f 1e fa 64 8b 04 25 18 00 00 00 85 c0 75 10 b8 2e 00 00 00 0f 05 <48> 3d 00 f0 ff ff 77 51 c3 48 83 ec 28 89 54 24 1c 48 89 74 24 10 All code ======== 0: 0a 00 or (%rax),%al 2: f7 d8 neg %eax 4: 64 89 02 mov %eax,%fs:(%rdx) 7: 48 c7 c0 ff ff ff ff mov $0xffffffffffffffff,%rax e: eb b9 jmp 0xffffffffffffffc9 10: 0f 1f 00 nopl (%rax) 13: f3 0f 1e fa endbr64 17: 64 8b 04 25 18 00 00 mov %fs:0x18,%eax 1e: 00 1f: 85 c0 test %eax,%eax 21: 75 10 jne 0x33 23: b8 2e 00 00 00 mov $0x2e,%eax 28: 0f 05 syscall 2a:* 48 3d 00 f0 ff ff cmp $0xfffffffffffff000,%rax <-- trapping instruction 30: 77 51 ja 0x83 32: c3 ret 33: 48 83 ec 28 sub $0x28,%rsp 37: 89 54 24 1c mov %edx,0x1c(%rsp) 3b: 48 89 74 24 10 mov %rsi,0x10(%rsp) Code starting with the faulting instruction =========================================== 0: 48 3d 00 f0 ff ff cmp $0xfffffffffffff000,%rax 6: 77 51 ja 0x59 8: c3 ret 9: 48 83 ec 28 sub $0x28,%rsp d: 89 54 24 1c mov %edx,0x1c(%rsp) 11: 48 89 74 24 10 mov %rsi,0x10(%rsp) [ 31.801425][ C0] RSP: 002b:00007ffd46d71c38 EFLAGS: 00000246 ORIG_RAX: 000000000000002e [ 31.801756][ C0] RAX: ffffffffffffffda RBX: 0000000000000001 RCX: 00007fc38fcc17b7 [ 31.802085][ C0] RDX: 0000000000000000 RSI: 00007ffd46d71ca0 RDI: 0000000000000005 [ 31.802407][ C0] RBP: 000000000047d6a0 R08: 0000000000000014 R09: 0000000000000000 [ 31.802739][ C0] R10: 00007fc38fb7a708 R11: 0000000000000246 R12: 00007ffd46d81f60 Finger prints: do_raw_spin_unlock:_raw_spin_unlock:net_tx_action:handle_softirqs:do_softirq