diff options
Diffstat (limited to 'drivers/net/wireless/libertas/scan.c')
-rw-r--r-- | drivers/net/wireless/libertas/scan.c | 58 |
1 files changed, 24 insertions, 34 deletions
diff --git a/drivers/net/wireless/libertas/scan.c b/drivers/net/wireless/libertas/scan.c index c3043dcb541e..8753f9344f3e 100644 --- a/drivers/net/wireless/libertas/scan.c +++ b/drivers/net/wireless/libertas/scan.c | |||
@@ -76,7 +76,7 @@ static inline int match_bss_no_security(struct wlan_802_11_security * secinfo, | |||
76 | && !secinfo->WPA2enabled | 76 | && !secinfo->WPA2enabled |
77 | && match_bss->wpa_ie[0] != WPA_IE | 77 | && match_bss->wpa_ie[0] != WPA_IE |
78 | && match_bss->rsn_ie[0] != WPA2_IE | 78 | && match_bss->rsn_ie[0] != WPA2_IE |
79 | && !match_bss->privacy) { | 79 | && !(match_bss->capability & WLAN_CAPABILITY_PRIVACY)) { |
80 | return 1; | 80 | return 1; |
81 | } | 81 | } |
82 | return 0; | 82 | return 0; |
@@ -88,7 +88,7 @@ static inline int match_bss_static_wep(struct wlan_802_11_security * secinfo, | |||
88 | if ( secinfo->wep_enabled | 88 | if ( secinfo->wep_enabled |
89 | && !secinfo->WPAenabled | 89 | && !secinfo->WPAenabled |
90 | && !secinfo->WPA2enabled | 90 | && !secinfo->WPA2enabled |
91 | && match_bss->privacy) { | 91 | && (match_bss->capability & WLAN_CAPABILITY_PRIVACY)) { |
92 | return 1; | 92 | return 1; |
93 | } | 93 | } |
94 | return 0; | 94 | return 0; |
@@ -101,7 +101,8 @@ static inline int match_bss_wpa(struct wlan_802_11_security * secinfo, | |||
101 | && secinfo->WPAenabled | 101 | && secinfo->WPAenabled |
102 | && (match_bss->wpa_ie[0] == WPA_IE) | 102 | && (match_bss->wpa_ie[0] == WPA_IE) |
103 | /* privacy bit may NOT be set in some APs like LinkSys WRT54G | 103 | /* privacy bit may NOT be set in some APs like LinkSys WRT54G |
104 | && bss->privacy */ | 104 | && (match_bss->capability & WLAN_CAPABILITY_PRIVACY)) { |
105 | */ | ||
105 | ) { | 106 | ) { |
106 | return 1; | 107 | return 1; |
107 | } | 108 | } |
@@ -115,7 +116,8 @@ static inline int match_bss_wpa2(struct wlan_802_11_security * secinfo, | |||
115 | && secinfo->WPA2enabled | 116 | && secinfo->WPA2enabled |
116 | && (match_bss->rsn_ie[0] == WPA2_IE) | 117 | && (match_bss->rsn_ie[0] == WPA2_IE) |
117 | /* privacy bit may NOT be set in some APs like LinkSys WRT54G | 118 | /* privacy bit may NOT be set in some APs like LinkSys WRT54G |
118 | && bss->privacy */ | 119 | && (match_bss->capability & WLAN_CAPABILITY_PRIVACY)) { |
120 | */ | ||
119 | ) { | 121 | ) { |
120 | return 1; | 122 | return 1; |
121 | } | 123 | } |
@@ -130,7 +132,7 @@ static inline int match_bss_dynamic_wep(struct wlan_802_11_security * secinfo, | |||
130 | && !secinfo->WPA2enabled | 132 | && !secinfo->WPA2enabled |
131 | && (match_bss->wpa_ie[0] != WPA_IE) | 133 | && (match_bss->wpa_ie[0] != WPA_IE) |
132 | && (match_bss->rsn_ie[0] != WPA2_IE) | 134 | && (match_bss->rsn_ie[0] != WPA2_IE) |
133 | && match_bss->privacy) { | 135 | && (match_bss->capability & WLAN_CAPABILITY_PRIVACY)) { |
134 | return 1; | 136 | return 1; |
135 | } | 137 | } |
136 | return 0; | 138 | return 0; |
@@ -177,7 +179,7 @@ static int is_network_compatible(wlan_adapter * adapter, | |||
177 | adapter->secinfo.wep_enabled ? "e" : "d", | 179 | adapter->secinfo.wep_enabled ? "e" : "d", |
178 | adapter->secinfo.WPAenabled ? "e" : "d", | 180 | adapter->secinfo.WPAenabled ? "e" : "d", |
179 | adapter->secinfo.WPA2enabled ? "e" : "d", | 181 | adapter->secinfo.WPA2enabled ? "e" : "d", |
180 | bss->privacy); | 182 | (bss->capability & WLAN_CAPABILITY_PRIVACY)); |
181 | goto done; | 183 | goto done; |
182 | } else if ((matched = match_bss_wpa2(&adapter->secinfo, bss))) { | 184 | } else if ((matched = match_bss_wpa2(&adapter->secinfo, bss))) { |
183 | lbs_deb_scan( | 185 | lbs_deb_scan( |
@@ -187,15 +189,14 @@ static int is_network_compatible(wlan_adapter * adapter, | |||
187 | adapter->secinfo.wep_enabled ? "e" : "d", | 189 | adapter->secinfo.wep_enabled ? "e" : "d", |
188 | adapter->secinfo.WPAenabled ? "e" : "d", | 190 | adapter->secinfo.WPAenabled ? "e" : "d", |
189 | adapter->secinfo.WPA2enabled ? "e" : "d", | 191 | adapter->secinfo.WPA2enabled ? "e" : "d", |
190 | bss->privacy); | 192 | (bss->capability & WLAN_CAPABILITY_PRIVACY)); |
191 | goto done; | 193 | goto done; |
192 | } else if ((matched = match_bss_dynamic_wep(&adapter->secinfo, bss))) { | 194 | } else if ((matched = match_bss_dynamic_wep(&adapter->secinfo, bss))) { |
193 | lbs_deb_scan( | 195 | lbs_deb_scan( |
194 | "is_network_compatible() dynamic WEP: " | 196 | "is_network_compatible() dynamic WEP: " |
195 | "wpa_ie=%#x wpa2_ie=%#x privacy=%#x\n", | 197 | "wpa_ie=%#x wpa2_ie=%#x privacy=%#x\n", |
196 | bss->wpa_ie[0], | 198 | bss->wpa_ie[0], bss->rsn_ie[0], |
197 | bss->rsn_ie[0], | 199 | (bss->capability & WLAN_CAPABILITY_PRIVACY)); |
198 | bss->privacy); | ||
199 | goto done; | 200 | goto done; |
200 | } | 201 | } |
201 | 202 | ||
@@ -207,7 +208,7 @@ static int is_network_compatible(wlan_adapter * adapter, | |||
207 | adapter->secinfo.wep_enabled ? "e" : "d", | 208 | adapter->secinfo.wep_enabled ? "e" : "d", |
208 | adapter->secinfo.WPAenabled ? "e" : "d", | 209 | adapter->secinfo.WPAenabled ? "e" : "d", |
209 | adapter->secinfo.WPA2enabled ? "e" : "d", | 210 | adapter->secinfo.WPA2enabled ? "e" : "d", |
210 | bss->privacy); | 211 | (bss->capability & WLAN_CAPABILITY_PRIVACY)); |
211 | 212 | ||
212 | done: | 213 | done: |
213 | lbs_deb_leave(LBS_DEB_SCAN); | 214 | lbs_deb_leave(LBS_DEB_SCAN); |
@@ -904,8 +905,6 @@ static int libertas_process_bss(struct bss_descriptor * bss, | |||
904 | struct ieeetypes_dsparamset *pDS; | 905 | struct ieeetypes_dsparamset *pDS; |
905 | struct ieeetypes_cfparamset *pCF; | 906 | struct ieeetypes_cfparamset *pCF; |
906 | struct ieeetypes_ibssparamset *pibss; | 907 | struct ieeetypes_ibssparamset *pibss; |
907 | struct ieeetypes_capinfo *pcap; | ||
908 | struct WLAN_802_11_FIXED_IEs fixedie; | ||
909 | u8 *pcurrentptr; | 908 | u8 *pcurrentptr; |
910 | u8 *pRate; | 909 | u8 *pRate; |
911 | u8 elemlen; | 910 | u8 elemlen; |
@@ -974,24 +973,28 @@ static int libertas_process_bss(struct bss_descriptor * bss, | |||
974 | bytesleftforcurrentbeacon -= 1; | 973 | bytesleftforcurrentbeacon -= 1; |
975 | 974 | ||
976 | /* time stamp is 8 bytes long */ | 975 | /* time stamp is 8 bytes long */ |
977 | fixedie.timestamp = bss->timestamp = le64_to_cpup((void *)pcurrentptr); | 976 | bss->timestamp = le64_to_cpup((void *)pcurrentptr); |
978 | pcurrentptr += 8; | 977 | pcurrentptr += 8; |
979 | bytesleftforcurrentbeacon -= 8; | 978 | bytesleftforcurrentbeacon -= 8; |
980 | 979 | ||
981 | /* beacon interval is 2 bytes long */ | 980 | /* beacon interval is 2 bytes long */ |
982 | fixedie.beaconinterval = bss->beaconperiod = le16_to_cpup((void *)pcurrentptr); | 981 | bss->beaconperiod = le16_to_cpup((void *)pcurrentptr); |
983 | pcurrentptr += 2; | 982 | pcurrentptr += 2; |
984 | bytesleftforcurrentbeacon -= 2; | 983 | bytesleftforcurrentbeacon -= 2; |
985 | 984 | ||
986 | /* capability information is 2 bytes long */ | 985 | /* capability information is 2 bytes long */ |
987 | memcpy(&fixedie.capabilities, pcurrentptr, 2); | 986 | bss->capability = le16_to_cpup((void *)pcurrentptr); |
988 | lbs_deb_scan("process_bss: fixedie.capabilities=0x%X\n", | 987 | lbs_deb_scan("process_bss: capabilities = 0x%4X\n", bss->capability); |
989 | fixedie.capabilities); | ||
990 | pcap = (struct ieeetypes_capinfo *) & fixedie.capabilities; | ||
991 | memcpy(&bss->cap, pcap, sizeof(struct ieeetypes_capinfo)); | ||
992 | pcurrentptr += 2; | 988 | pcurrentptr += 2; |
993 | bytesleftforcurrentbeacon -= 2; | 989 | bytesleftforcurrentbeacon -= 2; |
994 | 990 | ||
991 | if (bss->capability & WLAN_CAPABILITY_PRIVACY) | ||
992 | lbs_deb_scan("process_bss: AP WEP enabled\n"); | ||
993 | if (bss->capability & WLAN_CAPABILITY_IBSS) | ||
994 | bss->mode = IW_MODE_ADHOC; | ||
995 | else | ||
996 | bss->mode = IW_MODE_INFRA; | ||
997 | |||
995 | /* rest of the current buffer are IE's */ | 998 | /* rest of the current buffer are IE's */ |
996 | lbs_deb_scan("process_bss: IE length for this AP = %d\n", | 999 | lbs_deb_scan("process_bss: IE length for this AP = %d\n", |
997 | bytesleftforcurrentbeacon); | 1000 | bytesleftforcurrentbeacon); |
@@ -999,19 +1002,6 @@ static int libertas_process_bss(struct bss_descriptor * bss, | |||
999 | lbs_dbg_hex("process_bss: IE info", (u8 *) pcurrentptr, | 1002 | lbs_dbg_hex("process_bss: IE info", (u8 *) pcurrentptr, |
1000 | bytesleftforcurrentbeacon); | 1003 | bytesleftforcurrentbeacon); |
1001 | 1004 | ||
1002 | if (pcap->privacy) { | ||
1003 | lbs_deb_scan("process_bss: AP WEP enabled\n"); | ||
1004 | bss->privacy = wlan802_11privfilter8021xWEP; | ||
1005 | } else { | ||
1006 | bss->privacy = wlan802_11privfilteracceptall; | ||
1007 | } | ||
1008 | |||
1009 | if (pcap->ibss == 1) { | ||
1010 | bss->mode = IW_MODE_ADHOC; | ||
1011 | } else { | ||
1012 | bss->mode = IW_MODE_INFRA; | ||
1013 | } | ||
1014 | |||
1015 | /* process variable IE */ | 1005 | /* process variable IE */ |
1016 | while (bytesleftforcurrentbeacon >= 2) { | 1006 | while (bytesleftforcurrentbeacon >= 2) { |
1017 | elemID = (enum ieeetypes_elementid) (*((u8 *) pcurrentptr)); | 1007 | elemID = (enum ieeetypes_elementid) (*((u8 *) pcurrentptr)); |
@@ -1550,7 +1540,7 @@ static inline char *libertas_translate_scan(wlan_private *priv, | |||
1550 | 1540 | ||
1551 | /* Add encryption capability */ | 1541 | /* Add encryption capability */ |
1552 | iwe.cmd = SIOCGIWENCODE; | 1542 | iwe.cmd = SIOCGIWENCODE; |
1553 | if (bss->privacy) { | 1543 | if (bss->capability & WLAN_CAPABILITY_PRIVACY) { |
1554 | iwe.u.data.flags = IW_ENCODE_ENABLED | IW_ENCODE_NOKEY; | 1544 | iwe.u.data.flags = IW_ENCODE_ENABLED | IW_ENCODE_NOKEY; |
1555 | } else { | 1545 | } else { |
1556 | iwe.u.data.flags = IW_ENCODE_DISABLED; | 1546 | iwe.u.data.flags = IW_ENCODE_DISABLED; |