aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/mac80211/hostapd_ioctl.h8
-rw-r--r--net/mac80211/ieee80211_i.h2
-rw-r--r--net/mac80211/ieee80211_ioctl.c20
-rw-r--r--net/mac80211/ieee80211_sta.c3
4 files changed, 7 insertions, 26 deletions
diff --git a/net/mac80211/hostapd_ioctl.h b/net/mac80211/hostapd_ioctl.h
index fd072cb24e50..d43711aff4c5 100644
--- a/net/mac80211/hostapd_ioctl.h
+++ b/net/mac80211/hostapd_ioctl.h
@@ -41,14 +41,6 @@ enum {
41 PRISM2_PARAM_MIXED_CELL = 1039, 41 PRISM2_PARAM_MIXED_CELL = 1039,
42}; 42};
43 43
44enum {
45 IEEE80211_KEY_MGMT_NONE = 0,
46 IEEE80211_KEY_MGMT_IEEE8021X = 1,
47 IEEE80211_KEY_MGMT_WPA_PSK = 2,
48 IEEE80211_KEY_MGMT_WPA_EAP = 3,
49};
50
51
52/* Data structures used for get_hw_features ioctl */ 44/* Data structures used for get_hw_features ioctl */
53struct hostapd_ioctl_hw_modes_hdr { 45struct hostapd_ioctl_hw_modes_hdr {
54 int mode; 46 int mode;
diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h
index c557d578aa30..c771b7a76959 100644
--- a/net/mac80211/ieee80211_i.h
+++ b/net/mac80211/ieee80211_i.h
@@ -253,7 +253,7 @@ struct ieee80211_if_sta {
253 unsigned long request; 253 unsigned long request;
254 struct sk_buff_head skb_queue; 254 struct sk_buff_head skb_queue;
255 255
256 int key_mgmt; 256 int key_management_enabled;
257 unsigned long last_probe; 257 unsigned long last_probe;
258 258
259#define IEEE80211_AUTH_ALG_OPEN BIT(0) 259#define IEEE80211_AUTH_ALG_OPEN BIT(0)
diff --git a/net/mac80211/ieee80211_ioctl.c b/net/mac80211/ieee80211_ioctl.c
index 785f437b306a..643c8855801c 100644
--- a/net/mac80211/ieee80211_ioctl.c
+++ b/net/mac80211/ieee80211_ioctl.c
@@ -1342,22 +1342,12 @@ static int ieee80211_ioctl_siwauth(struct net_device *dev,
1342 ret = -EINVAL; 1342 ret = -EINVAL;
1343 else { 1343 else {
1344 /* 1344 /*
1345 * TODO: sdata->u.sta.key_mgmt does not match with WE18 1345 * Key management was set by wpa_supplicant,
1346 * value completely; could consider modifying this to 1346 * we only need this to associate to a network
1347 * be closer to WE18. For now, this value is not really 1347 * that has privacy enabled regardless of not
1348 * used for anything else than Privacy matching, so the 1348 * having a key.
1349 * current code here should be more or less OK.
1350 */ 1349 */
1351 if (data->value & IW_AUTH_KEY_MGMT_802_1X) { 1350 sdata->u.sta.key_management_enabled = !!data->value;
1352 sdata->u.sta.key_mgmt =
1353 IEEE80211_KEY_MGMT_WPA_EAP;
1354 } else if (data->value & IW_AUTH_KEY_MGMT_PSK) {
1355 sdata->u.sta.key_mgmt =
1356 IEEE80211_KEY_MGMT_WPA_PSK;
1357 } else {
1358 sdata->u.sta.key_mgmt =
1359 IEEE80211_KEY_MGMT_NONE;
1360 }
1361 } 1351 }
1362 break; 1352 break;
1363 case IW_AUTH_80211_AUTH_ALG: 1353 case IW_AUTH_80211_AUTH_ALG:
diff --git a/net/mac80211/ieee80211_sta.c b/net/mac80211/ieee80211_sta.c
index f43c39f11223..1b3304454356 100644
--- a/net/mac80211/ieee80211_sta.c
+++ b/net/mac80211/ieee80211_sta.c
@@ -716,8 +716,7 @@ static int ieee80211_privacy_mismatch(struct net_device *dev,
716 struct ieee80211_sta_bss *bss; 716 struct ieee80211_sta_bss *bss;
717 int res = 0; 717 int res = 0;
718 718
719 if (!ifsta || ifsta->mixed_cell || 719 if (!ifsta || ifsta->mixed_cell || ifsta->key_management_enabled)
720 ifsta->key_mgmt != IEEE80211_KEY_MGMT_NONE)
721 return 0; 720 return 0;
722 721
723 bss = ieee80211_rx_bss_get(dev, ifsta->bssid); 722 bss = ieee80211_rx_bss_get(dev, ifsta->bssid);