[PATCH] softmac: reduce default rate to 11Mbps.
We don't make much of an attempt to fall back to lower rates, and 54M just isn't reliable enough for many people. In fact, it's not clear we even set it to 11M if we're trying to associate with an 802.11b AP. This patch makes us default to 11M, which ought to work for most people. When we actually handle dynamic rate adjustment, we can reconsider the defaults -- but even then, probably it makes as much sense to start at 11M and adjust it upwards as it does to start at 54M and reduce it. Signed-off-by: David Woodhouse <dwmw2@infradead.org> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
16f4352733
commit
2638fed7cc
@ -183,16 +183,21 @@ void ieee80211softmac_start(struct net_device *dev)
|
|||||||
*/
|
*/
|
||||||
if (mac->txrates_change)
|
if (mac->txrates_change)
|
||||||
oldrates = mac->txrates;
|
oldrates = mac->txrates;
|
||||||
if (ieee->modulation & IEEE80211_OFDM_MODULATION) {
|
/* FIXME: We don't correctly handle backing down to lower
|
||||||
mac->txrates.default_rate = IEEE80211_OFDM_RATE_54MB;
|
rates, so 801.11g devices start off at 11M for now. People
|
||||||
change |= IEEE80211SOFTMAC_TXRATECHG_DEFAULT;
|
can manually change it if they really need to, but 11M is
|
||||||
mac->txrates.default_fallback = IEEE80211_OFDM_RATE_24MB;
|
more reliable. Note similar logic in
|
||||||
change |= IEEE80211SOFTMAC_TXRATECHG_DEFAULT_FBACK;
|
ieee80211softmac_wx_set_rate() */
|
||||||
} else if (ieee->modulation & IEEE80211_CCK_MODULATION) {
|
if (ieee->modulation & IEEE80211_CCK_MODULATION) {
|
||||||
mac->txrates.default_rate = IEEE80211_CCK_RATE_11MB;
|
mac->txrates.default_rate = IEEE80211_CCK_RATE_11MB;
|
||||||
change |= IEEE80211SOFTMAC_TXRATECHG_DEFAULT;
|
change |= IEEE80211SOFTMAC_TXRATECHG_DEFAULT;
|
||||||
mac->txrates.default_fallback = IEEE80211_CCK_RATE_5MB;
|
mac->txrates.default_fallback = IEEE80211_CCK_RATE_5MB;
|
||||||
change |= IEEE80211SOFTMAC_TXRATECHG_DEFAULT_FBACK;
|
change |= IEEE80211SOFTMAC_TXRATECHG_DEFAULT_FBACK;
|
||||||
|
} else if (ieee->modulation & IEEE80211_OFDM_MODULATION) {
|
||||||
|
mac->txrates.default_rate = IEEE80211_OFDM_RATE_54MB;
|
||||||
|
change |= IEEE80211SOFTMAC_TXRATECHG_DEFAULT;
|
||||||
|
mac->txrates.default_fallback = IEEE80211_OFDM_RATE_24MB;
|
||||||
|
change |= IEEE80211SOFTMAC_TXRATECHG_DEFAULT_FBACK;
|
||||||
} else
|
} else
|
||||||
assert(0);
|
assert(0);
|
||||||
if (mac->txrates_change)
|
if (mac->txrates_change)
|
||||||
|
@ -135,11 +135,15 @@ ieee80211softmac_wx_set_rate(struct net_device *net_dev,
|
|||||||
int err = -EINVAL;
|
int err = -EINVAL;
|
||||||
|
|
||||||
if (in_rate == -1) {
|
if (in_rate == -1) {
|
||||||
/* automatic detect */
|
/* FIXME: We don't correctly handle backing down to lower
|
||||||
if (ieee->modulation & IEEE80211_OFDM_MODULATION)
|
rates, so 801.11g devices start off at 11M for now. People
|
||||||
in_rate = 54000000;
|
can manually change it if they really need to, but 11M is
|
||||||
else
|
more reliable. Note similar logic in
|
||||||
|
ieee80211softmac_wx_set_rate() */
|
||||||
|
if (ieee->modulation & IEEE80211_CCK_MODULATION)
|
||||||
in_rate = 11000000;
|
in_rate = 11000000;
|
||||||
|
else
|
||||||
|
in_rate = 54000000;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (in_rate) {
|
switch (in_rate) {
|
||||||
|
Loading…
Reference in New Issue
Block a user