diff options
author | Johannes Berg <johannes.berg@intel.com> | 2012-01-20 07:55:18 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-02-06 14:48:24 -0500 |
commit | 077f49392819608084c6d8d20e3dcca230afe07d (patch) | |
tree | 7b19e4537933e9c7e0524421d16701576c4b74b2 /net/mac80211/util.c | |
parent | c8987876e9bf9b7b83e75b325586bc77ea8ac825 (diff) |
mac80211: simplify AP_VLAN handling
Setting keys and updating TKIP keys must use the
BSS sdata (not AP_VLAN), so we translate. Move
the translation into driver-ops wrappers instead
of having it inline in the code to simplify the
normal code flow.
The same can be done for sta_add/remove which
already does the translation in the wrapper.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/util.c')
-rw-r--r-- | net/mac80211/util.c | 11 |
1 files changed, 2 insertions, 9 deletions
diff --git a/net/mac80211/util.c b/net/mac80211/util.c index d82d886d0867..d4966e88aa49 100644 --- a/net/mac80211/util.c +++ b/net/mac80211/util.c | |||
@@ -1184,15 +1184,8 @@ int ieee80211_reconfig(struct ieee80211_local *local) | |||
1184 | /* add STAs back */ | 1184 | /* add STAs back */ |
1185 | mutex_lock(&local->sta_mtx); | 1185 | mutex_lock(&local->sta_mtx); |
1186 | list_for_each_entry(sta, &local->sta_list, list) { | 1186 | list_for_each_entry(sta, &local->sta_list, list) { |
1187 | if (sta->uploaded) { | 1187 | if (sta->uploaded) |
1188 | sdata = sta->sdata; | 1188 | WARN_ON(drv_sta_add(local, sta->sdata, &sta->sta)); |
1189 | if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN) | ||
1190 | sdata = container_of(sdata->bss, | ||
1191 | struct ieee80211_sub_if_data, | ||
1192 | u.ap); | ||
1193 | |||
1194 | WARN_ON(drv_sta_add(local, sdata, &sta->sta)); | ||
1195 | } | ||
1196 | } | 1189 | } |
1197 | mutex_unlock(&local->sta_mtx); | 1190 | mutex_unlock(&local->sta_mtx); |
1198 | 1191 | ||