mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-16 09:50:26 +00:00
323e249ce8
This updates mac80211 to version 6.1.97-1. This code is based on Linux 6.1.97 and contains all fixes included in the upstream wireless subsystem from that kernel version. This includes many bugfixes and also some security fixes. The removed patches are already integrated in upstream Linux 6.1.97 or in backports. The following patches were integrated in upstream Linux: ath11k/0013-wifi-ath11k-synchronize-ath11k_mac_he_gi_to_nl80211_.patch ath11k/0035-wifi-ath11k-Use-platform_get_irq-to-get-the-interrup.patch ath11k/0036-wifi-ath11k-fix-SAC-bug-on-peer-addition-with-sta-ba.patch ath11k/0047-wifi-ath11k-fix-deinitialization-of-firmware-resourc.patch ath11k/0053-wifi-ath11k-fix-writing-to-unintended-memory-region.patch ath11k/0060-wifi-ath11k-Ignore-frags-from-uninitialized-peer-in-.patch ath11k/0065-wifi-ath11k-fix-tx-status-reporting-in-encap-offload.patch ath11k/0067-wifi-ath11k-Fix-SKB-corruption-in-REO-destination-ri.patch ath11k/0069-wifi-ath11k-fix-registration-of-6Ghz-only-phy-withou.patch ath11k/0080-wifi-ath11k-add-support-default-regdb-while-searchin.patch ath11k/0085-wifi-ath11k-fix-memory-leak-in-WMI-firmware-stats.patch ath11k/0086-wifi-ath11k-Add-missing-check-for-ioremap.patch ath11k/0096-wifi-ath11k-fix-boot-failure-with-one-MSI-vector.patch subsys/337-wifi-mac80211-fix-race-condition-on-enabling-fast-xm.patch The following patches were integrated in upstream backports: ath11k/901-wifi-ath11k-pci-fix-compilation-in-5.16-and-older.patch build/080-resv_start_op.patch build/110-backport_napi_build_skb.patch The following files are missing in backports, we do not have to remove them any more. Some were already missing before some were removed in this update: include/linux/cordic.h include/linux/crc8.h include/linux/eeprom_93cx6.h include/linux/wl12xx.h include/net/ieee80211.h backport-include/linux/bcm47xx_nvram.h include/linux/ath9k_platform.h include/net/bluetooth/ backports ships a dummy Mediatek wed header for older kernel versions. We backported the feature in our kernel, remove the dummy header: backport-include/linux/soc/mediatek/mtk_wed.h Remove header files for subsystems used form the mainline kernel: include/trace/events/qrtr.h include/net/rsi_91x.h backport-include/linux/platform_data/brcmnand.h Link: https://github.com/openwrt/openwrt/pull/15827 Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
150 lines
4.6 KiB
Diff
150 lines
4.6 KiB
Diff
From: Felix Fietkau <nbd@nbd.name>
|
|
Date: Mon, 20 Mar 2023 14:28:08 +0100
|
|
Subject: [PATCH] wifi: mac80211: add support for letting drivers register tc
|
|
offload support
|
|
|
|
On newer MediaTek SoCs (e.g. MT7986), WLAN->WLAN or WLAN->Ethernet flows can
|
|
be offloaded by the SoC. In order to support that, the .ndo_setup_tc op is
|
|
needed.
|
|
|
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
---
|
|
|
|
--- a/include/net/mac80211.h
|
|
+++ b/include/net/mac80211.h
|
|
@@ -4201,6 +4201,10 @@ struct ieee80211_prep_tx_info {
|
|
* Note that a sta can also be inserted or removed with valid links,
|
|
* i.e. passed to @sta_add/@sta_state with sta->valid_links not zero.
|
|
* In fact, cannot change from having valid_links and not having them.
|
|
+ * @net_setup_tc: Called from .ndo_setup_tc in order to prepare hardware
|
|
+ * flow offloading for flows originating from the vif.
|
|
+ * Note that the driver must not assume that the vif driver_data is valid
|
|
+ * at this point, since the callback can be called during netdev teardown.
|
|
*/
|
|
struct ieee80211_ops {
|
|
void (*tx)(struct ieee80211_hw *hw,
|
|
@@ -4556,6 +4560,11 @@ struct ieee80211_ops {
|
|
struct ieee80211_vif *vif,
|
|
struct ieee80211_sta *sta,
|
|
u16 old_links, u16 new_links);
|
|
+ int (*net_setup_tc)(struct ieee80211_hw *hw,
|
|
+ struct ieee80211_vif *vif,
|
|
+ struct net_device *dev,
|
|
+ enum tc_setup_type type,
|
|
+ void *type_data);
|
|
};
|
|
|
|
/**
|
|
--- a/net/mac80211/driver-ops.h
|
|
+++ b/net/mac80211/driver-ops.h
|
|
@@ -1470,6 +1470,23 @@ static inline int drv_net_fill_forward_p
|
|
return ret;
|
|
}
|
|
|
|
+static inline int drv_net_setup_tc(struct ieee80211_local *local,
|
|
+ struct ieee80211_sub_if_data *sdata,
|
|
+ struct net_device *dev,
|
|
+ enum tc_setup_type type, void *type_data)
|
|
+{
|
|
+ int ret = -EOPNOTSUPP;
|
|
+
|
|
+ sdata = get_bss_sdata(sdata);
|
|
+ trace_drv_net_setup_tc(local, sdata, type);
|
|
+ if (local->ops->net_setup_tc)
|
|
+ ret = local->ops->net_setup_tc(&local->hw, &sdata->vif, dev,
|
|
+ type, type_data);
|
|
+ trace_drv_return_int(local, ret);
|
|
+
|
|
+ return ret;
|
|
+}
|
|
+
|
|
int drv_change_vif_links(struct ieee80211_local *local,
|
|
struct ieee80211_sub_if_data *sdata,
|
|
u16 old_links, u16 new_links,
|
|
--- a/net/mac80211/ieee80211_i.h
|
|
+++ b/net/mac80211/ieee80211_i.h
|
|
@@ -1944,7 +1944,8 @@ void ieee80211_color_collision_detection
|
|
/* interface handling */
|
|
#define MAC80211_SUPPORTED_FEATURES_TX (NETIF_F_IP_CSUM | NETIF_F_IPV6_CSUM | \
|
|
NETIF_F_HW_CSUM | NETIF_F_SG | \
|
|
- NETIF_F_HIGHDMA | NETIF_F_GSO_SOFTWARE)
|
|
+ NETIF_F_HIGHDMA | NETIF_F_GSO_SOFTWARE | \
|
|
+ NETIF_F_HW_TC)
|
|
#define MAC80211_SUPPORTED_FEATURES_RX (NETIF_F_RXCSUM)
|
|
#define MAC80211_SUPPORTED_FEATURES (MAC80211_SUPPORTED_FEATURES_TX | \
|
|
MAC80211_SUPPORTED_FEATURES_RX)
|
|
--- a/net/mac80211/iface.c
|
|
+++ b/net/mac80211/iface.c
|
|
@@ -813,6 +813,21 @@ ieee80211_get_stats64(struct net_device
|
|
dev_fetch_sw_netstats(stats, dev->tstats);
|
|
}
|
|
|
|
+static int ieee80211_netdev_setup_tc(struct net_device *dev,
|
|
+ enum tc_setup_type type, void *type_data)
|
|
+{
|
|
+ struct ieee80211_sub_if_data *sdata;
|
|
+ struct ieee80211_local *local;
|
|
+
|
|
+ sdata = IEEE80211_DEV_TO_SUB_IF(dev);
|
|
+ local = sdata->local;
|
|
+
|
|
+ if (!local->ops->net_setup_tc)
|
|
+ return -EOPNOTSUPP;
|
|
+
|
|
+ return drv_net_setup_tc(local, sdata, dev, type, type_data);
|
|
+}
|
|
+
|
|
static const struct net_device_ops ieee80211_dataif_ops = {
|
|
.ndo_open = ieee80211_open,
|
|
.ndo_stop = ieee80211_stop,
|
|
@@ -821,6 +836,7 @@ static const struct net_device_ops ieee8
|
|
.ndo_set_rx_mode = ieee80211_set_multicast_list,
|
|
.ndo_set_mac_address = ieee80211_change_mac,
|
|
.ndo_get_stats64 = ieee80211_get_stats64,
|
|
+ .ndo_setup_tc = ieee80211_netdev_setup_tc,
|
|
};
|
|
|
|
#if LINUX_VERSION_IS_GEQ(5,2,0)
|
|
@@ -945,6 +961,7 @@ static const struct net_device_ops ieee8
|
|
#if LINUX_VERSION_IS_GEQ(5,13,0)
|
|
.ndo_fill_forward_path = ieee80211_netdev_fill_forward_path,
|
|
#endif
|
|
+ .ndo_setup_tc = ieee80211_netdev_setup_tc,
|
|
};
|
|
|
|
static bool ieee80211_iftype_supports_hdr_offload(enum nl80211_iftype iftype)
|
|
--- a/net/mac80211/trace.h
|
|
+++ b/net/mac80211/trace.h
|
|
@@ -2478,6 +2478,31 @@ DEFINE_EVENT(sta_event, drv_net_fill_for
|
|
TP_ARGS(local, sdata, sta)
|
|
);
|
|
|
|
+TRACE_EVENT(drv_net_setup_tc,
|
|
+ TP_PROTO(struct ieee80211_local *local,
|
|
+ struct ieee80211_sub_if_data *sdata,
|
|
+ u8 type),
|
|
+
|
|
+ TP_ARGS(local, sdata, type),
|
|
+
|
|
+ TP_STRUCT__entry(
|
|
+ LOCAL_ENTRY
|
|
+ VIF_ENTRY
|
|
+ __field(u8, type)
|
|
+ ),
|
|
+
|
|
+ TP_fast_assign(
|
|
+ LOCAL_ASSIGN;
|
|
+ VIF_ASSIGN;
|
|
+ __entry->type = type;
|
|
+ ),
|
|
+
|
|
+ TP_printk(
|
|
+ LOCAL_PR_FMT VIF_PR_FMT " type:%d\n",
|
|
+ LOCAL_PR_ARG, VIF_PR_ARG, __entry->type
|
|
+ )
|
|
+);
|
|
+
|
|
TRACE_EVENT(drv_change_vif_links,
|
|
TP_PROTO(struct ieee80211_local *local,
|
|
struct ieee80211_sub_if_data *sdata,
|