====================================== | [ 38.314702][ T287] 1 lock held by iptables/287: | [ 38.314881][ T287] #0: ffff8880062eb8c8 (&nft_net->commit_mutex){+.+.}-{3:3}, at: nf_tables_valid_genid (./include/linux/jiffies.h:101 net/netfilter/nf_tables_api.c:10954) nf_tables | [ 38.315353][ T287] | [ 38.315353][ T287] stack backtrace: [ 38.315822][ T287] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS rel-1.16.3-0-ga6ed6b701f0a-prebuilt.qemu.org 04/01/2014 [ 38.316201][ T287] Call Trace: [ 38.316345][ T287] [ 38.316451][ T287] dump_stack_lvl (lib/dump_stack.c:123) [ 38.316648][ T287] lockdep_rcu_suspicious (kernel/locking/lockdep.c:6822) [ 38.316839][ T287] __nft_rule_lookup (net/netfilter/nf_tables_api.c:3420 (discriminator 7)) nf_tables [ 38.317096][ T287] nf_tables_delrule (net/netfilter/nf_tables_api.c:4300) nf_tables [ 38.317361][ T287] ? __lock_release (kernel/locking/lockdep.c:5501) [ 38.317548][ T287] ? net_generic (./include/linux/rcupdate.h:347 ./include/linux/rcupdate.h:880 ./include/net/netns/generic.h:48) [ 38.317727][ T287] ? __pfx_nf_tables_delrule (net/netfilter/nf_tables_api.c:4262) nf_tables [ 38.317978][ T287] ? trace_lock_acquire (./include/trace/events/lock.h:24 (discriminator 52)) [ 38.318157][ T287] ? __nla_validate_parse (lib/nlattr.c:638) [ 38.318338][ T287] nfnetlink_rcv_batch (net/netfilter/nfnetlink.c:524) [ 38.318525][ T287] ? __pfx_nfnetlink_rcv_batch (net/netfilter/nfnetlink.c:373) [ 38.318704][ T287] ? rcu_read_lock_any_held (kernel/rcu/update.c:387 kernel/rcu/update.c:380) [ 38.318877][ T287] ? find_stack (lib/stackdepot.c:552 (discriminator 1)) [ 38.319058][ T287] ? rcu_read_lock_any_held (kernel/rcu/update.c:386 kernel/rcu/update.c:380) [ 38.319231][ T287] ? validate_chain (kernel/locking/lockdep.c:3797 kernel/locking/lockdep.c:3817 kernel/locking/lockdep.c:3872) [ 38.319421][ T287] ? __pfx_validate_chain (kernel/locking/lockdep.c:3860) [ 38.319599][ T287] ? __lock_acquire (kernel/locking/lockdep.c:5202) [ 38.319773][ T287] ? __pfx_validate_nla (lib/nlattr.c:396) [ 38.319951][ T287] ? find_held_lock (kernel/locking/lockdep.c:5315) [ 38.320129][ T287] ? __nla_validate_parse (lib/nlattr.c:638) [ 38.320307][ T287] nfnetlink_rcv (net/netfilter/nfnetlink.c:647 net/netfilter/nfnetlink.c:665) [ 38.320477][ T287] ? __pfx_nfnetlink_rcv (net/netfilter/nfnetlink.c:651) [ 38.320652][ T287] ? netlink_deliver_tap (./include/linux/rcupdate.h:347 ./include/linux/rcupdate.h:880 ./include/net/netns/generic.h:48 net/netlink/af_netlink.c:333) [ 38.320832][ T287] netlink_unicast (net/netlink/af_netlink.c:1331 net/netlink/af_netlink.c:1357) [ 38.321009][ T287] ? __pfx_netlink_unicast (net/netlink/af_netlink.c:1342) [ 38.321189][ T287] netlink_sendmsg (net/netlink/af_netlink.c:1901) [ 38.321365][ T287] ? __pfx_netlink_sendmsg (net/netlink/af_netlink.c:1820) [ 38.321539][ T287] ? __import_iovec (lib/iov_iter.c:1433 lib/iov_iter.c:1449) [ 38.321722][ T287] ____sys_sendmsg (net/socket.c:729 net/socket.c:744 net/socket.c:2607) [ 38.321897][ T287] ? __pfx_____sys_sendmsg (net/socket.c:2553) [ 38.322066][ T287] ? __pfx_copy_msghdr_from_user (net/socket.c:2533) [ 38.322287][ T287] ? sk_setsockopt (net/core/sock.c:1129 net/core/sock.c:1621) [ 38.322461][ T287] ? __local_bh_enable_ip (./arch/x86/include/asm/irqflags.h:42 ./arch/x86/include/asm/irqflags.h:97 kernel/softirq.c:387) [ 38.322639][ T287] ___sys_sendmsg (net/socket.c:2663) [ 38.322817][ T287] ? __pfx____sys_sendmsg (net/socket.c:2650) [ 38.322992][ T287] ? __lock_acquire (kernel/locking/lockdep.c:5202) [ 38.323165][ T287] ? usage_skip (kernel/locking/lockdep.c:2314 kernel/locking/lockdep.c:2282) [ 38.323337][ T287] ? trace_kfree (./include/trace/events/kmem.h:94 (discriminator 52)) [ 38.323510][ T287] ? kfree (mm/slub.c:4716) [ 38.323648][ T287] ? do_sock_setsockopt (net/socket.c:2303) [ 38.323818][ T287] ? __pfx_do_sock_setsockopt (net/socket.c:2303) [ 38.324005][ T287] ? fdget (./include/linux/atomic/atomic-arch-fallback.h:479 ./include/linux/atomic/atomic-instrumented.h:50 fs/file.c:1114 fs/file.c:1128) [ 38.324146][ T287] __sys_sendmsg (./include/linux/file.h:35 net/socket.c:2692) [ 38.324320][ T287] ? __pfx___sys_sendmsg (net/socket.c:2678) [ 38.324490][ T287] ? __sys_setsockopt (./include/linux/file.h:35 net/socket.c:2359) [ 38.324667][ T287] ? __pfx___sys_setsockopt (net/socket.c:2347) [ 38.324852][ T287] do_syscall_64 (arch/x86/entry/common.c:52 arch/x86/entry/common.c:83) [ 38.325032][ T287] entry_SYSCALL_64_after_hwframe (arch/x86/entry/entry_64.S:130) [ 38.325247][ T287] RIP: 0033:0x7f58df53c7b7 [ 38.325429][ T287] 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) [ 38.326022][ T287] RSP: 002b:00007ffcbc515658 EFLAGS: 00000246 ORIG_RAX: 000000000000002e [ 38.326296][ T287] RAX: ffffffffffffffda RBX: 00007ffcbc515660 RCX: 00007f58df53c7b7 [ 38.326551][ T287] RDX: 0000000000000000 RSI: 00007ffcbc5166f0 RDI: 000000000000000c [ 38.326810][ T287] RBP: 00007ffcbc516cf0 R08: 0000000000000004 R09: 0000000000000000 [ 38.327075][ T287] R10: 00007f58df63dbd8 R11: 0000000000000246 R12: 0000000000004000 Finger prints: lockdep_rcu_suspicious:__nft_rule_lookup:nf_tables_delrule:nfnetlink_rcv_batch:nfnetlink_rcv