From 0982c156cb5beb70cd2f96aa02993c6d3c8ecf59 Mon Sep 17 00:00:00 2001
From: David Bauer <mail@david-bauer.net>
Date: Thu, 11 Jan 2024 01:57:39 +0100
Subject: [PATCH] modules: update openwrt

cdc907abed ath79: read back reset register
5ad05681f2 ath79: add support for UniFi UK-Ultra
e214118148 ath79: move UniFi AC template into common
4103958e76 mediatek: fix BPI-R3 wifi mac address
2fe497c4a5 mac80211: do not emit VHT160 capabilities if channel width is less than 160 MHz
9cd0023e54 hostapd: add missing NULL pointer check on radar notification
3bf602d740 mac80211: avoid crashing on invalid band info
d4a21d75a9 mediatek: GL-MT6000: Add missing LED state definitions
0cd6b3fd0c linux/modules: remove deprecated module
40cfdf5ffe kernel: bump 5.15 to 5.15.146
6e39d2426b ramips: add support for D-Link COVR-X1860 A1
af7ef781ac ramips: add encrypted SGE factory image for D-Link devices
67d998e25d kernel: bump 5.15 to 5.15.145
b54f7105df firmware-utils: move patch to maintaince branch
34e30fb53a firmware-utils: bump to latest openwrt-23.05
e61d651053 ramips: correct the PCIe port number for Unielec u7621-01
80ef582dee rockchip: configure eth pad driver strength for orangepi r1 plus lts
9cd589bd79 ramips: lzma-loader: use default uart for rt305x
2216b10ebb ramips: lzma-loader: use proper register names
76f7dd3312 ramips: lzma-loader: use virtual memory segments for uart base address
23506e7789 raimps: mtk_eth_soc: drop rst_esw from ESW driver
0128d860a0 ramips: dts: mt7628an: reset FE and ESW cores together
ee4a042483 ramips: dts: rt5350: reset FE and ESW cores together
4e1bf2a50c ramips: dts: rt3050: reset FE and ESW cores together
88501f82f5 ramips: dts: rt3352: reset FE and ESW cores together
289515e003 ramips: mtk_eth_soc: wait longer after FE core reset to settle
8ce87267ba ramips: mtk_eth_soc: allow multiple resets
3aec71a176 mac80211: add missing newline for "min_tx_power"
c6425bb525 kernel: delete stray linux 6.1 patch
49bde57679 kernel: fix bridge proxyarp issue with some broken DHCP clients
51881b2eb9 mediatek: add support for Routerich AX3000
18d7962f7b ramips: add support for Rostelecom RT-FE-1A
f6fb6bb2ba ramips: mt7621: use lzma-loader for Sercomm NA502
9a7b14dcfe mediatek: enable mt7981-wo-firmware package by default
9325da80ab mac80211: fix a race condition related to enabling fast-xmit
b0fc8b47e0 netifd: update to Git openwrt-23.05 (2024-01-04)
5cc1918a7a dropbear: increase default receive window size
60e49cf170 ramips: fix label-mac for Xiaomi RA75
---
 modules                                       |   2 +-
 ...-avoid-crashing-on-invalid-band-info.patch |  39 -----
 ...increase-default-receive-window-size.patch |  31 ----
 ...tion-in-netlink-socket-error-handing.patch | 152 ------------------
 4 files changed, 1 insertion(+), 223 deletions(-)
 delete mode 100644 patches/openwrt/0007-mac80211-avoid-crashing-on-invalid-band-info.patch
 delete mode 100644 patches/openwrt/0008-dropbear-increase-default-receive-window-size.patch
 delete mode 100644 patches/openwrt/0009-netifd-system-linux-fix-race-condition-in-netlink-socket-error-handing.patch

diff --git a/modules b/modules
index 8b77b64d..8a2bc916 100644
--- a/modules
+++ b/modules
@@ -2,7 +2,7 @@ GLUON_FEEDS='gluon packages routing'
 
 OPENWRT_REPO=https://github.com/openwrt/openwrt.git
 OPENWRT_BRANCH=openwrt-23.05
