aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/rndis_wlan.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/wireless/rndis_wlan.c')
-rw-r--r--drivers/net/wireless/rndis_wlan.c213
1 files changed, 103 insertions, 110 deletions
diff --git a/drivers/net/wireless/rndis_wlan.c b/drivers/net/wireless/rndis_wlan.c
index 10b776c1adc5..157c46463429 100644
--- a/drivers/net/wireless/rndis_wlan.c
+++ b/drivers/net/wireless/rndis_wlan.c
@@ -154,107 +154,100 @@ MODULE_PARM_DESC(workaround_interval,
154#define NDIS_802_11_LENGTH_RATES 8 154#define NDIS_802_11_LENGTH_RATES 8
155#define NDIS_802_11_LENGTH_RATES_EX 16 155#define NDIS_802_11_LENGTH_RATES_EX 16
156 156
157struct NDIS_802_11_SSID { 157enum ndis_80211_net_type {
158 ndis_80211_type_freq_hop,
159 ndis_80211_type_direct_seq,
160 ndis_80211_type_ofdm_a,
161 ndis_80211_type_ofdm_g
162};
163
164enum ndis_80211_net_infra {
165 ndis_80211_infra_adhoc,
166 ndis_80211_infra_infra,
167 ndis_80211_infra_auto_unknown
168};
169
170enum ndis_80211_auth_mode {
171 ndis_80211_auth_open,
172 ndis_80211_auth_shared,
173 ndis_80211_auth_auto_switch,
174 ndis_80211_auth_wpa,
175 ndis_80211_auth_wpa_psk,
176 ndis_80211_auth_wpa_none,
177 ndis_80211_auth_wpa2,
178 ndis_80211_auth_wpa2_psk
179};
180
181enum ndis_80211_encr_status {
182 ndis_80211_encr_wep_enabled,
183 ndis_80211_encr_disabled,
184 ndis_80211_encr_wep_key_absent,
185 ndis_80211_encr_not_supported,
186 ndis_80211_encr_tkip_enabled,
187 ndis_80211_encr_tkip_key_absent,
188 ndis_80211_encr_ccmp_enabled,
189 ndis_80211_encr_ccmp_key_absent
190};
191
192enum ndis_80211_priv_filter {
193 ndis_80211_priv_accept_all,
194 ndis_80211_priv_8021x_wep
195};
196
197struct ndis_80211_ssid {
158 __le32 SsidLength; 198 __le32 SsidLength;
159 u8 Ssid[NDIS_802_11_LENGTH_SSID]; 199 u8 Ssid[NDIS_802_11_LENGTH_SSID];
160} __attribute__((packed)); 200} __attribute__((packed));
161 201
162enum NDIS_802_11_NETWORK_TYPE { 202struct ndis_80211_conf_freq_hop {
163 Ndis802_11FH,
164 Ndis802_11DS,
165 Ndis802_11OFDM5,
166 Ndis802_11OFDM24,
167 Ndis802_11NetworkTypeMax
168};
169
170struct NDIS_802_11_CONFIGURATION_FH {
171 __le32 Length; 203 __le32 Length;
172 __le32 HopPattern; 204 __le32 HopPattern;
173 __le32 HopSet; 205 __le32 HopSet;
174 __le32 DwellTime; 206 __le32 DwellTime;
175} __attribute__((packed)); 207} __attribute__((packed));
176 208
177struct NDIS_802_11_CONFIGURATION { 209struct ndis_80211_conf {
178 __le32 Length; 210 __le32 Length;
179 __le32 BeaconPeriod; 211 __le32 BeaconPeriod;
180 __le32 ATIMWindow; 212 __le32 ATIMWindow;
181 __le32 DSConfig; 213 __le32 DSConfig;
182 struct NDIS_802_11_CONFIGURATION_FH FHConfig; 214 struct ndis_80211_conf_freq_hop FHConfig;
183} __attribute__((packed)); 215} __attribute__((packed));
184 216
185enum NDIS_802_11_NETWORK_INFRASTRUCTURE { 217struct ndis_80211_bssid_ex {
186 Ndis802_11IBSS,
187 Ndis802_11Infrastructure,
188 Ndis802_11AutoUnknown,
189 Ndis802_11InfrastructureMax
190};
191
192enum NDIS_802_11_AUTHENTICATION_MODE {
193 Ndis802_11AuthModeOpen,
194 Ndis802_11AuthModeShared,
195 Ndis802_11AuthModeAutoSwitch,
196 Ndis802_11AuthModeWPA,
197 Ndis802_11AuthModeWPAPSK,
198 Ndis802_11AuthModeWPANone,
199 Ndis802_11AuthModeWPA2,
200 Ndis802_11AuthModeWPA2PSK,
201 Ndis802_11AuthModeMax
202};
203
204enum NDIS_802_11_ENCRYPTION_STATUS {
205 Ndis802_11WEPEnabled,
206 Ndis802_11Encryption1Enabled = Ndis802_11WEPEnabled,
207 Ndis802_11WEPDisabled,
208 Ndis802_11EncryptionDisabled = Ndis802_11WEPDisabled,
209 Ndis802_11WEPKeyAbsent,
210 Ndis802_11Encryption1KeyAbsent = Ndis802_11WEPKeyAbsent,
211 Ndis802_11WEPNotSupported,
212 Ndis802_11EncryptionNotSupported = Ndis802_11WEPNotSupported,
213 Ndis802_11Encryption2Enabled,
214 Ndis802_11Encryption2KeyAbsent,
215 Ndis802_11Encryption3Enabled,
216 Ndis802_11Encryption3KeyAbsent
217};
218
219enum NDIS_802_11_PRIVACY_FILTER {
220 Ndis802_11PrivFilterAcceptAll,
221 Ndis802_11PrivFilter8021xWEP
222};
223
224struct NDIS_WLAN_BSSID_EX {
225 __le32 Length; 218 __le32 Length;
226 u8 MacAddress[6]; 219 u8 MacAddress[6];
227 u8 Padding[2]; 220 u8 Padding[2];
228 struct NDIS_802_11_SSID Ssid; 221 struct ndis_80211_ssid Ssid;
229 __le32 Privacy; 222 __le32 Privacy;
230 __le32 Rssi; 223 __le32 Rssi;
231 __le32 NetworkTypeInUse; 224 __le32 NetworkTypeInUse;
232 struct NDIS_802_11_CONFIGURATION Configuration; 225 struct ndis_80211_conf Configuration;
233 __le32 InfrastructureMode; 226 __le32 InfrastructureMode;
234 u8 SupportedRates[NDIS_802_11_LENGTH_RATES_EX]; 227 u8 SupportedRates[NDIS_802_11_LENGTH_RATES_EX];
235 __le32 IELength; 228 __le32 IELength;
236 u8 IEs[0]; 229 u8 IEs[0];
237} __attribute__((packed)); 230} __attribute__((packed));
238 231
239struct NDIS_802_11_BSSID_LIST_EX { 232struct ndis_80211_bssid_list_ex {
240 __le32 NumberOfItems; 233 __le32 NumberOfItems;
241 struct NDIS_WLAN_BSSID_EX Bssid[0]; 234 struct ndis_80211_bssid_ex Bssid[0];
242} __attribute__((packed)); 235} __attribute__((packed));
243 236
244struct NDIS_802_11_FIXED_IEs { 237struct ndis_80211_fixed_ies {
245 u8 Timestamp[8]; 238 u8 Timestamp[8];
246 __le16 BeaconInterval; 239 __le16 BeaconInterval;
247 __le16 Capabilities; 240 __le16 Capabilities;
248} __attribute__((packed)); 241} __attribute__((packed));
249 242
250struct NDIS_802_11_WEP { 243struct ndis_80211_wep_key {
251 __le32 Length; 244 __le32 Length;
252 __le32 KeyIndex; 245 __le32 KeyIndex;
253 __le32 KeyLength; 246 __le32 KeyLength;
254 u8 KeyMaterial[32]; 247 u8 KeyMaterial[32];
255} __attribute__((packed)); 248} __attribute__((packed));
256 249
257struct NDIS_802_11_KEY { 250struct ndis_80211_key {
258 __le32 Length; 251 __le32 Length;
259 __le32 KeyIndex; 252 __le32 KeyIndex;
260 __le32 KeyLength; 253 __le32 KeyLength;
@@ -264,13 +257,13 @@ struct NDIS_802_11_KEY {
264 u8 KeyMaterial[32]; 257 u8 KeyMaterial[32];
265} __attribute__((packed)); 258} __attribute__((packed));
266 259
267struct NDIS_802_11_REMOVE_KEY { 260struct ndis_80211_remove_key {
268 __le32 Length; 261 __le32 Length;
269 __le32 KeyIndex; 262 __le32 KeyIndex;
270 u8 Bssid[6]; 263 u8 Bssid[6];
271} __attribute__((packed)); 264} __attribute__((packed));
272 265
273struct RNDIS_CONFIG_PARAMETER_INFOBUFFER { 266struct ndis_config_param {
274 __le32 ParameterNameOffset; 267 __le32 ParameterNameOffset;
275 __le32 ParameterNameLength; 268 __le32 ParameterNameLength;
276 __le32 ParameterType; 269 __le32 ParameterType;
@@ -334,7 +327,7 @@ struct rndis_wext_private {
334 /* hardware state */ 327 /* hardware state */
335 int radio_on; 328 int radio_on;
336 int infra_mode; 329 int infra_mode;
337 struct NDIS_802_11_SSID essid; 330 struct ndis_80211_ssid essid;
338 331
339 /* encryption stuff */ 332 /* encryption stuff */
340 int encr_tx_key_index; 333 int encr_tx_key_index;
@@ -484,7 +477,7 @@ static int rndis_set_oid(struct usbnet *dev, __le32 oid, void *data, int len)
484static int rndis_set_config_parameter(struct usbnet *dev, char *param, 477static int rndis_set_config_parameter(struct usbnet *dev, char *param,
485 int value_type, void *value) 478 int value_type, void *value)
486{ 479{
487 struct RNDIS_CONFIG_PARAMETER_INFOBUFFER *infobuf; 480 struct ndis_config_param *infobuf;
488 int value_len, info_len, param_len, ret, i; 481 int value_len, info_len, param_len, ret, i;
489 __le16 *unibuf; 482 __le16 *unibuf;
490 __le32 *dst_value; 483 __le32 *dst_value;
@@ -630,7 +623,7 @@ static int freq_to_dsconfig(struct iw_freq *freq, unsigned int *dsconfig)
630static int 623static int
631add_wep_key(struct usbnet *usbdev, char *key, int key_len, int index); 624add_wep_key(struct usbnet *usbdev, char *key, int key_len, int index);
632 625
633static int get_essid(struct usbnet *usbdev, struct NDIS_802_11_SSID *ssid) 626static int get_essid(struct usbnet *usbdev, struct ndis_80211_ssid *ssid)
634{ 627{
635 int ret, len; 628 int ret, len;
636 629
@@ -653,7 +646,7 @@ static int get_essid(struct usbnet *usbdev, struct NDIS_802_11_SSID *ssid)
653} 646}
654 647
655 648
656static int set_essid(struct usbnet *usbdev, struct NDIS_802_11_SSID *ssid) 649static int set_essid(struct usbnet *usbdev, struct ndis_80211_ssid *ssid)
657{ 650{
658 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev); 651 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev);
659 int ret; 652 int ret;
@@ -697,7 +690,7 @@ static int is_associated(struct usbnet *usbdev)
697static int disassociate(struct usbnet *usbdev, int reset_ssid) 690static int disassociate(struct usbnet *usbdev, int reset_ssid)
698{ 691{
699 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev); 692 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev);
700 struct NDIS_802_11_SSID ssid; 693 struct ndis_80211_ssid ssid;
701 int i, ret = 0; 694 int i, ret = 0;
702 695
703 if (priv->radio_on) { 696 if (priv->radio_on) {
@@ -737,23 +730,23 @@ static int set_auth_mode(struct usbnet *usbdev, int wpa_version, int authalg)
737 730
738 if (wpa_version & IW_AUTH_WPA_VERSION_WPA2) { 731 if (wpa_version & IW_AUTH_WPA_VERSION_WPA2) {
739 if (priv->wpa_keymgmt & IW_AUTH_KEY_MGMT_802_1X) 732 if (priv->wpa_keymgmt & IW_AUTH_KEY_MGMT_802_1X)
740 auth_mode = Ndis802_11AuthModeWPA2; 733 auth_mode = ndis_80211_auth_wpa2;
741 else 734 else
742 auth_mode = Ndis802_11AuthModeWPA2PSK; 735 auth_mode = ndis_80211_auth_wpa2_psk;
743 } else if (wpa_version & IW_AUTH_WPA_VERSION_WPA) { 736 } else if (wpa_version & IW_AUTH_WPA_VERSION_WPA) {
744 if (priv->wpa_keymgmt & IW_AUTH_KEY_MGMT_802_1X) 737 if (priv->wpa_keymgmt & IW_AUTH_KEY_MGMT_802_1X)
745 auth_mode = Ndis802_11AuthModeWPA; 738 auth_mode = ndis_80211_auth_wpa;
746 else if (priv->wpa_keymgmt & IW_AUTH_KEY_MGMT_PSK) 739 else if (priv->wpa_keymgmt & IW_AUTH_KEY_MGMT_PSK)
747 auth_mode = Ndis802_11AuthModeWPAPSK; 740 auth_mode = ndis_80211_auth_wpa_psk;
748 else 741 else
749 auth_mode = Ndis802_11AuthModeWPANone; 742 auth_mode = ndis_80211_auth_wpa_none;
750 } else if (authalg & IW_AUTH_ALG_SHARED_KEY) { 743 } else if (authalg & IW_AUTH_ALG_SHARED_KEY) {
751 if (authalg & IW_AUTH_ALG_OPEN_SYSTEM) 744 if (authalg & IW_AUTH_ALG_OPEN_SYSTEM)
752 auth_mode = Ndis802_11AuthModeAutoSwitch; 745 auth_mode = ndis_80211_auth_auto_switch;
753 else 746 else
754 auth_mode = Ndis802_11AuthModeShared; 747 auth_mode = ndis_80211_auth_shared;
755 } else 748 } else
756 auth_mode = Ndis802_11AuthModeOpen; 749 auth_mode = ndis_80211_auth_open;
757 750
758 tmp = cpu_to_le32(auth_mode); 751 tmp = cpu_to_le32(auth_mode);
759 ret = rndis_set_oid(usbdev, OID_802_11_AUTHENTICATION_MODE, &tmp, 752 ret = rndis_set_oid(usbdev, OID_802_11_AUTHENTICATION_MODE, &tmp,
@@ -778,9 +771,9 @@ static int set_priv_filter(struct usbnet *usbdev)
778 771
779 if (priv->wpa_version & IW_AUTH_WPA_VERSION_WPA2 || 772 if (priv->wpa_version & IW_AUTH_WPA_VERSION_WPA2 ||
780 priv->wpa_version & IW_AUTH_WPA_VERSION_WPA) 773 priv->wpa_version & IW_AUTH_WPA_VERSION_WPA)
781 tmp = cpu_to_le32(Ndis802_11PrivFilter8021xWEP); 774 tmp = cpu_to_le32(ndis_80211_priv_8021x_wep);
782 else 775 else
783 tmp = cpu_to_le32(Ndis802_11PrivFilterAcceptAll); 776 tmp = cpu_to_le32(ndis_80211_priv_accept_all);
784 777
785 return rndis_set_oid(usbdev, OID_802_11_PRIVACY_FILTER, &tmp, 778 return rndis_set_oid(usbdev, OID_802_11_PRIVACY_FILTER, &tmp,
786 sizeof(tmp)); 779 sizeof(tmp));
@@ -798,18 +791,18 @@ static int set_encr_mode(struct usbnet *usbdev, int pairwise, int groupwise)
798 groupwise); 791 groupwise);
799 792
800 if (pairwise & IW_AUTH_CIPHER_CCMP) 793 if (pairwise & IW_AUTH_CIPHER_CCMP)
801 encr_mode = Ndis802_11Encryption3Enabled; 794 encr_mode = ndis_80211_encr_ccmp_enabled;
802 else if (pairwise & IW_AUTH_CIPHER_TKIP) 795 else if (pairwise & IW_AUTH_CIPHER_TKIP)
803 encr_mode = Ndis802_11Encryption2Enabled; 796 encr_mode = ndis_80211_encr_tkip_enabled;
804 else if (pairwise & 797 else if (pairwise &
805 (IW_AUTH_CIPHER_WEP40 | IW_AUTH_CIPHER_WEP104)) 798 (IW_AUTH_CIPHER_WEP40 | IW_AUTH_CIPHER_WEP104))
806 encr_mode = Ndis802_11Encryption1Enabled; 799 encr_mode = ndis_80211_encr_wep_enabled;
807 else if (groupwise & IW_AUTH_CIPHER_CCMP) 800 else if (groupwise & IW_AUTH_CIPHER_CCMP)
808 encr_mode = Ndis802_11Encryption3Enabled; 801 encr_mode = ndis_80211_encr_ccmp_enabled;
809 else if (groupwise & IW_AUTH_CIPHER_TKIP) 802 else if (groupwise & IW_AUTH_CIPHER_TKIP)
810 encr_mode = Ndis802_11Encryption2Enabled; 803 encr_mode = ndis_80211_encr_tkip_enabled;
811 else 804 else
812 encr_mode = Ndis802_11EncryptionDisabled; 805 encr_mode = ndis_80211_encr_disabled;
813 806
814 tmp = cpu_to_le32(encr_mode); 807 tmp = cpu_to_le32(encr_mode);
815 ret = rndis_set_oid(usbdev, OID_802_11_ENCRYPTION_STATUS, &tmp, 808 ret = rndis_set_oid(usbdev, OID_802_11_ENCRYPTION_STATUS, &tmp,
@@ -877,7 +870,7 @@ static void set_default_iw_params(struct usbnet *usbdev)
877 priv->wpa_keymgmt = 0; 870 priv->wpa_keymgmt = 0;
878 priv->wpa_version = 0; 871 priv->wpa_version = 0;
879 872
880 set_infra_mode(usbdev, Ndis802_11Infrastructure); 873 set_infra_mode(usbdev, ndis_80211_infra_infra);
881 set_auth_mode(usbdev, IW_AUTH_WPA_VERSION_DISABLED, 874 set_auth_mode(usbdev, IW_AUTH_WPA_VERSION_DISABLED,
882 IW_AUTH_ALG_OPEN_SYSTEM); 875 IW_AUTH_ALG_OPEN_SYSTEM);
883 set_priv_filter(usbdev); 876 set_priv_filter(usbdev);
@@ -899,7 +892,7 @@ static int deauthenticate(struct usbnet *usbdev)
899static int add_wep_key(struct usbnet *usbdev, char *key, int key_len, int index) 892static int add_wep_key(struct usbnet *usbdev, char *key, int key_len, int index)
900{ 893{
901 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev); 894 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev);
902 struct NDIS_802_11_WEP ndis_key; 895 struct ndis_80211_wep_key ndis_key;
903 int ret; 896 int ret;
904 897
905 if (key_len <= 0 || key_len > 32 || index < 0 || index >= 4) 898 if (key_len <= 0 || key_len > 32 || index < 0 || index >= 4)
@@ -940,7 +933,7 @@ static int add_wep_key(struct usbnet *usbdev, char *key, int key_len, int index)
940static int remove_key(struct usbnet *usbdev, int index, u8 bssid[ETH_ALEN]) 933static int remove_key(struct usbnet *usbdev, int index, u8 bssid[ETH_ALEN])
941{ 934{
942 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev); 935 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev);
943 struct NDIS_802_11_REMOVE_KEY remove_key; 936 struct ndis_80211_remove_key remove_key;
944 __le32 keyindex; 937 __le32 keyindex;
945 int ret; 938 int ret;
946 939
@@ -1184,7 +1177,7 @@ static int rndis_iw_get_name(struct net_device *dev,
1184static int rndis_iw_set_essid(struct net_device *dev, 1177static int rndis_iw_set_essid(struct net_device *dev,
1185 struct iw_request_info *info, union iwreq_data *wrqu, char *essid) 1178 struct iw_request_info *info, union iwreq_data *wrqu, char *essid)
1186{ 1179{
1187 struct NDIS_802_11_SSID ssid; 1180 struct ndis_80211_ssid ssid;
1188 int length = wrqu->essid.length; 1181 int length = wrqu->essid.length;
1189 struct usbnet *usbdev = dev->priv; 1182 struct usbnet *usbdev = dev->priv;
1190 1183
@@ -1212,7 +1205,7 @@ static int rndis_iw_set_essid(struct net_device *dev,
1212static int rndis_iw_get_essid(struct net_device *dev, 1205static int rndis_iw_get_essid(struct net_device *dev,
1213 struct iw_request_info *info, union iwreq_data *wrqu, char *essid) 1206 struct iw_request_info *info, union iwreq_data *wrqu, char *essid)
1214{ 1207{
1215 struct NDIS_802_11_SSID ssid; 1208 struct ndis_80211_ssid ssid;
1216 struct usbnet *usbdev = dev->priv; 1209 struct usbnet *usbdev = dev->priv;
1217 int ret; 1210 int ret;
1218 1211
@@ -1398,13 +1391,13 @@ static int rndis_iw_get_mode(struct net_device *dev,
1398 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev); 1391 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev);
1399 1392
1400 switch (priv->infra_mode) { 1393 switch (priv->infra_mode) {
1401 case Ndis802_11IBSS: 1394 case ndis_80211_infra_adhoc:
1402 wrqu->mode = IW_MODE_ADHOC; 1395 wrqu->mode = IW_MODE_ADHOC;
1403 break; 1396 break;
1404 case Ndis802_11Infrastructure: 1397 case ndis_80211_infra_infra:
1405 wrqu->mode = IW_MODE_INFRA; 1398 wrqu->mode = IW_MODE_INFRA;
1406 break; 1399 break;
1407 /*case Ndis802_11AutoUnknown:*/ 1400 /*case ndis_80211_infra_auto_unknown:*/
1408 default: 1401 default:
1409 wrqu->mode = IW_MODE_AUTO; 1402 wrqu->mode = IW_MODE_AUTO;
1410 break; 1403 break;
@@ -1424,14 +1417,14 @@ static int rndis_iw_set_mode(struct net_device *dev,
1424 1417
1425 switch (wrqu->mode) { 1418 switch (wrqu->mode) {
1426 case IW_MODE_ADHOC: 1419 case IW_MODE_ADHOC:
1427 mode = Ndis802_11IBSS; 1420 mode = ndis_80211_infra_adhoc;
1428 break; 1421 break;
1429 case IW_MODE_INFRA: 1422 case IW_MODE_INFRA:
1430 mode = Ndis802_11Infrastructure; 1423 mode = ndis_80211_infra_infra;
1431 break; 1424 break;
1432 /*case IW_MODE_AUTO:*/ 1425 /*case IW_MODE_AUTO:*/
1433 default: 1426 default:
1434 mode = Ndis802_11AutoUnknown; 1427 mode = ndis_80211_infra_auto_unknown;
1435 break; 1428 break;
1436 } 1429 }
1437 1430
@@ -1507,7 +1500,7 @@ static int rndis_iw_set_encode_ext(struct net_device *dev,
1507 struct iw_encode_ext *ext = (struct iw_encode_ext *)extra; 1500 struct iw_encode_ext *ext = (struct iw_encode_ext *)extra;
1508 struct usbnet *usbdev = dev->priv; 1501 struct usbnet *usbdev = dev->priv;
1509 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev); 1502 struct rndis_wext_private *priv = get_rndis_wext_priv(usbdev);
1510 struct NDIS_802_11_KEY ndis_key; 1503 struct ndis_80211_key ndis_key;
1511 int keyidx, ret; 1504 int keyidx, ret;
1512 u8 *addr; 1505 u8 *addr;
1513 1506
@@ -1550,7 +1543,7 @@ static int rndis_iw_set_encode_ext(struct net_device *dev,
1550 addr = ext->addr.sa_data; 1543 addr = ext->addr.sa_data;
1551 if (ext->ext_flags & IW_ENCODE_EXT_GROUP_KEY) { 1544 if (ext->ext_flags & IW_ENCODE_EXT_GROUP_KEY) {
1552 /* group key */ 1545 /* group key */
1553 if (priv->infra_mode == Ndis802_11IBSS) 1546 if (priv->infra_mode == ndis_80211_infra_adhoc)
1554 memset(ndis_key.Bssid, 0xff, ETH_ALEN); 1547 memset(ndis_key.Bssid, 0xff, ETH_ALEN);
1555 else 1548 else
1556 get_bssid(usbdev, ndis_key.Bssid); 1549 get_bssid(usbdev, ndis_key.Bssid);
@@ -1611,7 +1604,7 @@ static int rndis_iw_set_scan(struct net_device *dev,
1611 1604
1612 1605
1613static char *rndis_translate_scan(struct net_device *dev, 1606static char *rndis_translate_scan(struct net_device *dev,
1614 char *cev, char *end_buf, struct NDIS_WLAN_BSSID_EX *bssid) 1607 char *cev, char *end_buf, struct ndis_80211_bssid_ex *bssid)
1615{ 1608{
1616#ifdef DEBUG 1609#ifdef DEBUG
1617 struct usbnet *usbdev = dev->priv; 1610 struct usbnet *usbdev = dev->priv;
@@ -1645,13 +1638,13 @@ static char *rndis_translate_scan(struct net_device *dev,
1645 le32_to_cpu(bssid->InfrastructureMode)); 1638 le32_to_cpu(bssid->InfrastructureMode));
1646 iwe.cmd = SIOCGIWMODE; 1639 iwe.cmd = SIOCGIWMODE;
1647 switch (le32_to_cpu(bssid->InfrastructureMode)) { 1640 switch (le32_to_cpu(bssid->InfrastructureMode)) {
1648 case Ndis802_11IBSS: 1641 case ndis_80211_infra_adhoc:
1649 iwe.u.mode = IW_MODE_ADHOC; 1642 iwe.u.mode = IW_MODE_ADHOC;
1650 break; 1643 break;
1651 case Ndis802_11Infrastructure: 1644 case ndis_80211_infra_infra:
1652 iwe.u.mode = IW_MODE_INFRA; 1645 iwe.u.mode = IW_MODE_INFRA;
1653 break; 1646 break;
1654 /*case Ndis802_11AutoUnknown:*/ 1647 /*case ndis_80211_infra_auto_unknown:*/
1655 default: 1648 default:
1656 iwe.u.mode = IW_MODE_AUTO; 1649 iwe.u.mode = IW_MODE_AUTO;
1657 break; 1650 break;
@@ -1677,7 +1670,7 @@ static char *rndis_translate_scan(struct net_device *dev,
1677 devdbg(usbdev, "ENCODE %d", le32_to_cpu(bssid->Privacy)); 1670 devdbg(usbdev, "ENCODE %d", le32_to_cpu(bssid->Privacy));
1678 iwe.cmd = SIOCGIWENCODE; 1671 iwe.cmd = SIOCGIWENCODE;
1679 iwe.u.data.length = 0; 1672 iwe.u.data.length = 0;
1680 if (le32_to_cpu(bssid->Privacy) == Ndis802_11PrivFilterAcceptAll) 1673 if (le32_to_cpu(bssid->Privacy) == ndis_80211_priv_accept_all)
1681 iwe.u.data.flags = IW_ENCODE_DISABLED; 1674 iwe.u.data.flags = IW_ENCODE_DISABLED;
1682 else 1675 else
1683 iwe.u.data.flags = IW_ENCODE_ENABLED | IW_ENCODE_NOKEY; 1676 iwe.u.data.flags = IW_ENCODE_ENABLED | IW_ENCODE_NOKEY;
@@ -1716,10 +1709,10 @@ static char *rndis_translate_scan(struct net_device *dev,
1716 iwe.u.data.length = strlen(sbuf); 1709 iwe.u.data.length = strlen(sbuf);
1717 cev = iwe_stream_add_point(cev, end_buf, &iwe, sbuf); 1710 cev = iwe_stream_add_point(cev, end_buf, &iwe, sbuf);
1718 1711
1719 ie = (void *)(bssid->IEs + sizeof(struct NDIS_802_11_FIXED_IEs)); 1712 ie = (void *)(bssid->IEs + sizeof(struct ndis_80211_fixed_ies));
1720 ie_len = min(bssid_len - (int)sizeof(*bssid), 1713 ie_len = min(bssid_len - (int)sizeof(*bssid),
1721 (int)le32_to_cpu(bssid->IELength)); 1714 (int)le32_to_cpu(bssid->IELength));
1722 ie_len -= sizeof(struct NDIS_802_11_FIXED_IEs); 1715 ie_len -= sizeof(struct ndis_80211_fixed_ies);
1723 while (ie_len >= sizeof(*ie) && sizeof(*ie) + ie->len <= ie_len) { 1716 while (ie_len >= sizeof(*ie) && sizeof(*ie) + ie->len <= ie_len) {
1724 if ((ie->id == MFIE_TYPE_GENERIC && ie->len >= 4 && 1717 if ((ie->id == MFIE_TYPE_GENERIC && ie->len >= 4 &&
1725 memcmp(ie->data, "\x00\x50\xf2\x01", 4) == 0) || 1718 memcmp(ie->data, "\x00\x50\xf2\x01", 4) == 0) ||
@@ -1746,8 +1739,8 @@ static int rndis_iw_get_scan(struct net_device *dev,
1746 struct usbnet *usbdev = dev->priv; 1739 struct usbnet *usbdev = dev->priv;
1747 void *buf = NULL; 1740 void *buf = NULL;
1748 char *cev = extra; 1741 char *cev = extra;
1749 struct NDIS_802_11_BSSID_LIST_EX *bssid_list; 1742 struct ndis_80211_bssid_list_ex *bssid_list;
1750 struct NDIS_WLAN_BSSID_EX *bssid; 1743 struct ndis_80211_bssid_ex *bssid;
1751 int ret = -EINVAL, len, count, bssid_len; 1744 int ret = -EINVAL, len, count, bssid_len;
1752 1745
1753 devdbg(usbdev, "SIOCGIWSCAN"); 1746 devdbg(usbdev, "SIOCGIWSCAN");
@@ -1948,7 +1941,7 @@ static int rndis_iw_set_freq(struct net_device *dev,
1948 struct iw_request_info *info, union iwreq_data *wrqu, char *extra) 1941 struct iw_request_info *info, union iwreq_data *wrqu, char *extra)
1949{ 1942{
1950 struct usbnet *usbdev = dev->priv; 1943 struct usbnet *usbdev = dev->priv;
1951 struct NDIS_802_11_CONFIGURATION config; 1944 struct ndis_80211_conf config;
1952 unsigned int dsconfig; 1945 unsigned int dsconfig;
1953 int len, ret; 1946 int len, ret;
1954 1947
@@ -1979,7 +1972,7 @@ static int rndis_iw_get_freq(struct net_device *dev,
1979 struct iw_request_info *info, union iwreq_data *wrqu, char *extra) 1972 struct iw_request_info *info, union iwreq_data *wrqu, char *extra)
1980{ 1973{
1981 struct usbnet *usbdev = dev->priv; 1974 struct usbnet *usbdev = dev->priv;
1982 struct NDIS_802_11_CONFIGURATION config; 1975 struct ndis_80211_conf config;
1983 int len, ret; 1976 int len, ret;
1984 1977
1985 len = sizeof(config); 1978 len = sizeof(config);
@@ -2266,14 +2259,14 @@ static int rndis_wext_get_caps(struct usbnet *dev)
2266 n = 8; 2259 n = 8;
2267 for (i = 0; i < n; i++) { 2260 for (i = 0; i < n; i++) {
2268 switch (le32_to_cpu(networks_supported.items[i])) { 2261 switch (le32_to_cpu(networks_supported.items[i])) {
2269 case Ndis802_11FH: 2262 case ndis_80211_type_freq_hop:
2270 case Ndis802_11DS: 2263 case ndis_80211_type_direct_seq:
2271 priv->caps |= CAP_MODE_80211B; 2264 priv->caps |= CAP_MODE_80211B;
2272 break; 2265 break;
2273 case Ndis802_11OFDM5: 2266 case ndis_80211_type_ofdm_a:
2274 priv->caps |= CAP_MODE_80211A; 2267 priv->caps |= CAP_MODE_80211A;
2275 break; 2268 break;
2276 case Ndis802_11OFDM24: 2269 case ndis_80211_type_ofdm_g:
2277 priv->caps |= CAP_MODE_80211G; 2270 priv->caps |= CAP_MODE_80211G;
2278 break; 2271 break;
2279 } 2272 }