Commit 2638fed7 authored by David Woodhouse's avatar David Woodhouse Committed by John W. Linville

[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: default avatarDavid Woodhouse <dwmw2@infradead.org>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 16f43527
...@@ -183,16 +183,21 @@ void ieee80211softmac_start(struct net_device *dev) ...@@ -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, ...@@ -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) {
......
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