diff options
author | Johannes Berg <johannes.berg@intel.com> | 2012-10-24 04:59:25 -0400 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2012-10-30 04:11:34 -0400 |
commit | 1ea6f9c0d48b11b6ec3ec4b5579ec74fc3951cf8 (patch) | |
tree | 5a589d0bccfcac6ba0952942a04482b99752ddcc /net/mac80211/debugfs_netdev.c | |
parent | c8442118ad9cd05cfe3b993f058e70ab25b1009a (diff) |
mac80211: handle TX power per virtual interface
Even before channel contexts/multi-channel, having a
single global TX power limit was already problematic,
in particular if two managed interfaces connected to
two APs with different power constraints. The channel
context introduction completely broke this though and
in fact I had disabled TX power configuration there
for drivers using channel contexts.
Change everything to track TX power per interface so
that different user settings and different channel
maxima are treated correctly. Also continue tracking
the global TX power though for compatibility with
applications that attempt to configure the wiphy's
TX power globally.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/mac80211/debugfs_netdev.c')
-rw-r--r-- | net/mac80211/debugfs_netdev.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/net/mac80211/debugfs_netdev.c b/net/mac80211/debugfs_netdev.c index 3393ad5b8ab1..07c5721323ca 100644 --- a/net/mac80211/debugfs_netdev.c +++ b/net/mac80211/debugfs_netdev.c | |||
@@ -168,6 +168,9 @@ IEEE80211_IF_FILE(rc_rateidx_mcs_mask_5ghz, | |||
168 | IEEE80211_IF_FILE(flags, flags, HEX); | 168 | IEEE80211_IF_FILE(flags, flags, HEX); |
169 | IEEE80211_IF_FILE(state, state, LHEX); | 169 | IEEE80211_IF_FILE(state, state, LHEX); |
170 | IEEE80211_IF_FILE(channel_type, vif.bss_conf.channel_type, DEC); | 170 | IEEE80211_IF_FILE(channel_type, vif.bss_conf.channel_type, DEC); |
171 | IEEE80211_IF_FILE(txpower, vif.bss_conf.txpower, DEC); | ||
172 | IEEE80211_IF_FILE(ap_power_level, ap_power_level, DEC); | ||
173 | IEEE80211_IF_FILE(user_power_level, user_power_level, DEC); | ||
171 | 174 | ||
172 | /* STA attributes */ | 175 | /* STA attributes */ |
173 | IEEE80211_IF_FILE(bssid, u.mgd.bssid, MAC); | 176 | IEEE80211_IF_FILE(bssid, u.mgd.bssid, MAC); |
@@ -632,6 +635,9 @@ static void add_files(struct ieee80211_sub_if_data *sdata) | |||
632 | DEBUGFS_ADD(flags); | 635 | DEBUGFS_ADD(flags); |
633 | DEBUGFS_ADD(state); | 636 | DEBUGFS_ADD(state); |
634 | DEBUGFS_ADD(channel_type); | 637 | DEBUGFS_ADD(channel_type); |
638 | DEBUGFS_ADD(txpower); | ||
639 | DEBUGFS_ADD(user_power_level); | ||
640 | DEBUGFS_ADD(ap_power_level); | ||
635 | 641 | ||
636 | if (sdata->vif.type != NL80211_IFTYPE_MONITOR) | 642 | if (sdata->vif.type != NL80211_IFTYPE_MONITOR) |
637 | add_common_files(sdata); | 643 | add_common_files(sdata); |