====================================== | xx__-> [ 16.702228][ T70] ================================================================== | [ 16.702702][ T70] BUG: KASAN: slab-use-after-free in kobject_put (lib/kobject.c:733) | [ 16.703114][ T70] Read of size 1 at addr ffff888008101694 by task kworker/u16:1/70 | [ 16.703499][ T70] [ 16.703703][ T70] Hardware name: Bochs Bochs, BIOS Bochs 01/01/2011 [ 16.703707][ T70] Workqueue: netns cleanup_net [ 16.703720][ T70] Call Trace: [ 16.703725][ T70] [ 16.703729][ T70] dump_stack_lvl (lib/dump_stack.c:123) [ 16.703742][ T70] print_address_description.constprop.0 (mm/kasan/report.c:379) [ 16.703757][ T70] ? kobject_put (lib/kobject.c:733) [ 16.703764][ T70] print_report (mm/kasan/report.c:483) [ 16.703770][ T70] ? kobject_put (lib/kobject.c:733) [ 16.703774][ T70] ? kasan_addr_to_slab (./include/linux/mm.h:1245 mm/kasan/../slab.h:191 mm/kasan/common.c:47) [ 16.703781][ T70] ? kobject_put (lib/kobject.c:733) [ 16.703786][ T70] kasan_report (mm/kasan/report.c:597) [ 16.703793][ T70] ? kobject_put (lib/kobject.c:733) [ 16.703803][ T70] kobject_put (lib/kobject.c:733) [ 16.703808][ T70] netdev_run_todo (./include/linux/list.h:381 net/core/dev.c:11670) [ 16.703818][ T70] ? dev_ingress_queue_create (net/core/dev.c:12299) [ 16.703824][ T70] ? generic_xdp_install (net/core/dev.c:11630) [ 16.703837][ T70] ops_undo_list (net/core/net_namespace.c:190 net/core/net_namespace.c:248) [ 16.703845][ T70] ? netns_get (net/core/net_namespace.c:223) [ 16.703848][ T70] ? cleanup_net (./include/linux/list.h:191 net/core/net_namespace.c:693) [ 16.703858][ T70] cleanup_net (net/core/net_namespace.c:698) [ 16.703865][ T70] ? net_passive_dec (net/core/net_namespace.c:660) [ 16.703871][ T70] ? rcu_is_watching (./include/linux/context_tracking.h:128 kernel/rcu/tree.c:751) [ 16.703883][ T70] process_one_work (kernel/workqueue.c:3268) [ 16.703898][ T70] ? pwq_dec_nr_in_flight (kernel/workqueue.c:3165) [ 16.703907][ T70] ? assign_work (kernel/workqueue.c:1206) [ 16.703918][ T70] worker_thread (kernel/workqueue.c:3340 kernel/workqueue.c:3427) [ 16.703927][ T70] ? rescuer_thread (kernel/workqueue.c:3373) [ 16.703933][ T70] kthread (kernel/kthread.c:463) [ 16.703939][ T70] ? kthread_is_per_cpu (kernel/kthread.c:412) [ 16.703943][ T70] ? ret_from_fork (arch/x86/kernel/process.c:157) [ 16.703953][ T70] ? __lock_release (kernel/locking/lockdep.c:5536) [ 16.703963][ T70] ? rcu_is_watching (./include/linux/context_tracking.h:128 kernel/rcu/tree.c:751) [ 16.703968][ T70] ? kthread_is_per_cpu (kernel/kthread.c:412) [ 16.703974][ T70] ret_from_fork (arch/x86/kernel/process.c:164) [ 16.703979][ T70] ? kthread_is_per_cpu (kernel/kthread.c:412) [ 16.703984][ T70] ret_from_fork_asm (arch/x86/entry/entry_64.S:255) | [ 16.733845][ T70] refcount_t: underflow; use-after-free. | [ 16.734181][ T70] WARNING: CPU: 2 PID: 70 at lib/refcount.c:28 refcount_warn_saturate (lib/refcount.c:28 (discriminator 3)) | [ 16.734658][ T70] Modules linked in: veth | [ 16.735511][ T70] Tainted: [B]=BAD_PAGE [ 16.735741][ T70] Hardware name: Bochs Bochs, BIOS Bochs 01/01/2011 [ 16.736113][ T70] Workqueue: netns cleanup_net [ 16.736413][ T70] RIP: 0010:refcount_warn_saturate (lib/refcount.c:28 (discriminator 3)) [ 16.736769][ T70] Code: 48 92 02 80 fb 01 0f 87 cb 7d d9 fe 83 e3 01 0f 85 51 ff ff ff c6 05 75 48 92 02 01 90 48 c7 c7 a0 8d 05 bc e8 42 93 18 ff 90 <0f> 0b 90 90 e9 33 ff ff ff 48 89 df e8 c0 37 a1 ff e9 ba fe ff ff All code ======== 0: 48 92 xchg %rax,%rdx 2: 02 80 fb 01 0f 87 add -0x78f0fe05(%rax),%al 8: cb lret 9: 7d d9 jge 0xffffffffffffffe4 b: fe 83 e3 01 0f 85 incb -0x7af0fe1d(%rbx) 11: 51 push %rcx 12: ff (bad) 13: ff (bad) 14: ff c6 inc %esi 16: 05 75 48 92 02 add $0x2924875,%eax 1b: 01 90 48 c7 c7 a0 add %edx,-0x5f3838b8(%rax) 21: 8d 05 bc e8 42 93 lea -0x6cbd1744(%rip),%eax # 0xffffffff9342e8e3 27: 18 ff sbb %bh,%bh 29: 90 nop 2a:* 0f 0b ud2 <-- trapping instruction 2c: 90 nop 2d: 90 nop 2e: e9 33 ff ff ff jmp 0xffffffffffffff66 33: 48 89 df mov %rbx,%rdi 36: e8 c0 37 a1 ff call 0xffffffffffa137fb 3b: e9 ba fe ff ff jmp 0xfffffffffffffefa Code starting with the faulting instruction =========================================== 0: 0f 0b ud2 2: 90 nop 3: 90 nop 4: e9 33 ff ff ff jmp 0xffffffffffffff3c 9: 48 89 df mov %rbx,%rdi c: e8 c0 37 a1 ff call 0xffffffffffa137d1 11: e9 ba fe ff ff jmp 0xfffffffffffffed0 [ 16.737729][ T70] RSP: 0018:ffffc900004b7a08 EFLAGS: 00010282 [ 16.738102][ T70] RAX: 0000000000000000 RBX: 0000000000000000 RCX: 0000000000000000 [ 16.738509][ T70] RDX: 0000000000000002 RSI: 0000000000000004 RDI: 0000000000000001 [ 16.738922][ T70] RBP: 0000000000000003 R08: 0000000000000000 R09: fffffbfff793e134 [ 16.739353][ T70] R10: 0000000000000003 R11: ffffc900004b7580 R12: 0000000000000001 [ 16.739767][ T70] R13: dffffc0000000000 R14: dead000000000122 R15: dead000000000100 [ 16.740192][ T70] FS: 0000000000000000(0000) GS:ffff888078510000(0000) knlGS:0000000000000000 [ 16.740670][ T70] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 [ 16.741038][ T70] CR2: 00007f49901d51a0 CR3: 000000000c8fa002 CR4: 0000000000772ef0 [ 16.741453][ T70] PKRU: 55555554 [ 16.741680][ T70] Call Trace: [ 16.741908][ T70] [ 16.742076][ T70] netdev_run_todo (./include/linux/list.h:381 net/core/dev.c:11670) [ 16.742364][ T70] ? dev_ingress_queue_create (net/core/dev.c:12299) [ 16.742647][ T70] ? generic_xdp_install (net/core/dev.c:11630) [ 16.742938][ T70] ops_undo_list (net/core/net_namespace.c:190 net/core/net_namespace.c:248) [ 16.743233][ T70] ? netns_get (net/core/net_namespace.c:223) [ 16.743508][ T70] ? cleanup_net (./include/linux/list.h:191 net/core/net_namespace.c:693) [ 16.743812][ T70] cleanup_net (net/core/net_namespace.c:698) [ 16.744105][ T70] ? net_passive_dec (net/core/net_namespace.c:660) [ 16.744391][ T70] ? rcu_is_watching (./include/linux/context_tracking.h:128 kernel/rcu/tree.c:751) [ 16.744681][ T70] process_one_work (kernel/workqueue.c:3268) [ 16.744982][ T70] ? pwq_dec_nr_in_flight (kernel/workqueue.c:3165) [ 16.745302][ T70] ? assign_work (kernel/workqueue.c:1206) [ 16.745595][ T70] worker_thread (kernel/workqueue.c:3340 kernel/workqueue.c:3427) [ 16.745933][ T70] ? rescuer_thread (kernel/workqueue.c:3373) [ 16.746264][ T70] kthread (kernel/kthread.c:463) [ 16.746498][ T70] ? kthread_is_per_cpu (kernel/kthread.c:412) [ 16.746959][ T70] ? ret_from_fork (arch/x86/kernel/process.c:157) [ 16.747436][ T70] ? __lock_release (kernel/locking/lockdep.c:5536) [ 16.747851][ T70] ? rcu_is_watching (./include/linux/context_tracking.h:128 kernel/rcu/tree.c:751) [ 16.748327][ T70] ? kthread_is_per_cpu (kernel/kthread.c:412) [ 16.748746][ T70] ret_from_fork (arch/x86/kernel/process.c:164) [ 16.749150][ T70] ? kthread_is_per_cpu (kernel/kthread.c:412) Finger prints: print_report:kasan_report:kobject_put:netdev_run_todo:ops_undo_list refcount_warn_saturate:netdev_run_todo:ops_undo_list:cleanup_net:process_one_work