summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFelix Fietkau2026-02-06 09:30:49 +0000
committerFelix Fietkau2026-02-07 09:04:17 +0000
commit389a79d97230fbd31de98a7f8896302ad284c114 (patch)
treee0298c367b151c6f07b27b755b8947c34815b11b
parentf09596f84f3572d963e1c893762fd105b4ceee2e (diff)
downloadopenwrt-389a79d97230fbd31de98a7f8896302ad284c114.tar.gz
unetmsg: close all channels on network removal
network_close() only closed the listening socket without shutting down established RX/TX connections. This left remote state in core.remote_publish/core.remote_subscribe for hosts on the removed network, causing stale entries in channel listings and failed routing attempts. Close all RX and TX channels before removing the network, which also triggers remote state cleanup via network_rx_socket_close(). Signed-off-by: Felix Fietkau <nbd@nbd.name>
-rw-r--r--package/network/services/unetmsg/files/usr/share/ucode/unetmsg/unetmsgd-remote.uc7
1 files changed, 7 insertions, 0 deletions
diff --git a/package/network/services/unetmsg/files/usr/share/ucode/unetmsg/unetmsgd-remote.uc b/package/network/services/unetmsg/files/usr/share/ucode/unetmsg/unetmsgd-remote.uc
index 54e77596f1..f6b0ef2d59 100644
--- a/package/network/services/unetmsg/files/usr/share/ucode/unetmsg/unetmsgd-remote.uc
+++ b/package/network/services/unetmsg/files/usr/share/ucode/unetmsg/unetmsgd-remote.uc
@@ -449,6 +449,13 @@ function network_close(name)
net.timer.cancel();
net.handle.delete();
net.socket.close();
+
+ for (let peer, sock_data in net.rx_channels)
+ network_rx_socket_close(sock_data);
+
+ for (let peer, sock_data in net.tx_channels)
+ network_tx_socket_close(sock_data);
+
delete networks[name];
}