====================================== | [ 1263.117607][ T4311] rcu_scheduler_active = 2, debug_locks = 1 | [ 1263.117991][ T4311] no locks held by smcrouted/4311. | [ 1263.118259][ T4311] | [ 1263.118259][ T4311] stack backtrace: [ 1263.119047][ T4311] Hardware name: Bochs Bochs, BIOS Bochs 01/01/2011 [ 1263.119364][ T4311] Call Trace: [ 1263.119567][ T4311] [ 1263.119703][ T4311] dump_stack_lvl (lib/dump_stack.c:123) [ 1263.119967][ T4311] lockdep_rcu_suspicious (kernel/locking/lockdep.c:6822) [ 1263.120229][ T4311] ip6mr_get_table (net/ipv6/ip6mr.c:132 (discriminator 11)) [ 1263.120491][ T4311] ip6_mroute_setsockopt (net/ipv6/ip6mr.c:1670) [ 1263.120754][ T4311] ? __pfx_ip6_mroute_setsockopt (net/ipv6/ip6mr.c:1658) [ 1263.121073][ T4311] ? __lock_release (kernel/locking/lockdep.c:5501) [ 1263.121320][ T4311] ? __might_fault (mm/memory.c:6716 mm/memory.c:6709) [ 1263.121575][ T4311] ? trace_lock_acquire (./include/trace/events/lock.h:24 (discriminator 52)) [ 1263.121844][ T4311] ? __might_fault (mm/memory.c:6716 mm/memory.c:6709) [ 1263.122089][ T4311] ? lock_acquire (kernel/locking/lockdep.c:5798) [ 1263.122334][ T4311] ? __might_fault (mm/memory.c:6716 mm/memory.c:6709) [ 1263.122595][ T4311] ? __might_fault (mm/memory.c:6716 mm/memory.c:6709) [ 1263.122858][ T4311] do_ipv6_setsockopt (net/ipv6/ipv6_sockglue.c:415) [ 1263.123114][ T4311] ? __lock_release (kernel/locking/lockdep.c:5486) [ 1263.123366][ T4311] ? __pfx_do_ipv6_setsockopt (net/ipv6/ipv6_sockglue.c:395) [ 1263.123610][ T4311] ? __pfx_lock_acquire.part.0 (kernel/locking/lockdep.c:5790) [ 1263.123872][ T4311] ? rcu_read_lock_any_held (kernel/rcu/update.c:386 kernel/rcu/update.c:380) [ 1263.124134][ T4311] ? validate_chain (kernel/locking/lockdep.c:3797 kernel/locking/lockdep.c:3817 kernel/locking/lockdep.c:3872) [ 1263.124385][ T4311] ? is_bpf_text_address (./include/linux/rcupdate.h:347 ./include/linux/rcupdate.h:880 kernel/bpf/core.c:769) [ 1263.124648][ T4311] ? __pfx_validate_chain (kernel/locking/lockdep.c:3860) [ 1263.124896][ T4311] ? 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) [ 1263.125160][ T4311] ? mark_lock (kernel/locking/lockdep.c:4703 (discriminator 3)) [ 1263.125360][ T4311] ? __lock_acquire (kernel/locking/lockdep.c:5202) [ 1263.125634][ T4311] ? find_held_lock (kernel/locking/lockdep.c:5315) [ 1263.125903][ T4311] ? ipv6_setsockopt (net/ipv6/ipv6_sockglue.c:996) [ 1263.126154][ T4311] ipv6_setsockopt (net/ipv6/ipv6_sockglue.c:996) [ 1263.126415][ T4311] rawv6_setsockopt (net/ipv6/raw.c:1054) [ 1263.126672][ T4311] ? __pfx_rawv6_setsockopt (net/ipv6/raw.c:1039) [ 1263.126916][ T4311] ? __lock_acquire (kernel/locking/lockdep.c:5202) [ 1263.127175][ T4311] ? kfree (mm/slub.c:4716) [ 1263.127377][ T4311] do_sock_setsockopt (net/socket.c:2336) [ 1263.127630][ T4311] ? __pfx_do_sock_setsockopt (net/socket.c:2305) [ 1263.127885][ T4311] ? __lock_release (kernel/locking/lockdep.c:5501) [ 1263.128135][ T4311] ? fd_install (./include/linux/rcupdate.h:347 ./include/linux/rcupdate.h:962 fs/file.c:612) [ 1263.128390][ T4311] ? trace_lock_acquire (./include/trace/events/lock.h:24 (discriminator 52)) [ 1263.128650][ T4311] ? fdget (./include/linux/atomic/atomic-arch-fallback.h:479 ./include/linux/atomic/atomic-instrumented.h:50 fs/file.c:1114 fs/file.c:1128) [ 1263.128852][ T4311] __sys_setsockopt (./include/linux/file.h:35 net/socket.c:2361) [ 1263.129112][ T4311] ? __pfx___sys_setsockopt (net/socket.c:2349) [ 1263.129378][ T4311] ? __sys_socket (net/socket.c:496 net/socket.c:1727) [ 1263.129640][ T4311] ? __pfx___sys_socket (net/socket.c:1714) [ 1263.129915][ T4311] ? do_user_addr_fault (./include/linux/mmap_lock.h:172 arch/x86/mm/fault.c:1417) [ 1263.130198][ T4311] __x64_sys_setsockopt (net/socket.c:2365) [ 1263.130452][ T4311] ? lockdep_hardirqs_on_prepare (kernel/locking/lockdep.c:4347 kernel/locking/lockdep.c:4406) [ 1263.130783][ T4311] do_syscall_64 (arch/x86/entry/common.c:52 arch/x86/entry/common.c:83) [ 1263.131040][ T4311] entry_SYSCALL_64_after_hwframe (arch/x86/entry/entry_64.S:130) [ 1263.131384][ T4311] RIP: 0033:0x7f420c7b991e [ 1263.131654][ T4311] Code: 0f 1f 40 00 48 8b 15 e1 94 0a 00 f7 d8 64 89 02 48 c7 c0 ff ff ff ff eb b1 0f 1f 00 f3 0f 1e fa 49 89 ca b8 36 00 00 00 0f 05 <48> 3d 00 f0 ff ff 77 0a c3 66 0f 1f 84 00 00 00 00 00 48 8b 15 a9 All code ======== 0: 0f 1f 40 00 nopl 0x0(%rax) 4: 48 8b 15 e1 94 0a 00 mov 0xa94e1(%rip),%rdx # 0xa94ec b: f7 d8 neg %eax d: 64 89 02 mov %eax,%fs:(%rdx) 10: 48 c7 c0 ff ff ff ff mov $0xffffffffffffffff,%rax 17: eb b1 jmp 0xffffffffffffffca 19: 0f 1f 00 nopl (%rax) 1c: f3 0f 1e fa endbr64 20: 49 89 ca mov %rcx,%r10 23: b8 36 00 00 00 mov $0x36,%eax 28: 0f 05 syscall 2a:* 48 3d 00 f0 ff ff cmp $0xfffffffffffff000,%rax <-- trapping instruction 30: 77 0a ja 0x3c 32: c3 ret 33: 66 0f 1f 84 00 00 00 nopw 0x0(%rax,%rax,1) 3a: 00 00 3c: 48 rex.W 3d: 8b .byte 0x8b 3e: 15 .byte 0x15 3f: a9 .byte 0xa9 Code starting with the faulting instruction =========================================== 0: 48 3d 00 f0 ff ff cmp $0xfffffffffffff000,%rax 6: 77 0a ja 0x12 8: c3 ret 9: 66 0f 1f 84 00 00 00 nopw 0x0(%rax,%rax,1) 10: 00 00 12: 48 rex.W 13: 8b .byte 0x8b 14: 15 .byte 0x15 15: a9 .byte 0xa9 [ 1263.132525][ T4311] RSP: 002b:00007ffdaf4099d8 EFLAGS: 00000246 ORIG_RAX: 0000000000000036 [ 1263.132922][ T4311] RAX: ffffffffffffffda RBX: 0000000000000000 RCX: 00007f420c7b991e [ 1263.133292][ T4311] RDX: 00000000000000c8 RSI: 0000000000000029 RDI: 0000000000000008 [ 1263.133657][ T4311] RBP: 0000000000000008 R08: 0000000000000004 R09: 000000003bcf4010 [ 1263.134033][ T4311] R10: 00007ffdaf4099fc R11: 0000000000000246 R12: 0000000000000000 Finger prints: lockdep_rcu_suspicious:ip6mr_get_table:ip6_mroute_setsockopt:do_ipv6_setsockopt:ipv6_setsockopt