Commit 077f4939 authored by Johannes Berg's avatar Johannes Berg Committed by John W. Linville

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: default avatarJohannes Berg <johannes.berg@intel.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent c8987876
...@@ -253,6 +253,7 @@ static inline int drv_set_key(struct ieee80211_local *local, ...@@ -253,6 +253,7 @@ static inline int drv_set_key(struct ieee80211_local *local,
might_sleep(); might_sleep();
sdata = get_bss_sdata(sdata);
check_sdata_in_driver(sdata); check_sdata_in_driver(sdata);
trace_drv_set_key(local, cmd, sdata, sta, key); trace_drv_set_key(local, cmd, sdata, sta, key);
...@@ -272,6 +273,7 @@ static inline void drv_update_tkip_key(struct ieee80211_local *local, ...@@ -272,6 +273,7 @@ static inline void drv_update_tkip_key(struct ieee80211_local *local,
if (sta) if (sta)
ista = &sta->sta; ista = &sta->sta;
sdata = get_bss_sdata(sdata);
check_sdata_in_driver(sdata); check_sdata_in_driver(sdata);
trace_drv_update_tkip_key(local, sdata, conf, ista, iv32); trace_drv_update_tkip_key(local, sdata, conf, ista, iv32);
......
...@@ -123,9 +123,6 @@ static int ieee80211_key_enable_hw_accel(struct ieee80211_key *key) ...@@ -123,9 +123,6 @@ static int ieee80211_key_enable_hw_accel(struct ieee80211_key *key)
*/ */
if (!(key->conf.flags & IEEE80211_KEY_FLAG_PAIRWISE)) if (!(key->conf.flags & IEEE80211_KEY_FLAG_PAIRWISE))
goto out_unsupported; goto out_unsupported;
sdata = container_of(sdata->bss,
struct ieee80211_sub_if_data,
u.ap);
} }
ret = drv_set_key(key->local, SET_KEY, sdata, sta, &key->conf); ret = drv_set_key(key->local, SET_KEY, sdata, sta, &key->conf);
...@@ -187,11 +184,6 @@ static void ieee80211_key_disable_hw_accel(struct ieee80211_key *key) ...@@ -187,11 +184,6 @@ static void ieee80211_key_disable_hw_accel(struct ieee80211_key *key)
(key->conf.flags & IEEE80211_KEY_FLAG_PUT_IV_SPACE))) (key->conf.flags & IEEE80211_KEY_FLAG_PUT_IV_SPACE)))
increment_tailroom_need_count(sdata); increment_tailroom_need_count(sdata);
if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN)
sdata = container_of(sdata->bss,
struct ieee80211_sub_if_data,
u.ap);
ret = drv_set_key(key->local, DISABLE_KEY, sdata, ret = drv_set_key(key->local, DISABLE_KEY, sdata,
sta, &key->conf); sta, &key->conf);
......
...@@ -97,15 +97,8 @@ int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan) ...@@ -97,15 +97,8 @@ int __ieee80211_suspend(struct ieee80211_hw *hw, struct cfg80211_wowlan *wowlan)
/* tear down aggregation sessions and remove STAs */ /* tear down aggregation sessions and remove STAs */
mutex_lock(&local->sta_mtx); mutex_lock(&local->sta_mtx);
list_for_each_entry(sta, &local->sta_list, list) { list_for_each_entry(sta, &local->sta_list, list) {
if (sta->uploaded) { if (sta->uploaded)
sdata = sta->sdata; drv_sta_remove(local, sta->sdata, &sta->sta);
if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN)
sdata = container_of(sdata->bss,
struct ieee80211_sub_if_data,
u.ap);
drv_sta_remove(local, sdata, &sta->sta);
}
mesh_plink_quiesce(sta); mesh_plink_quiesce(sta);
} }
......
...@@ -764,14 +764,8 @@ int __must_check __sta_info_destroy(struct sta_info *sta) ...@@ -764,14 +764,8 @@ int __must_check __sta_info_destroy(struct sta_info *sta)
} }
} }
if (sta->uploaded) { if (sta->uploaded)
if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN)
sdata = container_of(sdata->bss,
struct ieee80211_sub_if_data,
u.ap);
drv_sta_remove(local, sdata, &sta->sta); drv_sta_remove(local, sdata, &sta->sta);
sdata = sta->sdata;
}
/* /*
* At this point, after we wait for an RCU grace period, * At this point, after we wait for an RCU grace period,
......
...@@ -1184,15 +1184,8 @@ int ieee80211_reconfig(struct ieee80211_local *local) ...@@ -1184,15 +1184,8 @@ int ieee80211_reconfig(struct ieee80211_local *local)
/* add STAs back */ /* add STAs back */
mutex_lock(&local->sta_mtx); mutex_lock(&local->sta_mtx);
list_for_each_entry(sta, &local->sta_list, list) { list_for_each_entry(sta, &local->sta_list, list) {
if (sta->uploaded) { if (sta->uploaded)
sdata = sta->sdata; WARN_ON(drv_sta_add(local, sta->sdata, &sta->sta));
if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN)
sdata = container_of(sdata->bss,
struct ieee80211_sub_if_data,
u.ap);
WARN_ON(drv_sta_add(local, sdata, &sta->sta));
}
} }
mutex_unlock(&local->sta_mtx); mutex_unlock(&local->sta_mtx);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment