aboutsummaryrefslogtreecommitdiffstats
path: root/net/mac80211/cfg.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/mac80211/cfg.c')
-rw-r--r--net/mac80211/cfg.c39
1 files changed, 14 insertions, 25 deletions
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c
index 3c9774e36a80..7606571d4581 100644
--- a/net/mac80211/cfg.c
+++ b/net/mac80211/cfg.c
@@ -1194,18 +1194,14 @@ static int ieee80211_auth(struct wiphy *wiphy, struct net_device *dev,
1194 } 1194 }
1195 1195
1196 memcpy(sdata->u.mgd.bssid, req->peer_addr, ETH_ALEN); 1196 memcpy(sdata->u.mgd.bssid, req->peer_addr, ETH_ALEN);
1197 sdata->u.mgd.flags &= ~IEEE80211_STA_AUTO_BSSID_SEL;
1198 sdata->u.mgd.flags |= IEEE80211_STA_BSSID_SET;
1199 1197
1200 /* TODO: req->chan */ 1198 sdata->local->oper_channel = req->chan;
1201 sdata->u.mgd.flags |= IEEE80211_STA_AUTO_CHANNEL_SEL; 1199 ieee80211_hw_config(sdata->local, 0);
1202 1200
1203 if (req->ssid) { 1201 if (!req->ssid)
1204 sdata->u.mgd.flags |= IEEE80211_STA_SSID_SET; 1202 return -EINVAL;
1205 memcpy(sdata->u.mgd.ssid, req->ssid, req->ssid_len); 1203 memcpy(sdata->u.mgd.ssid, req->ssid, req->ssid_len);
1206 sdata->u.mgd.ssid_len = req->ssid_len; 1204 sdata->u.mgd.ssid_len = req->ssid_len;
1207 sdata->u.mgd.flags &= ~IEEE80211_STA_AUTO_SSID_SEL;
1208 }
1209 1205
1210 kfree(sdata->u.mgd.sme_auth_ie); 1206 kfree(sdata->u.mgd.sme_auth_ie);
1211 sdata->u.mgd.sme_auth_ie = NULL; 1207 sdata->u.mgd.sme_auth_ie = NULL;
@@ -1218,7 +1214,6 @@ static int ieee80211_auth(struct wiphy *wiphy, struct net_device *dev,
1218 sdata->u.mgd.sme_auth_ie_len = req->ie_len; 1214 sdata->u.mgd.sme_auth_ie_len = req->ie_len;
1219 } 1215 }
1220 1216
1221 sdata->u.mgd.flags |= IEEE80211_STA_EXT_SME;
1222 sdata->u.mgd.state = IEEE80211_STA_MLME_DIRECT_PROBE; 1217 sdata->u.mgd.state = IEEE80211_STA_MLME_DIRECT_PROBE;
1223 ieee80211_sta_req_auth(sdata); 1218 ieee80211_sta_req_auth(sdata);
1224 return 0; 1219 return 0;
@@ -1236,27 +1231,22 @@ static int ieee80211_assoc(struct wiphy *wiphy, struct net_device *dev,
1236 !(sdata->u.mgd.flags & IEEE80211_STA_AUTHENTICATED)) 1231 !(sdata->u.mgd.flags & IEEE80211_STA_AUTHENTICATED))
1237 return -ENOLINK; /* not authenticated */ 1232 return -ENOLINK; /* not authenticated */
1238 1233
1239 sdata->u.mgd.flags &= ~IEEE80211_STA_TKIP_WEP_USED; 1234 sdata->u.mgd.flags &= ~IEEE80211_STA_DISABLE_11N;
1240 1235
1241 for (i = 0; i < req->crypto.n_ciphers_pairwise; i++) 1236 for (i = 0; i < req->crypto.n_ciphers_pairwise; i++)
1242 if (req->crypto.ciphers_pairwise[i] == WLAN_CIPHER_SUITE_WEP40 || 1237 if (req->crypto.ciphers_pairwise[i] == WLAN_CIPHER_SUITE_WEP40 ||
1243 req->crypto.ciphers_pairwise[i] == WLAN_CIPHER_SUITE_TKIP || 1238 req->crypto.ciphers_pairwise[i] == WLAN_CIPHER_SUITE_TKIP ||
1244 req->crypto.ciphers_pairwise[i] == WLAN_CIPHER_SUITE_WEP104) 1239 req->crypto.ciphers_pairwise[i] == WLAN_CIPHER_SUITE_WEP104)
1245 sdata->u.mgd.flags |= IEEE80211_STA_TKIP_WEP_USED; 1240 sdata->u.mgd.flags |= IEEE80211_STA_DISABLE_11N;
1246 1241
1247 sdata->u.mgd.flags &= ~IEEE80211_STA_AUTO_BSSID_SEL; 1242 sdata->local->oper_channel = req->chan;
1248 sdata->u.mgd.flags |= IEEE80211_STA_BSSID_SET; 1243 ieee80211_hw_config(sdata->local, 0);
1249 1244
1250 /* TODO: req->chan */ 1245 if (!req->ssid)
1251 sdata->u.mgd.flags |= IEEE80211_STA_AUTO_CHANNEL_SEL; 1246 return -EINVAL;
1252 1247
1253 if (req->ssid) { 1248 memcpy(sdata->u.mgd.ssid, req->ssid, req->ssid_len);
1254 sdata->u.mgd.flags |= IEEE80211_STA_SSID_SET; 1249 sdata->u.mgd.ssid_len = req->ssid_len;
1255 memcpy(sdata->u.mgd.ssid, req->ssid, req->ssid_len);
1256 sdata->u.mgd.ssid_len = req->ssid_len;
1257 sdata->u.mgd.flags &= ~IEEE80211_STA_AUTO_SSID_SEL;
1258 } else
1259 sdata->u.mgd.flags |= IEEE80211_STA_AUTO_SSID_SEL;
1260 1250
1261 ret = ieee80211_sta_set_extra_ie(sdata, req->ie, req->ie_len); 1251 ret = ieee80211_sta_set_extra_ie(sdata, req->ie, req->ie_len);
1262 if (ret && ret != -EALREADY) 1252 if (ret && ret != -EALREADY)
@@ -1275,7 +1265,6 @@ static int ieee80211_assoc(struct wiphy *wiphy, struct net_device *dev,
1275 else 1265 else
1276 sdata->u.mgd.flags &= ~IEEE80211_STA_CONTROL_PORT; 1266 sdata->u.mgd.flags &= ~IEEE80211_STA_CONTROL_PORT;
1277 1267
1278 sdata->u.mgd.flags |= IEEE80211_STA_EXT_SME;
1279 sdata->u.mgd.state = IEEE80211_STA_MLME_ASSOCIATE; 1268 sdata->u.mgd.state = IEEE80211_STA_MLME_ASSOCIATE;
1280 ieee80211_sta_req_auth(sdata); 1269 ieee80211_sta_req_auth(sdata);
1281 return 0; 1270 return 0;