diff options
author | Johannes Berg <johannes.berg@intel.com> | 2012-04-03 14:35:57 +0200 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-04-11 16:23:49 -0400 |
commit | 4b6f1dd6a6faf4ed8d209bbd548e78b15e55aee8 (patch) | |
tree | 7d79667ca414d70b99cb82a646d1a3c2cc466670 /net/mac80211/pm.c | |
parent | 3edaf3e61fda3aa9ff8d38445bf92f2bec23bf63 (diff) | |
download | linux-4b6f1dd6a6faf4ed8d209bbd548e78b15e55aee8.tar.gz linux-4b6f1dd6a6faf4ed8d209bbd548e78b15e55aee8.tar.bz2 linux-4b6f1dd6a6faf4ed8d209bbd548e78b15e55aee8.zip |
mac80211: add explicit monitor interface if needed
The queue mapping redesign that I'm planning to do
will break pure injection unless we handle monitor
interfaces explicitly. One possible option would
be to have the driver tell mac80211 about monitor
mode queues etc., but that would duplicate the API
since we already need to have queue assignments
handled per virtual interface.
So in order to solve this, have a virtual monitor
interface that is added whenever all active vifs
are monitors. We could also use the state of one
of the monitor interfaces, but managing that would
be complicated, so allocate separate state.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/pm.c')
-rw-r--r-- | net/mac80211/pm.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/net/mac80211/pm.c b/net/mac80211/pm.c index ef8eba1d736d..af1c4e26e965 100644 --- a/net/mac80211/pm.c +++ b/net/mac80211/pm.c @@ -127,6 +127,10 @@ int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan) drv_remove_interface(local, sdata); } + sdata = rtnl_dereference(local->monitor_sdata); + if (sdata) + drv_remove_interface(local, sdata); + /* stop hardware - this must stop RX */ if (local->open_count) ieee80211_stop_device(local); |