-OPENWRT_COMMIT=59fd8f08cf544a7f0fcaf700ca9af9292de3adcc
+OPENWRT_COMMIT=cdc907abedf1ad0d17cc88fd33d35a3ef3f8fc75
 
 PACKAGES_GLUON_REPO=https://github.com/freifunk-gluon/packages.git
 PACKAGES_GLUON_COMMIT=53ea3b89771fc7d7a80f1800ce25e98dfe1633aa
diff --git a/patches/openwrt/0007-mac80211-avoid-crashing-on-invalid-band-info.patch b/patches/openwrt/0007-mac80211-avoid-crashing-on-invalid-band-info.patch
deleted file mode 100644
index 3ebb462e..00000000
--- a/patches/openwrt/0007-mac80211-avoid-crashing-on-invalid-band-info.patch
+++ /dev/null
@@ -1,39 +0,0 @@
-From: David Bauer <mail@david-bauer.net>
-Date: Thu, 30 Nov 2023 07:32:52 +0100
-Subject: mac80211: avoid crashing on invalid band info
-
-Frequent crashes have been observed on MT7916 based platforms. While the
-root of these crashes are currently unknown, they happen when decoding
-rate information of connected STAs in AP mode. The rate-information is
-associated with a band which is not available on the PHY.
-
-Check for this condition in order to avoid crashing the whole system.
-This patch should be removed once the roout cause has been found and
-fixed.
-
-Link: https://github.com/freifunk-gluon/gluon/issues/2980
-
-Signed-off-by: David Bauer <mail@david-bauer.net>
-
-diff --git a/package/kernel/mac80211/patches/subsys/780-avoid-crashing-missing-band.patch b/package/kernel/mac80211/patches/subsys/780-avoid-crashing-missing-band.patch
-new file mode 100644
-index 0000000000000000000000000000000000000000..1847b2fe8defd67ec17a1b760ce03c0db1065f8c
---- /dev/null
-+++ b/package/kernel/mac80211/patches/subsys/780-avoid-crashing-missing-band.patch
-@@ -0,0 +1,16 @@
-+--- a/net/mac80211/sta_info.c
-++++ b/net/mac80211/sta_info.c
-+@@ -2422,6 +2422,13 @@ static void sta_stats_decode_rate(struct
-+ 
-+ 		sband = local->hw.wiphy->bands[band];
-+ 
-++		if (!sband) {
-++			wiphy_debug(local->hw.wiphy,
-++				    "Invalid band %d\n",
-++				    band);
-++			break;
-++		}
-++
-+ 		if (WARN_ON_ONCE(!sband->bitrates))
-+ 			break;
-+ 
diff --git a/patches/openwrt/0008-dropbear-increase-default-receive-window-size.patch b/patches/openwrt/0008-dropbear-increase-default-receive-window-size.patch
deleted file mode 100644
index 6617b719..00000000
--- a/patches/openwrt/0008-dropbear-increase-default-receive-window-size.patch
+++ /dev/null
@@ -1,31 +0,0 @@
-From: David Bauer <mail@david-bauer.net>
-Date: Thu, 28 Dec 2023 23:16:02 +0100
-Subject: dropbear: increase default receive window size
-
-Increasing the receive window size improves throughout on higher-latency
-links such as WAN connections. The current default of 24KB caps out at
-around 500 KB/s.
-
-Increasing the receive buffer to 256KB increases the throughput to at
-least 11 MB/s.
-
-Signed-off-by: David Bauer <mail@david-bauer.net>
-(cherry picked from commit f95eecfb21ff08662e022accd30e8254028ff63b)
-
-diff --git a/package/network/services/dropbear/files/dropbear.init b/package/network/services/dropbear/files/dropbear.init
-index b82e967cbcedc4564dba6cfccc1383f7b7fa499f..a40b5f7baeea0f3a1e258f1a74aba0eb1ca3adcb 100755
---- a/package/network/services/dropbear/files/dropbear.init
-+++ b/package/network/services/dropbear/files/dropbear.init
-@@ -155,6 +155,12 @@ dropbear_instance()
- 	PIDCOUNT="$(( ${PIDCOUNT} + 1))"
- 	local pid_file="/var/run/${NAME}.${PIDCOUNT}.pid"
- 
-+	# Increase default receive window size to increase
-+	# throughput on high latency links
-+	if [ "${RecvWindowSize}" -eq "0" ]; then
-+		RecvWindowSize="262144"
-+	fi
-+
- 	procd_open_instance
- 	procd_set_param command "$PROG" -F -P "$pid_file"
- 	[ "${PasswordAuth}" -eq 0 ] && procd_append_param command -s
diff --git a/patches/openwrt/0009-netifd-system-linux-fix-race-condition-in-netlink-socket-error-handing.patch b/patches/openwrt/0009-netifd-system-linux-fix-race-condition-in-netlink-socket-error-handing.patch
deleted file mode 100644
index 86d11290..00000000
--- a/patches/openwrt/0009-netifd-system-linux-fix-race-condition-in-netlink-socket-error-handing.patch
+++ /dev/null
@@ -1,152 +0,0 @@
-From: David Bauer <mail@david-bauer.net>
-Date: Wed, 3 Jan 2024 16:43:09 +0100
-Subject: netifd: system-linux: fix race condition in netlink socket error handing
-
-The error handling needed for the buffer growth logic relies on
-uloop_fd's error flag, which is set based on epoll events. Doing so
-without handling recvmsg's error codes is racy, as an error state may be
-set between receiving epoll events and the next recvmsg, but calling
-recvmsg clears the error state.
-
-To fix this, add handling for errors returned by nl_recvmsgs_default()
-and nl_recv(); checking for u->error and retrieving the error status
-using getsockopt() becomes redundant.
-
-We have observed this issue on Gluon (recent OpenWrt 23.05); on some
-devices with DSA switches, the bridge interface's carrier-on event would
-consistenly get lost during boot due to insufficient buffer space
-(see [1]).
-
-We have bisected the issue to netifd commit 516ab774cc16 ("system-linux:
-fix race condition on bringing up wireless devices"), but that commit only
-uncovered the preexisting bug by switching from getting the carrier state
-from sysfs to using the netlink messages in cb_rtnl_event().
-
-I suspect that other recent issues about netifd missing a carrier state
-change like [2] may have the same underlying cause.
-
-[1] https://github.com/freifunk-gluon/gluon/issues/3130
-[2] https://github.com/openwrt/openwrt/issues/13863
-
-Signed-off-by: Matthias Schiffer <mschiffer@universe-factory.net>
-Signed-off-by: David Bauer <mail@david-bauer.net>
-
-diff --git a/package/network/config/netifd/patches/0002-netifd-system-linux-fix-race-condition-in-netlink-socket-error-handing.patch b/package/network/config/netifd/patches/0002-netifd-system-linux-fix-race-condition-in-netlink-socket-error-handing.patch
-new file mode 100644
-index 0000000000000000000000000000000000000000..1b8dd71da622ef7aa73794bd70c636ab0fe59c4e
---- /dev/null
-+++ b/package/network/config/netifd/patches/0002-netifd-system-linux-fix-race-condition-in-netlink-socket-error-handing.patch
-@@ -0,0 +1,113 @@
-+From 54eb773cebb74ffecf1f0c4e8ebd4b65812095c0 Mon Sep 17 00:00:00 2001
-+From: Matthias Schiffer <mschiffer@universe-factory.net>
-+Date: Tue, 2 Jan 2024 15:58:30 +0100
-+Subject: [PATCH] system-linux: fix race condition in netlink socket error
-+ handing
-+
-+The error handling needed for the buffer growth logic relies on
-+uloop_fd's error flag, which is set based on epoll events. Doing so
-+without handling recvmsg's error codes is racy, as an error state may be
-+set between receiving epoll events and the next recvmsg, but calling
-+recvmsg clears the error state.
-+
-+To fix this, add handling for errors returned by nl_recvmsgs_default()
-+and nl_recv(); checking for u->error and retrieving the error status
-+using getsockopt() becomes redundant.
-+
-+We have observed this issue on Gluon (recent OpenWrt 23.05); on some
-+devices with DSA switches, the bridge interface's carrier-on event would
-+consistenly get lost during boot due to insufficient buffer space
-+(see [1]).
-+
-+We have bisected the issue to netifd commit 516ab774cc16 ("system-linux:
-+fix race condition on bringing up wireless devices"), but that commit only
-+uncovered the preexisting bug by switching from getting the carrier state
-+from sysfs to using the netlink messages in cb_rtnl_event().
-+
-+I suspect that other recent issues about netifd missing a carrier state
-+change like [2] may have the same underlying cause.
-+
-+[1] https://github.com/freifunk-gluon/gluon/issues/3130
-+[2] https://github.com/openwrt/openwrt/issues/13863
-+
-+Signed-off-by: Matthias Schiffer <mschiffer@universe-factory.net>
-+---
-+ system-linux.c | 38 +++++++++++++-------------------------
-+ 1 file changed, 13 insertions(+), 25 deletions(-)
-+
-+--- a/system-linux.c
-++++ b/system-linux.c
-+@@ -169,19 +169,14 @@ static void
-+ handler_nl_event(struct uloop_fd *u, unsigned int events)
-+ {
-+ 	struct event_socket *ev = container_of(u, struct event_socket, uloop);
-+-	int err;
-+-	socklen_t errlen = sizeof(err);
-++	int ret;
-+ 
-+-	if (!u->error) {
-+-		nl_recvmsgs_default(ev->sock);
-++	ret = nl_recvmsgs_default(ev->sock);
-++	if (ret >= 0)
-+ 		return;
-+-	}
-+-
-+-	if (getsockopt(u->fd, SOL_SOCKET, SO_ERROR, (void *)&err, &errlen))
-+-		goto abort;
-+ 
-+-	switch(err) {
-+-	case ENOBUFS:
-++	switch (-ret) {
-++	case NLE_NOMEM:
-+ 		/* Increase rx buffer size on netlink socket */
-+ 		ev->bufsize *= 2;
-+ 		if (nl_socket_set_buffer_size(ev->sock, ev->bufsize, 0))
-+@@ -195,7 +190,6 @@ handler_nl_event(struct uloop_fd *u, uns
-+ 	default:
-+ 		goto abort;
-+ 	}
-+-	u->error = false;
-+ 	return;
-+ 
-+ abort:
-+@@ -791,24 +785,19 @@ handle_hotplug_event(struct uloop_fd *u,
-+ 	struct sockaddr_nl nla;
-+ 	unsigned char *buf = NULL;
-+ 	int size;
-+-	int err;
-+-	socklen_t errlen = sizeof(err);
-+ 
-+-	if (!u->error) {
-+-		while ((size = nl_recv(ev->sock, &nla, &buf, NULL)) > 0) {
-+-			if (nla.nl_pid == 0)
-+-				handle_hotplug_msg((char *) buf, size);
-++	while ((size = nl_recv(ev->sock, &nla, &buf, NULL)) > 0) {
-++		if (nla.nl_pid == 0)
-++			handle_hotplug_msg((char *) buf, size);
-+ 
-+-			free(buf);
-+-		}
-+-		return;
-++		free(buf);
-+ 	}
-+ 
-+-	if (getsockopt(u->fd, SOL_SOCKET, SO_ERROR, (void *)&err, &errlen))
-+-		goto abort;
-++	switch (-size) {
-++	case 0:
-++		return;
-+ 
-+-	switch(err) {
-+-	case ENOBUFS:
-++	case NLE_NOMEM:
-+ 		/* Increase rx buffer size on netlink socket */
-+ 		ev->bufsize *= 2;
-+ 		if (nl_socket_set_buffer_size(ev->sock, ev->bufsize, 0))
-+@@ -818,7 +807,6 @@ handle_hotplug_event(struct uloop_fd *u,
-+ 	default:
-+ 		goto abort;
-+ 	}
-+-	u->error = false;
-+ 	return;
-+ 
-+ abort:
-- 
GitLab