aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2012-12-14 08:22:10 -0500
committerJohannes Berg <johannes.berg@intel.com>2013-01-03 07:01:36 -0500
commitb8dc1a35c88dddcf62ce7bc59a7ed4c38c2f7597 (patch)
tree557b5f33c852896f353349c2d25ddba146848066 /net
parent8da349329ae52462253052f804ef30d086c9911a (diff)
mac80211: further simplify ieee80211_bss_info_change_notify
The special case in the function isn't really needed, instead make the suspend code a bit better and also easier to understand and move the warning into the driver op wrapper inline. Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net')
-rw-r--r--net/mac80211/driver-ops.h6
-rw-r--r--net/mac80211/main.c14
-rw-r--r--net/mac80211/pm.c15
3 files changed, 16 insertions, 19 deletions
diff --git a/net/mac80211/driver-ops.h b/net/mac80211/driver-ops.h
index 608ced41548d..cccc486ae3d0 100644
--- a/net/mac80211/driver-ops.h
+++ b/net/mac80211/driver-ops.h
@@ -207,6 +207,12 @@ static inline void drv_bss_info_changed(struct ieee80211_local *local,
207{ 207{
208 might_sleep(); 208 might_sleep();
209 209
210 WARN_ON_ONCE(changed & (BSS_CHANGED_BEACON |
211 BSS_CHANGED_BEACON_ENABLED) &&
212 sdata->vif.type != NL80211_IFTYPE_AP &&
213 sdata->vif.type != NL80211_IFTYPE_ADHOC &&
214 sdata->vif.type != NL80211_IFTYPE_MESH_POINT);
215
210 check_sdata_in_driver(sdata); 216 check_sdata_in_driver(sdata);
211 217
212 trace_drv_bss_info_changed(local, sdata, info, changed); 218 trace_drv_bss_info_changed(local, sdata, info, changed);
diff --git a/net/mac80211/main.c b/net/mac80211/main.c
index 71a64f49fe61..b719a16eabde 100644
--- a/net/mac80211/main.c
+++ b/net/mac80211/main.c
@@ -231,20 +231,6 @@ void ieee80211_bss_info_change_notify(struct ieee80211_sub_if_data *sdata,
231 return; 231 return;
232 } 232 }
233 233
234 switch (sdata->vif.type) {
235 case NL80211_IFTYPE_AP:
236 case NL80211_IFTYPE_ADHOC:
237 case NL80211_IFTYPE_WDS:
238 case NL80211_IFTYPE_MESH_POINT:
239 break;
240 default:
241 /* do not warn to simplify caller in scan.c */
242 changed &= ~BSS_CHANGED_BEACON_ENABLED;
243 if (WARN_ON(changed & BSS_CHANGED_BEACON))
244 return;
245 break;
246 }
247
248 drv_bss_info_changed(local, sdata, &sdata->vif.bss_conf, changed); 234 drv_bss_info_changed(local, sdata, &sdata->vif.bss_conf, changed);
249} 235}
250 236
diff --git a/net/mac80211/pm.c b/net/mac80211/pm.c
index 712c17ff6e22..8a67d7e982f7 100644
--- a/net/mac80211/pm.c
+++ b/net/mac80211/pm.c
@@ -121,7 +121,7 @@ int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan)
121 121
122 /* remove all interfaces */ 122 /* remove all interfaces */
123 list_for_each_entry(sdata, &local->interfaces, list) { 123 list_for_each_entry(sdata, &local->interfaces, list) {
124 u32 changed = BSS_CHANGED_BEACON_ENABLED; 124 u32 changed = 0;
125 125
126 if (!ieee80211_sdata_running(sdata)) 126 if (!ieee80211_sdata_running(sdata))
127 continue; 127 continue;
@@ -136,14 +136,19 @@ int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan)
136 changed = BSS_CHANGED_ASSOC | 136 changed = BSS_CHANGED_ASSOC |
137 BSS_CHANGED_BSSID | 137 BSS_CHANGED_BSSID |
138 BSS_CHANGED_IDLE; 138 BSS_CHANGED_IDLE;
139 else 139 break;
140 changed = 0; 140 case NL80211_IFTYPE_AP:
141 /* fall through */ 141 case NL80211_IFTYPE_ADHOC:
142 case NL80211_IFTYPE_MESH_POINT:
143 if (sdata->vif.bss_conf.enable_beacon)
144 changed = BSS_CHANGED_BEACON_ENABLED;
145 break;
142 default: 146 default:
143 ieee80211_quiesce(sdata);
144 break; 147 break;
145 } 148 }
146 149
150 ieee80211_quiesce(sdata);
151
147 sdata->suspend_bss_conf = sdata->vif.bss_conf; 152 sdata->suspend_bss_conf = sdata->vif.bss_conf;
148 memset(&sdata->vif.bss_conf, 0, sizeof(sdata->vif.bss_conf)); 153 memset(&sdata->vif.bss_conf, 0, sizeof(sdata->vif.bss_conf));
149 sdata->vif.bss_conf.idle = true; 154 sdata->vif.bss_conf.idle = true;