diff options
author | Johannes Berg <johannes@sipsolutions.net> | 2009-07-02 11:20:43 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-07-10 15:01:53 -0400 |
commit | 19957bb399e2722719c0e20c9ae91cf8b6aaff04 (patch) | |
tree | 9c4d53fe5938ceee41333a1afd5be0ed5c1ce313 /net/wireless/core.h | |
parent | 517357c685ccc4b5783cc7dbdae8824ada19a97f (diff) |
cfg80211: keep track of BSSes
In order to avoid problems with BSS structs going away
while they're in use, I've long wanted to make cfg80211
keep track of them. Without the SME, that wasn't doable
but now that we have the SME we can do this too. It can
keep track of up to four separate authentications and
one association, regardless of whether it's controlled
by the cfg80211 SME or the userspace SME.
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/wireless/core.h')
-rw-r--r-- | net/wireless/core.h | 41 |
1 files changed, 40 insertions, 1 deletions
diff --git a/net/wireless/core.h b/net/wireless/core.h index 5209acb0ff7e..82918f5896a5 100644 --- a/net/wireless/core.h +++ b/net/wireless/core.h | |||
@@ -110,12 +110,30 @@ struct cfg80211_internal_bss { | |||
110 | struct rb_node rbn; | 110 | struct rb_node rbn; |
111 | unsigned long ts; | 111 | unsigned long ts; |
112 | struct kref ref; | 112 | struct kref ref; |
113 | bool hold, ies_allocated; | 113 | atomic_t hold; |
114 | bool ies_allocated; | ||
114 | 115 | ||
115 | /* must be last because of priv member */ | 116 | /* must be last because of priv member */ |
116 | struct cfg80211_bss pub; | 117 | struct cfg80211_bss pub; |
117 | }; | 118 | }; |
118 | 119 | ||
120 | static inline struct cfg80211_internal_bss *bss_from_pub(struct cfg80211_bss *pub) | ||
121 | { | ||
122 | return container_of(pub, struct cfg80211_internal_bss, pub); | ||
123 | } | ||
124 | |||
125 | static inline void cfg80211_hold_bss(struct cfg80211_internal_bss *bss) | ||
126 | { | ||
127 | atomic_inc(&bss->hold); | ||
128 | } | ||
129 | |||
130 | static inline void cfg80211_unhold_bss(struct cfg80211_internal_bss *bss) | ||
131 | { | ||
132 | int r = atomic_dec_return(&bss->hold); | ||
133 | WARN_ON(r < 0); | ||
134 | } | ||
135 | |||
136 | |||
119 | struct cfg80211_registered_device *cfg80211_drv_by_wiphy_idx(int wiphy_idx); | 137 | struct cfg80211_registered_device *cfg80211_drv_by_wiphy_idx(int wiphy_idx); |
120 | int get_wiphy_idx(struct wiphy *wiphy); | 138 | int get_wiphy_idx(struct wiphy *wiphy); |
121 | 139 | ||
@@ -176,6 +194,26 @@ void cfg80211_clear_ibss(struct net_device *dev, bool nowext); | |||
176 | int cfg80211_leave_ibss(struct cfg80211_registered_device *rdev, | 194 | int cfg80211_leave_ibss(struct cfg80211_registered_device *rdev, |
177 | struct net_device *dev, bool nowext); | 195 | struct net_device *dev, bool nowext); |
178 | 196 | ||
197 | /* MLME */ | ||
198 | int cfg80211_mlme_auth(struct cfg80211_registered_device *rdev, | ||
199 | struct net_device *dev, struct ieee80211_channel *chan, | ||
200 | enum nl80211_auth_type auth_type, const u8 *bssid, | ||
201 | const u8 *ssid, int ssid_len, | ||
202 | const u8 *ie, int ie_len); | ||
203 | int cfg80211_mlme_assoc(struct cfg80211_registered_device *rdev, | ||
204 | struct net_device *dev, struct ieee80211_channel *chan, | ||
205 | const u8 *bssid, const u8 *ssid, int ssid_len, | ||
206 | const u8 *ie, int ie_len, bool use_mfp, | ||
207 | struct cfg80211_crypto_settings *crypt); | ||
208 | int cfg80211_mlme_deauth(struct cfg80211_registered_device *rdev, | ||
209 | struct net_device *dev, const u8 *bssid, | ||
210 | const u8 *ie, int ie_len, u16 reason); | ||
211 | int cfg80211_mlme_disassoc(struct cfg80211_registered_device *rdev, | ||
212 | struct net_device *dev, const u8 *bssid, | ||
213 | const u8 *ie, int ie_len, u16 reason); | ||
214 | void cfg80211_mlme_down(struct cfg80211_registered_device *rdev, | ||
215 | struct net_device *dev); | ||
216 | |||
179 | /* SME */ | 217 | /* SME */ |
180 | int cfg80211_connect(struct cfg80211_registered_device *rdev, | 218 | int cfg80211_connect(struct cfg80211_registered_device *rdev, |
181 | struct net_device *dev, | 219 | struct net_device *dev, |
@@ -193,5 +231,6 @@ void __cfg80211_disconnected(struct net_device *dev, gfp_t gfp, u8 *ie, | |||
193 | size_t ie_len, u16 reason, bool from_ap); | 231 | size_t ie_len, u16 reason, bool from_ap); |
194 | void cfg80211_sme_scan_done(struct net_device *dev); | 232 | void cfg80211_sme_scan_done(struct net_device *dev); |
195 | void cfg80211_sme_rx_auth(struct net_device *dev, const u8 *buf, size_t len); | 233 | void cfg80211_sme_rx_auth(struct net_device *dev, const u8 *buf, size_t len); |
234 | void cfg80211_sme_disassoc(struct net_device *dev, int idx); | ||
196 | 235 | ||
197 | #endif /* __NET_WIRELESS_CORE_H */ | 236 | #endif /* __NET_WIRELESS_CORE_H */ |