Commit d0b03439 authored by Adrian Chadd's avatar Adrian Chadd Committed by Kalle Valo

b43: don't unconditionally fall back to CCK if the rate is 6MB OFDM.

Check the current PHY operating mode (gmode) to see if we should
fall back from 6MB OFDM to 11MB CCK.  For 5GHz operation this isn't
allowed.

Note, the fallback lookup is only done for RTS rates; normal fallback
rates are done via mac80211 and aren't affected by this change.
Signed-off-by: default avatarAdrian Chadd <adrian@freebsd.org>
Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
parent b7467401
...@@ -205,7 +205,7 @@ static u16 b43_generate_tx_phy_ctl1(struct b43_wldev *dev, u8 bitrate) ...@@ -205,7 +205,7 @@ static u16 b43_generate_tx_phy_ctl1(struct b43_wldev *dev, u8 bitrate)
return control; return control;
} }
static u8 b43_calc_fallback_rate(u8 bitrate) static u8 b43_calc_fallback_rate(u8 bitrate, int gmode)
{ {
switch (bitrate) { switch (bitrate) {
case B43_CCK_RATE_1MB: case B43_CCK_RATE_1MB:
...@@ -216,8 +216,15 @@ static u8 b43_calc_fallback_rate(u8 bitrate) ...@@ -216,8 +216,15 @@ static u8 b43_calc_fallback_rate(u8 bitrate)
return B43_CCK_RATE_2MB; return B43_CCK_RATE_2MB;
case B43_CCK_RATE_11MB: case B43_CCK_RATE_11MB:
return B43_CCK_RATE_5MB; return B43_CCK_RATE_5MB;
/*
* Don't just fallback to CCK; it may be in 5GHz operation
* and falling back to CCK won't work out very well.
*/
case B43_OFDM_RATE_6MB: case B43_OFDM_RATE_6MB:
if (gmode)
return B43_CCK_RATE_5MB; return B43_CCK_RATE_5MB;
else
return B43_OFDM_RATE_6MB;
case B43_OFDM_RATE_9MB: case B43_OFDM_RATE_9MB:
return B43_OFDM_RATE_6MB; return B43_OFDM_RATE_6MB;
case B43_OFDM_RATE_12MB: case B43_OFDM_RATE_12MB:
...@@ -438,7 +445,7 @@ int b43_generate_txhdr(struct b43_wldev *dev, ...@@ -438,7 +445,7 @@ int b43_generate_txhdr(struct b43_wldev *dev,
rts_rate = rts_cts_rate ? rts_cts_rate->hw_value : B43_CCK_RATE_1MB; rts_rate = rts_cts_rate ? rts_cts_rate->hw_value : B43_CCK_RATE_1MB;
rts_rate_ofdm = b43_is_ofdm_rate(rts_rate); rts_rate_ofdm = b43_is_ofdm_rate(rts_rate);
rts_rate_fb = b43_calc_fallback_rate(rts_rate); rts_rate_fb = b43_calc_fallback_rate(rts_rate, phy->gmode);
rts_rate_fb_ofdm = b43_is_ofdm_rate(rts_rate_fb); rts_rate_fb_ofdm = b43_is_ofdm_rate(rts_rate_fb);
if (rates[0].flags & IEEE80211_TX_RC_USE_CTS_PROTECT) { if (rates[0].flags & IEEE80211_TX_RC_USE_CTS_PROTECT) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment