* [PATCH v1 net] tipc: Fix use-after-free in tipc_mon_reinit_self().
@ 2025-11-06 5:32 Kuniyuki Iwashima
2025-11-06 9:38 ` [syzbot ci] " syzbot ci
0 siblings, 1 reply; 7+ messages in thread
From: Kuniyuki Iwashima @ 2025-11-06 5:32 UTC (permalink / raw)
To: Jon Maloy, David S. Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni
Cc: Simon Horman, Hoang Le, Kuniyuki Iwashima, Kuniyuki Iwashima,
netdev, tipc-discussion, syzbot+d7dad7fd4b3921104957
syzbot reported use-after-free of tipc_net(net)->monitors[]
in tipc_mon_reinit_self().
The array is protected by RTNL, but tipc_mon_reinit_self()
iterates over it without RTNL.
Let's hold RTNL in tipc_mon_reinit_self().
[0]:
BUG: KASAN: slab-use-after-free in __raw_spin_lock_irqsave include/linux/spinlock_api_smp.h:110 [inline]
BUG: KASAN: slab-use-after-free in _raw_spin_lock_irqsave+0xa7/0xf0 kernel/locking/spinlock.c:162
Read of size 1 at addr ffff88805eae1030 by task kworker/0:7/5989
CPU: 0 UID: 0 PID: 5989 Comm: kworker/0:7 Not tainted syzkaller #0 PREEMPT_{RT,(full)}
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 08/18/2025
Workqueue: events tipc_net_finalize_work
Call Trace:
<TASK>
dump_stack_lvl+0x189/0x250 lib/dump_stack.c:120
print_address_description mm/kasan/report.c:378 [inline]
print_report+0xca/0x240 mm/kasan/report.c:482
kasan_report+0x118/0x150 mm/kasan/report.c:595
__kasan_check_byte+0x2a/0x40 mm/kasan/common.c:568
kasan_check_byte include/linux/kasan.h:399 [inline]
lock_acquire+0x8d/0x360 kernel/locking/lockdep.c:5842
__raw_spin_lock_irqsave include/linux/spinlock_api_smp.h:110 [inline]
_raw_spin_lock_irqsave+0xa7/0xf0 kernel/locking/spinlock.c:162
rtlock_slowlock kernel/locking/rtmutex.c:1894 [inline]
rwbase_rtmutex_lock_state kernel/locking/spinlock_rt.c:160 [inline]
rwbase_write_lock+0xd3/0x7e0 kernel/locking/rwbase_rt.c:244
rt_write_lock+0x76/0x110 kernel/locking/spinlock_rt.c:243
write_lock_bh include/linux/rwlock_rt.h:99 [inline]
tipc_mon_reinit_self+0x79/0x430 net/tipc/monitor.c:718
tipc_net_finalize+0x115/0x190 net/tipc/net.c:140
process_one_work kernel/workqueue.c:3236 [inline]
process_scheduled_works+0xade/0x17b0 kernel/workqueue.c:3319
worker_thread+0x8a0/0xda0 kernel/workqueue.c:3400
kthread+0x70e/0x8a0 kernel/kthread.c:463
ret_from_fork+0x439/0x7d0 arch/x86/kernel/process.c:148
ret_from_fork_asm+0x1a/0x30 arch/x86/entry/entry_64.S:245
</TASK>
Allocated by task 6089:
kasan_save_stack mm/kasan/common.c:47 [inline]
kasan_save_track+0x3e/0x80 mm/kasan/common.c:68
poison_kmalloc_redzone mm/kasan/common.c:388 [inline]
__kasan_kmalloc+0x93/0xb0 mm/kasan/common.c:405
kasan_kmalloc include/linux/kasan.h:260 [inline]
__kmalloc_cache_noprof+0x1a8/0x320 mm/slub.c:4407
kmalloc_noprof include/linux/slab.h:905 [inline]
kzalloc_noprof include/linux/slab.h:1039 [inline]
tipc_mon_create+0xc3/0x4d0 net/tipc/monitor.c:657
tipc_enable_bearer net/tipc/bearer.c:357 [inline]
__tipc_nl_bearer_enable+0xe16/0x13f0 net/tipc/bearer.c:1047
__tipc_nl_compat_doit net/tipc/netlink_compat.c:371 [inline]
tipc_nl_compat_doit+0x3bc/0x5f0 net/tipc/netlink_compat.c:393
tipc_nl_compat_handle net/tipc/netlink_compat.c:-1 [inline]
tipc_nl_compat_recv+0x83c/0xbe0 net/tipc/netlink_compat.c:1321
genl_family_rcv_msg_doit+0x215/0x300 net/netlink/genetlink.c:1115
genl_family_rcv_msg net/netlink/genetlink.c:1195 [inline]
genl_rcv_msg+0x60e/0x790 net/netlink/genetlink.c:1210
netlink_rcv_skb+0x208/0x470 net/netlink/af_netlink.c:2552
genl_rcv+0x28/0x40 net/netlink/genetlink.c:1219
netlink_unicast_kernel net/netlink/af_netlink.c:1320 [inline]
netlink_unicast+0x846/0xa10 net/netlink/af_netlink.c:1346
netlink_sendmsg+0x805/0xb30 net/netlink/af_netlink.c:1896
sock_sendmsg_nosec net/socket.c:714 [inline]
__sock_sendmsg+0x21c/0x270 net/socket.c:729
____sys_sendmsg+0x508/0x820 net/socket.c:2614
___sys_sendmsg+0x21f/0x2a0 net/socket.c:2668
__sys_sendmsg net/socket.c:2700 [inline]
__do_sys_sendmsg net/socket.c:2705 [inline]
__se_sys_sendmsg net/socket.c:2703 [inline]
__x64_sys_sendmsg+0x1a1/0x260 net/socket.c:2703
do_syscall_x64 arch/x86/entry/syscall_64.c:63 [inline]
do_syscall_64+0xfa/0x3b0 arch/x86/entry/syscall_64.c:94
entry_SYSCALL_64_after_hwframe+0x77/0x7f
Freed by task 6088:
kasan_save_stack mm/kasan/common.c:47 [inline]
kasan_save_track+0x3e/0x80 mm/kasan/common.c:68
kasan_save_free_info+0x46/0x50 mm/kasan/generic.c:576
poison_slab_object mm/kasan/common.c:243 [inline]
__kasan_slab_free+0x5b/0x80 mm/kasan/common.c:275
kasan_slab_free include/linux/kasan.h:233 [inline]
slab_free_hook mm/slub.c:2422 [inline]
slab_free mm/slub.c:4695 [inline]
kfree+0x195/0x550 mm/slub.c:4894
tipc_l2_device_event+0x380/0x650 net/tipc/bearer.c:-1
notifier_call_chain+0x1b3/0x3e0 kernel/notifier.c:85
call_netdevice_notifiers_extack net/core/dev.c:2267 [inline]
call_netdevice_notifiers net/core/dev.c:2281 [inline]
unregister_netdevice_many_notify+0x14d7/0x1fe0 net/core/dev.c:12166
unregister_netdevice_many net/core/dev.c:12229 [inline]
unregister_netdevice_queue+0x33c/0x380 net/core/dev.c:12073
unregister_netdevice include/linux/netdevice.h:3385 [inline]
__tun_detach+0xe4d/0x1620 drivers/net/tun.c:621
tun_detach drivers/net/tun.c:637 [inline]
tun_chr_close+0x10d/0x1c0 drivers/net/tun.c:3433
__fput+0x458/0xa80 fs/file_table.c:468
task_work_run+0x1d4/0x260 kernel/task_work.c:227
resume_user_mode_work include/linux/resume_user_mode.h:50 [inline]
exit_to_user_mode_loop+0xec/0x110 kernel/entry/common.c:43
exit_to_user_mode_prepare include/linux/irq-entry-common.h:225 [inline]
syscall_exit_to_user_mode_work include/linux/entry-common.h:175 [inline]
syscall_exit_to_user_mode include/linux/entry-common.h:210 [inline]
do_syscall_64+0x2bd/0x3b0 arch/x86/entry/syscall_64.c:100
entry_SYSCALL_64_after_hwframe+0x77/0x7f
Fixes: 46cb01eeeb86 ("tipc: update mon's self addr when node addr generated")
Reported-by: syzbot+d7dad7fd4b3921104957@syzkaller.appspotmail.com
Closes: https://lore.kernel.org/netdev/690c323a.050a0220.baf87.007f.GAE@google.com/
Signed-off-by: Kuniyuki Iwashima <kuniyu@google.com>
---
net/tipc/monitor.c | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/net/tipc/monitor.c b/net/tipc/monitor.c
index 572b79bf76ce..46c8814c3ee6 100644
--- a/net/tipc/monitor.c
+++ b/net/tipc/monitor.c
@@ -711,6 +711,8 @@ void tipc_mon_reinit_self(struct net *net)
struct tipc_monitor *mon;
int bearer_id;
+ rtnl_lock();
+
for (bearer_id = 0; bearer_id < MAX_BEARERS; bearer_id++) {
mon = tipc_monitor(net, bearer_id);
if (!mon)
@@ -720,6 +722,8 @@ void tipc_mon_reinit_self(struct net *net)
mon->self->addr = tipc_own_addr(net);
write_unlock_bh(&mon->lock);
}
+
+ rtnl_unlock();
}
int tipc_nl_monitor_set_threshold(struct net *net, u32 cluster_size)
--
2.51.2.1026.g39e6a42477-goog
^ permalink raw reply related [flat|nested] 7+ messages in thread* [syzbot ci] Re: tipc: Fix use-after-free in tipc_mon_reinit_self(). 2025-11-06 5:32 [PATCH v1 net] tipc: Fix use-after-free in tipc_mon_reinit_self() Kuniyuki Iwashima @ 2025-11-06 9:38 ` syzbot ci 2025-11-06 17:59 ` Kuniyuki Iwashima 0 siblings, 1 reply; 7+ messages in thread From: syzbot ci @ 2025-11-06 9:38 UTC (permalink / raw) To: davem, edumazet, hoang.h.le, horms, jmaloy, kuba, kuni1840, kuniyu, netdev, pabeni, syzbot, tipc-discussion Cc: syzbot, syzkaller-bugs syzbot ci has tested the following series [v1] tipc: Fix use-after-free in tipc_mon_reinit_self(). https://lore.kernel.org/all/20251106053309.401275-1-kuniyu@google.com * [PATCH v1 net] tipc: Fix use-after-free in tipc_mon_reinit_self(). and found the following issue: possible deadlock in tipc_mon_reinit_self Full report is available here: https://ci.syzbot.org/series/bfabf013-65e3-4ca9-8f54-0c7eef8be01a *** possible deadlock in tipc_mon_reinit_self tree: net URL: https://kernel.googlesource.com/pub/scm/linux/kernel/git/netdev/net.git base: 3d18a84eddde169d6dbf3c72cc5358b988c347d0 arch: amd64 compiler: Debian clang version 20.1.8 (++20250708063551+0c9f909b7976-1~exp1~20250708183702.136), Debian LLD 20.1.8 config: https://ci.syzbot.org/builds/b2774856-e331-420e-a340-5107ec4b06f9/config C repro: https://ci.syzbot.org/findings/1f0a4298-b797-4217-8d6d-15f98c0ffd38/c_repro syz repro: https://ci.syzbot.org/findings/1f0a4298-b797-4217-8d6d-15f98c0ffd38/syz_repro tipc: Started in network mode tipc: Node identity 4, cluster identity 4711 tipc: Node number set to 4 ============================================ WARNING: possible recursive locking detected syzkaller #0 Not tainted -------------------------------------------- syz.0.17/5963 is trying to acquire lock: ffffffff8f2cb1c8 (rtnl_mutex){+.+.}-{4:4}, at: tipc_mon_reinit_self+0x25/0x360 net/tipc/monitor.c:714 but task is already holding lock: ffffffff8f2cb1c8 (rtnl_mutex){+.+.}-{4:4}, at: __tipc_nl_compat_doit net/tipc/netlink_compat.c:358 [inline] ffffffff8f2cb1c8 (rtnl_mutex){+.+.}-{4:4}, at: tipc_nl_compat_doit+0x1fd/0x5f0 net/tipc/netlink_compat.c:393 other info that might help us debug this: Possible unsafe locking scenario: CPU0 ---- lock(rtnl_mutex); lock(rtnl_mutex); *** DEADLOCK *** May be due to missing lock nesting notation 3 locks held by syz.0.17/5963: #0: ffffffff8f331050 (cb_lock){++++}-{4:4}, at: genl_rcv+0x19/0x40 net/netlink/genetlink.c:1218 #1: ffffffff8f330e68 (genl_mutex){+.+.}-{4:4}, at: genl_lock net/netlink/genetlink.c:35 [inline] #1: ffffffff8f330e68 (genl_mutex){+.+.}-{4:4}, at: genl_op_lock net/netlink/genetlink.c:60 [inline] #1: ffffffff8f330e68 (genl_mutex){+.+.}-{4:4}, at: genl_rcv_msg+0x10d/0x790 net/netlink/genetlink.c:1209 #2: ffffffff8f2cb1c8 (rtnl_mutex){+.+.}-{4:4}, at: __tipc_nl_compat_doit net/tipc/netlink_compat.c:358 [inline] #2: ffffffff8f2cb1c8 (rtnl_mutex){+.+.}-{4:4}, at: tipc_nl_compat_doit+0x1fd/0x5f0 net/tipc/netlink_compat.c:393 stack backtrace: CPU: 1 UID: 0 PID: 5963 Comm: syz.0.17 Not tainted syzkaller #0 PREEMPT(full) Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS 1.16.2-debian-1.16.2-1 04/01/2014 Call Trace: <TASK> dump_stack_lvl+0x189/0x250 lib/dump_stack.c:120 print_deadlock_bug+0x28b/0x2a0 kernel/locking/lockdep.c:3041 check_deadlock kernel/locking/lockdep.c:3093 [inline] validate_chain+0x1a3f/0x2140 kernel/locking/lockdep.c:3895 __lock_acquire+0xab9/0xd20 kernel/locking/lockdep.c:5237 lock_acquire+0x120/0x360 kernel/locking/lockdep.c:5868 __mutex_lock_common kernel/locking/mutex.c:598 [inline] __mutex_lock+0x187/0x1350 kernel/locking/mutex.c:760 tipc_mon_reinit_self+0x25/0x360 net/tipc/monitor.c:714 tipc_net_finalize+0x115/0x190 net/tipc/net.c:140 tipc_net_init+0x104/0x190 net/tipc/net.c:122 __tipc_nl_net_set+0x3b9/0x5a0 net/tipc/net.c:263 __tipc_nl_compat_doit net/tipc/netlink_compat.c:371 [inline] tipc_nl_compat_doit+0x3bc/0x5f0 net/tipc/netlink_compat.c:393 tipc_nl_compat_handle net/tipc/netlink_compat.c:-1 [inline] tipc_nl_compat_recv+0x83c/0xbe0 net/tipc/netlink_compat.c:1321 genl_family_rcv_msg_doit+0x215/0x300 net/netlink/genetlink.c:1115 genl_family_rcv_msg net/netlink/genetlink.c:1195 [inline] genl_rcv_msg+0x60e/0x790 net/netlink/genetlink.c:1210 netlink_rcv_skb+0x208/0x470 net/netlink/af_netlink.c:2552 genl_rcv+0x28/0x40 net/netlink/genetlink.c:1219 netlink_unicast_kernel net/netlink/af_netlink.c:1320 [inline] netlink_unicast+0x82f/0x9e0 net/netlink/af_netlink.c:1346 netlink_sendmsg+0x805/0xb30 net/netlink/af_netlink.c:1896 sock_sendmsg_nosec net/socket.c:727 [inline] __sock_sendmsg+0x21c/0x270 net/socket.c:742 ____sys_sendmsg+0x505/0x830 net/socket.c:2630 ___sys_sendmsg+0x21f/0x2a0 net/socket.c:2684 __sys_sendmsg net/socket.c:2716 [inline] __do_sys_sendmsg net/socket.c:2721 [inline] __se_sys_sendmsg net/socket.c:2719 [inline] __x64_sys_sendmsg+0x19b/0x260 net/socket.c:2719 do_syscall_x64 arch/x86/entry/syscall_64.c:63 [inline] do_syscall_64+0xfa/0xfa0 arch/x86/entry/syscall_64.c:94 entry_SYSCALL_64_after_hwframe+0x77/0x7f RIP: 0033:0x7f13d8b8efc9 Code: ff ff c3 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 40 00 48 89 f8 48 89 f7 48 89 d6 48 89 ca 4d 89 c2 4d 89 c8 4c 8b 4c 24 08 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 c7 c1 a8 ff ff ff f7 d8 64 89 01 48 RSP: 002b:00007fff77cccbf8 EFLAGS: 00000246 ORIG_RAX: 000000000000002e RAX: ffffffffffffffda RBX: 00007f13d8de5fa0 RCX: 00007f13d8b8efc9 RDX: 0000000000000000 RSI: 00002000000001c0 RDI: 0000000000000003 RBP: 00007f13d8c11f91 R08: 0000000000000000 R09: 0000000000000000 R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000000000 R13: 00007f13d8de5fa0 R14: 00007f13d8de5fa0 R15: 0000000000000003 </TASK> *** If these findings have caused you to resend the series or submit a separate fix, please add the following tag to your commit message: Tested-by: syzbot@syzkaller.appspotmail.com --- This report is generated by a bot. It may contain errors. syzbot ci engineers can be reached at syzkaller@googlegroups.com. ^ permalink raw reply [flat|nested] 7+ messages in thread
* [syzbot ci] Re: tipc: Fix use-after-free in tipc_mon_reinit_self(). 2025-11-06 9:38 ` [syzbot ci] " syzbot ci @ 2025-11-06 17:59 ` Kuniyuki Iwashima 2025-11-06 22:30 ` Jakub Kicinski 0 siblings, 1 reply; 7+ messages in thread From: Kuniyuki Iwashima @ 2025-11-06 17:59 UTC (permalink / raw) To: syzbot+cif2d6d318f7e85f0b Cc: davem, edumazet, hoang.h.le, horms, jmaloy, kuba, kuni1840, kuniyu, netdev, pabeni, syzbot, syzbot, syzkaller-bugs, tipc-discussion From: syzbot ci <syzbot+cif2d6d318f7e85f0b@syzkaller.appspotmail.com> Date: Thu, 06 Nov 2025 01:38:49 -0800 > syzbot ci has tested the following series > > [v1] tipc: Fix use-after-free in tipc_mon_reinit_self(). > https://lore.kernel.org/all/20251106053309.401275-1-kuniyu@google.com > * [PATCH v1 net] tipc: Fix use-after-free in tipc_mon_reinit_self(). > > and found the following issue: > possible deadlock in tipc_mon_reinit_self > > Full report is available here: > https://ci.syzbot.org/series/bfabf013-65e3-4ca9-8f54-0c7eef8be01a > > *** > > possible deadlock in tipc_mon_reinit_self > > tree: net > URL: https://kernel.googlesource.com/pub/scm/linux/kernel/git/netdev/net.git > base: 3d18a84eddde169d6dbf3c72cc5358b988c347d0 > arch: amd64 > compiler: Debian clang version 20.1.8 (++20250708063551+0c9f909b7976-1~exp1~20250708183702.136), Debian LLD 20.1.8 > config: https://ci.syzbot.org/builds/b2774856-e331-420e-a340-5107ec4b06f9/config > C repro: https://ci.syzbot.org/findings/1f0a4298-b797-4217-8d6d-15f98c0ffd38/c_repro > syz repro: https://ci.syzbot.org/findings/1f0a4298-b797-4217-8d6d-15f98c0ffd38/syz_repro > > tipc: Started in network mode > tipc: Node identity 4, cluster identity 4711 > tipc: Node number set to 4 > ============================================ > WARNING: possible recursive locking detected > syzkaller #0 Not tainted > -------------------------------------------- > syz.0.17/5963 is trying to acquire lock: > ffffffff8f2cb1c8 (rtnl_mutex){+.+.}-{4:4}, at: tipc_mon_reinit_self+0x25/0x360 net/tipc/monitor.c:714 > > but task is already holding lock: > ffffffff8f2cb1c8 (rtnl_mutex){+.+.}-{4:4}, at: __tipc_nl_compat_doit net/tipc/netlink_compat.c:358 [inline] > ffffffff8f2cb1c8 (rtnl_mutex){+.+.}-{4:4}, at: tipc_nl_compat_doit+0x1fd/0x5f0 net/tipc/netlink_compat.c:393 > > other info that might help us debug this: > Possible unsafe locking scenario: > > CPU0 > ---- > lock(rtnl_mutex); > lock(rtnl_mutex); > > *** DEADLOCK *** > > May be due to missing lock nesting notation > > 3 locks held by syz.0.17/5963: > #0: ffffffff8f331050 (cb_lock){++++}-{4:4}, at: genl_rcv+0x19/0x40 net/netlink/genetlink.c:1218 > #1: ffffffff8f330e68 (genl_mutex){+.+.}-{4:4}, at: genl_lock net/netlink/genetlink.c:35 [inline] > #1: ffffffff8f330e68 (genl_mutex){+.+.}-{4:4}, at: genl_op_lock net/netlink/genetlink.c:60 [inline] > #1: ffffffff8f330e68 (genl_mutex){+.+.}-{4:4}, at: genl_rcv_msg+0x10d/0x790 net/netlink/genetlink.c:1209 > #2: ffffffff8f2cb1c8 (rtnl_mutex){+.+.}-{4:4}, at: __tipc_nl_compat_doit net/tipc/netlink_compat.c:358 [inline] > #2: ffffffff8f2cb1c8 (rtnl_mutex){+.+.}-{4:4}, at: tipc_nl_compat_doit+0x1fd/0x5f0 net/tipc/netlink_compat.c:393 > > stack backtrace: > CPU: 1 UID: 0 PID: 5963 Comm: syz.0.17 Not tainted syzkaller #0 PREEMPT(full) > Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS 1.16.2-debian-1.16.2-1 04/01/2014 > Call Trace: > <TASK> > dump_stack_lvl+0x189/0x250 lib/dump_stack.c:120 > print_deadlock_bug+0x28b/0x2a0 kernel/locking/lockdep.c:3041 > check_deadlock kernel/locking/lockdep.c:3093 [inline] > validate_chain+0x1a3f/0x2140 kernel/locking/lockdep.c:3895 > __lock_acquire+0xab9/0xd20 kernel/locking/lockdep.c:5237 > lock_acquire+0x120/0x360 kernel/locking/lockdep.c:5868 > __mutex_lock_common kernel/locking/mutex.c:598 [inline] > __mutex_lock+0x187/0x1350 kernel/locking/mutex.c:760 > tipc_mon_reinit_self+0x25/0x360 net/tipc/monitor.c:714 > tipc_net_finalize+0x115/0x190 net/tipc/net.c:140 > tipc_net_init+0x104/0x190 net/tipc/net.c:122 > __tipc_nl_net_set+0x3b9/0x5a0 net/tipc/net.c:263 I missed another path calling tipc_net_finalize under RTNL. I'll change v2 this way. ---8<--- diff --git a/net/tipc/monitor.c b/net/tipc/monitor.c index 46c8814c3ee6..be1e51efc445 100644 --- a/net/tipc/monitor.c +++ b/net/tipc/monitor.c @@ -706,12 +706,13 @@ void tipc_mon_delete(struct net *net, int bearer_id) kfree(mon); } -void tipc_mon_reinit_self(struct net *net) +void tipc_mon_reinit_self(struct net *net, bool rtnl_held) { struct tipc_monitor *mon; int bearer_id; - rtnl_lock(); + if (!rtnl_held) + rtnl_lock(); for (bearer_id = 0; bearer_id < MAX_BEARERS; bearer_id++) { mon = tipc_monitor(net, bearer_id); @@ -723,7 +724,8 @@ void tipc_mon_reinit_self(struct net *net) write_unlock_bh(&mon->lock); } - rtnl_unlock(); + if (!rtnl_held) + rtnl_unlock(); } int tipc_nl_monitor_set_threshold(struct net *net, u32 cluster_size) diff --git a/net/tipc/net.c b/net/tipc/net.c index 0e95572e56b4..56527f6f548c 100644 --- a/net/tipc/net.c +++ b/net/tipc/net.c @@ -119,11 +119,11 @@ int tipc_net_init(struct net *net, u8 *node_id, u32 addr) if (node_id) tipc_set_node_id(net, node_id); if (addr) - tipc_net_finalize(net, addr); + tipc_net_finalize(net, addr, true); return 0; } -static void tipc_net_finalize(struct net *net, u32 addr) +static void tipc_net_finalize(struct net *net, u32 addr, bool rtnl_held) { struct tipc_net *tn = tipc_net(net); struct tipc_socket_addr sk = {0, addr}; @@ -137,7 +137,7 @@ static void tipc_net_finalize(struct net *net, u32 addr) tipc_set_node_addr(net, addr); tipc_named_reinit(net); tipc_sk_reinit(net); - tipc_mon_reinit_self(net); + tipc_mon_reinit_self(net, rtnl_held); tipc_nametbl_publish(net, &ua, &sk, addr); } @@ -145,7 +145,7 @@ void tipc_net_finalize_work(struct work_struct *work) { struct tipc_net *tn = container_of(work, struct tipc_net, work); - tipc_net_finalize(tipc_link_net(tn->bcl), tn->trial_addr); + tipc_net_finalize(tipc_link_net(tn->bcl), tn->trial_addr, false); } void tipc_net_stop(struct net *net) ---8<--- ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [syzbot ci] Re: tipc: Fix use-after-free in tipc_mon_reinit_self(). 2025-11-06 17:59 ` Kuniyuki Iwashima @ 2025-11-06 22:30 ` Jakub Kicinski 2025-11-06 22:37 ` Kuniyuki Iwashima 0 siblings, 1 reply; 7+ messages in thread From: Jakub Kicinski @ 2025-11-06 22:30 UTC (permalink / raw) To: Kuniyuki Iwashima Cc: syzbot+cif2d6d318f7e85f0b, davem, edumazet, hoang.h.le, horms, jmaloy, kuni1840, netdev, pabeni, syzbot, syzbot, syzkaller-bugs, tipc-discussion On Thu, 6 Nov 2025 17:59:17 +0000 Kuniyuki Iwashima wrote: > -void tipc_mon_reinit_self(struct net *net) > +void tipc_mon_reinit_self(struct net *net, bool rtnl_held) > { > struct tipc_monitor *mon; > int bearer_id; > > - rtnl_lock(); > + if (!rtnl_held) > + rtnl_lock(); I haven't looked closely but for the record conditional locking is generally considered to be poor code design. Extract the body into a __tipc_mon_reinit_self() helper and call that when lock is already held? And: void tipc_mon_reinit_self(struct net *net) { rtnl_lock(); __tipc_mon_reinit_self(net); rtnl_unlock(); } ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [syzbot ci] Re: tipc: Fix use-after-free in tipc_mon_reinit_self(). 2025-11-06 22:30 ` Jakub Kicinski @ 2025-11-06 22:37 ` Kuniyuki Iwashima 2025-11-06 22:39 ` Jakub Kicinski 0 siblings, 1 reply; 7+ messages in thread From: Kuniyuki Iwashima @ 2025-11-06 22:37 UTC (permalink / raw) To: Jakub Kicinski Cc: syzbot+cif2d6d318f7e85f0b, davem, edumazet, hoang.h.le, horms, jmaloy, kuni1840, netdev, pabeni, syzbot, syzbot, syzkaller-bugs, tipc-discussion On Thu, Nov 6, 2025 at 2:30 PM Jakub Kicinski <kuba@kernel.org> wrote: > > On Thu, 6 Nov 2025 17:59:17 +0000 Kuniyuki Iwashima wrote: > > -void tipc_mon_reinit_self(struct net *net) > > +void tipc_mon_reinit_self(struct net *net, bool rtnl_held) > > { > > struct tipc_monitor *mon; > > int bearer_id; > > > > - rtnl_lock(); > > + if (!rtnl_held) > > + rtnl_lock(); > > I haven't looked closely but for the record conditional locking > is generally considered to be poor code design. Extract the body > into a __tipc_mon_reinit_self() helper and call that when lock > is already held? And: > > void tipc_mon_reinit_self(struct net *net) > { > rtnl_lock(); > __tipc_mon_reinit_self(net); > rtnl_unlock(); > } That's much cleaner, I'll use this. Thanks, Jakub! ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [syzbot ci] Re: tipc: Fix use-after-free in tipc_mon_reinit_self(). 2025-11-06 22:37 ` Kuniyuki Iwashima @ 2025-11-06 22:39 ` Jakub Kicinski 2025-11-06 22:51 ` Kuniyuki Iwashima 0 siblings, 1 reply; 7+ messages in thread From: Jakub Kicinski @ 2025-11-06 22:39 UTC (permalink / raw) To: Kuniyuki Iwashima Cc: syzbot+cif2d6d318f7e85f0b, davem, edumazet, hoang.h.le, horms, jmaloy, kuni1840, netdev, pabeni, syzbot, syzbot, syzkaller-bugs, tipc-discussion On Thu, 6 Nov 2025 14:37:10 -0800 Kuniyuki Iwashima wrote: > > On Thu, 6 Nov 2025 17:59:17 +0000 Kuniyuki Iwashima wrote: > > > -void tipc_mon_reinit_self(struct net *net) > > > +void tipc_mon_reinit_self(struct net *net, bool rtnl_held) > > > { > > > struct tipc_monitor *mon; > > > int bearer_id; > > > > > > - rtnl_lock(); > > > + if (!rtnl_held) > > > + rtnl_lock(); > > > > I haven't looked closely but for the record conditional locking > > is generally considered to be poor code design. Extract the body > > into a __tipc_mon_reinit_self() helper and call that when lock > > is already held? And: > > > > void tipc_mon_reinit_self(struct net *net) > > { > > rtnl_lock(); > > __tipc_mon_reinit_self(net); > > rtnl_unlock(); > > } > > That's much cleaner, I'll use this. After sending I realized you probably want to do this wrapping around tipc_net_finalize(), otherwise we'd just be shifting the conditional. But you get the point.. :) ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [syzbot ci] Re: tipc: Fix use-after-free in tipc_mon_reinit_self(). 2025-11-06 22:39 ` Jakub Kicinski @ 2025-11-06 22:51 ` Kuniyuki Iwashima 0 siblings, 0 replies; 7+ messages in thread From: Kuniyuki Iwashima @ 2025-11-06 22:51 UTC (permalink / raw) To: Jakub Kicinski Cc: syzbot+cif2d6d318f7e85f0b, davem, edumazet, hoang.h.le, horms, jmaloy, kuni1840, netdev, pabeni, syzbot, syzbot, syzkaller-bugs, tipc-discussion On Thu, Nov 6, 2025 at 2:39 PM Jakub Kicinski <kuba@kernel.org> wrote: > > On Thu, 6 Nov 2025 14:37:10 -0800 Kuniyuki Iwashima wrote: > > > On Thu, 6 Nov 2025 17:59:17 +0000 Kuniyuki Iwashima wrote: > > > > -void tipc_mon_reinit_self(struct net *net) > > > > +void tipc_mon_reinit_self(struct net *net, bool rtnl_held) > > > > { > > > > struct tipc_monitor *mon; > > > > int bearer_id; > > > > > > > > - rtnl_lock(); > > > > + if (!rtnl_held) > > > > + rtnl_lock(); > > > > > > I haven't looked closely but for the record conditional locking > > > is generally considered to be poor code design. Extract the body > > > into a __tipc_mon_reinit_self() helper and call that when lock > > > is already held? And: > > > > > > void tipc_mon_reinit_self(struct net *net) > > > { > > > rtnl_lock(); > > > __tipc_mon_reinit_self(net); > > > rtnl_unlock(); > > > } > > > > That's much cleaner, I'll use this. > > After sending I realized you probably want to do this wrapping around > tipc_net_finalize(), otherwise we'd just be shifting the conditional. > But you get the point.. :) Yes, will wrap it in tipc_net_finalize_work() :) ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2025-11-06 22:52 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2025-11-06 5:32 [PATCH v1 net] tipc: Fix use-after-free in tipc_mon_reinit_self() Kuniyuki Iwashima 2025-11-06 9:38 ` [syzbot ci] " syzbot ci 2025-11-06 17:59 ` Kuniyuki Iwashima 2025-11-06 22:30 ` Jakub Kicinski 2025-11-06 22:37 ` Kuniyuki Iwashima 2025-11-06 22:39 ` Jakub Kicinski 2025-11-06 22:51 ` Kuniyuki Iwashima
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).