mac80211: handle power constraint/country IE better
authorJohannes Berg <johannes.berg@intel.com>
Wed, 5 Sep 2012 11:41:37 +0000 (13:41 +0200)
committerJohannes Berg <johannes.berg@intel.com>
Fri, 14 Sep 2012 12:06:51 +0000 (14:06 +0200)
commit04b7b2ff50fc77380c1e711f1d7223734547e41b
tree0f048db9f4324e9db134bdbbddc139df9bceffab
parent3a6a0d8ee88d23e7dda28808c2c890c4db50ccb2
mac80211: handle power constraint/country IE better

Currently, mac80211 uses the power constraint IE, and reduces
the regulatory max TX power by it. This can cause issues if
the AP is advertising a large power constraint value matching
a high TX power in its country IE, for example in this case:

...
Country: US  Environment: Indoor/Outdoor
    ...
    Channels [157 - 157] @ 30 dBm
    ...
Power constraint: 13 dB
...

What happened here is that our local regulatory TX power is
15 dBm, and gets reduced by 13 dB so we end up with only
2 dBm effective TX power, which is way too low.

Instead, handle the country IE/power constraint IE combined
and restrict our TX power to the max of the regulatory power
and the maximum power advertised by the AP, in this case
17 dBm (= 30 dBm - 13 dB).

Also print a message when this happens to let the user know
and help us debug issues with it.

Reported-by: Carl A. Cook <CACook@quantum-equities.com>
Tested-by: Carl A. Cook <CACook@quantum-equities.com>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
net/mac80211/ieee80211_i.h
net/mac80211/main.c
net/mac80211/mlme.c