diff options
author | Johannes Berg <johannes.berg@intel.com> | 2012-01-20 07:55:27 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-02-06 14:50:37 -0500 |
commit | 66e67e418908442389d3a9e6509985f01cbaf9b0 (patch) | |
tree | 01fad87d0d47f5887497c569d98cee20fa1f0f29 /net/mac80211/cfg.c | |
parent | 4c0c0b75e0c35ddb8f61c06bcbffede63ab4f4a2 (diff) |
mac80211: redesign auth/assoc
This is the second part of the auth/assoc redesign,
the mac80211 part. This moves the auth/assoc code
out of the work abstraction and into the MLME, so
that we don't flip channels all the time etc.
The only downside is that when we are associated,
we need to drop the association in order to create
a connection to another AP, but for most drivers
this is actually desirable and the ability to do
was never used by any applications. If we want to
implement resource reservation with FT-OTA, we'd
probably best do it with explicit R-O-C in wpa_s.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/cfg.c')
-rw-r--r-- | net/mac80211/cfg.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index d15ba0d0de94..c3de921c8cfd 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c | |||
@@ -2028,7 +2028,7 @@ ieee80211_offchan_tx_done(struct ieee80211_work *wk, struct sk_buff *skb) | |||
2028 | if (wk->offchan_tx.wait && !wk->offchan_tx.status) | 2028 | if (wk->offchan_tx.wait && !wk->offchan_tx.status) |
2029 | cfg80211_mgmt_tx_status(wk->sdata->dev, | 2029 | cfg80211_mgmt_tx_status(wk->sdata->dev, |
2030 | (unsigned long) wk->offchan_tx.frame, | 2030 | (unsigned long) wk->offchan_tx.frame, |
2031 | wk->ie, wk->ie_len, false, GFP_KERNEL); | 2031 | wk->data, wk->data_len, false, GFP_KERNEL); |
2032 | 2032 | ||
2033 | return WORK_DONE_DESTROY; | 2033 | return WORK_DONE_DESTROY; |
2034 | } | 2034 | } |
@@ -2179,8 +2179,8 @@ static int ieee80211_mgmt_tx(struct wiphy *wiphy, struct net_device *dev, | |||
2179 | wk->done = ieee80211_offchan_tx_done; | 2179 | wk->done = ieee80211_offchan_tx_done; |
2180 | wk->offchan_tx.frame = skb; | 2180 | wk->offchan_tx.frame = skb; |
2181 | wk->offchan_tx.wait = wait; | 2181 | wk->offchan_tx.wait = wait; |
2182 | wk->ie_len = len; | 2182 | wk->data_len = len; |
2183 | memcpy(wk->ie, buf, len); | 2183 | memcpy(wk->data, buf, len); |
2184 | 2184 | ||
2185 | ieee80211_add_work(wk); | 2185 | ieee80211_add_work(wk); |
2186 | return 0; | 2186 | return 0; |