mirror of
https://github.com/torvalds/linux.git
synced 2026-06-06 21:45:45 +02:00
wcn36xx: fix RX BD rate mapping for 5GHz legacy rates
[ Upstream commitcfdf6b19e7] The linear mapping between the BD rate field and the driver's 5GHz legacy rates table (wcn_5ghz_rates) does not only apply for the latter four rates -- it applies to all eight rates. Fixes:6ea131acea("wcn36xx: Fix warning due to bad rate_idx") Signed-off-by: Benjamin Li <benl@squareup.com> Tested-by: Loic Poulain <loic.poulain@linaro.org> Signed-off-by: Kalle Valo <kvalo@codeaurora.org> Link: https://lore.kernel.org/r/20211104010548.1107405-3-benl@squareup.com Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
22406ed4e3
commit
2fe056d979
|
|
@ -237,7 +237,6 @@ int wcn36xx_rx_skb(struct wcn36xx *wcn, struct sk_buff *skb)
|
||||||
const struct wcn36xx_rate *rate;
|
const struct wcn36xx_rate *rate;
|
||||||
struct ieee80211_hdr *hdr;
|
struct ieee80211_hdr *hdr;
|
||||||
struct wcn36xx_rx_bd *bd;
|
struct wcn36xx_rx_bd *bd;
|
||||||
struct ieee80211_supported_band *sband;
|
|
||||||
u16 fc, sn;
|
u16 fc, sn;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
@ -295,12 +294,11 @@ int wcn36xx_rx_skb(struct wcn36xx *wcn, struct sk_buff *skb)
|
||||||
status.enc_flags = rate->encoding_flags;
|
status.enc_flags = rate->encoding_flags;
|
||||||
status.bw = rate->bw;
|
status.bw = rate->bw;
|
||||||
status.rate_idx = rate->mcs_or_legacy_index;
|
status.rate_idx = rate->mcs_or_legacy_index;
|
||||||
sband = wcn->hw->wiphy->bands[status.band];
|
|
||||||
status.nss = 1;
|
status.nss = 1;
|
||||||
|
|
||||||
if (status.band == NL80211_BAND_5GHZ &&
|
if (status.band == NL80211_BAND_5GHZ &&
|
||||||
status.encoding == RX_ENC_LEGACY &&
|
status.encoding == RX_ENC_LEGACY &&
|
||||||
status.rate_idx >= sband->n_bitrates) {
|
status.rate_idx >= 4) {
|
||||||
/* no dsss rates in 5Ghz rates table */
|
/* no dsss rates in 5Ghz rates table */
|
||||||
status.rate_idx -= 4;
|
status.rate_idx -= 4;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user