mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-12 16:03:13 +00:00
ba249bc955
If no mcast_rate is set for the wifi-iface then there is no rate_idx (0)
set for the bss. This can break for example 5GHz meshpoint interfaces
because 0 maps to a CCK rate (11Mbit/s).
It must also be avoided that the ath10k-ct internal state for the rates is
not synced with the mac80211 rates state. Otherwise, the user specified
rate (e.g. a wifi-iface mcast_rate for a meshpoint interface) will only be
set on startup. And a short while after that, ath10k-ct specific code in
ath10k_check_apply_special_rates is missing a valid rate in its own
structures and is then recalculating a new default rate. This default rate
is in most situations not the requested rate.
Fixes: 4df3c71cd4
("ath10k-ct: Update to 2018-12-11 and use version based on 4.19")
Signed-off-by: Sven Eckelmann <sven@narfation.org>
38 lines
1.3 KiB
Diff
38 lines
1.3 KiB
Diff
From: Sven Eckelmann <sven@narfation.org>
|
|
Date: Tue, 26 Feb 2019 08:06:35 +0100
|
|
Subject: ath10k-ct: apply mac80211 rates to ath10k-ct rate state
|
|
|
|
The rates from mac80211 have to be copied to the state of ath10k-ct or
|
|
otherwise the ath10k_check_apply_special_rates function overwrites
|
|
them again with some default values. This breaks for example the
|
|
mcast_rate set for a wifi-iface.
|
|
|
|
Signed-off-by: Sven Eckelmann <sven@narfation.org>
|
|
|
|
--- a/ath10k-4.19/mac.c
|
|
+++ b/ath10k-4.19/mac.c
|
|
@@ -6460,6 +6460,7 @@ static void ath10k_bss_info_changed(stru
|
|
"mac vdev %d mcast_rate %x\n",
|
|
arvif->vdev_id, rate);
|
|
|
|
+ arvif->mcast_rate[band] = rate;
|
|
vdev_param = ar->wmi.vdev_param->mcast_data_rate;
|
|
ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id,
|
|
vdev_param, rate);
|
|
@@ -6468,6 +6469,7 @@ static void ath10k_bss_info_changed(stru
|
|
"failed to set mcast rate on vdev %i: %d\n",
|
|
arvif->vdev_id, ret);
|
|
|
|
+ arvif->bcast_rate[band] = rate;
|
|
vdev_param = ar->wmi.vdev_param->bcast_data_rate;
|
|
ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id,
|
|
vdev_param, rate);
|
|
@@ -6494,6 +6496,7 @@ static void ath10k_bss_info_changed(stru
|
|
return;
|
|
}
|
|
|
|
+ arvif->mgt_rate[def.chan->band] = hw_rate_code;
|
|
vdev_param = ar->wmi.vdev_param->mgmt_rate;
|
|
ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
|
|
hw_rate_code);
|