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.c258
1 files changed, 126 insertions, 132 deletions
diff --git a/drivers/net/wireless/rndis_wlan.c b/drivers/net/wireless/rndis_wlan.c
index 157c46463429..977751f372ff 100644
--- a/drivers/net/wireless/rndis_wlan.c
+++ b/drivers/net/wireless/rndis_wlan.c
@@ -195,80 +195,80 @@ enum ndis_80211_priv_filter {
195}; 195};
196 196
197struct ndis_80211_ssid { 197struct ndis_80211_ssid {
198 __le32 SsidLength; 198 __le32 length;
199 u8 Ssid[NDIS_802_11_LENGTH_SSID]; 199 u8 essid[NDIS_802_11_LENGTH_SSID];
200} __attribute__((packed)); 200} __attribute__((packed));
201 201
202struct ndis_80211_conf_freq_hop { 202struct ndis_80211_conf_freq_hop {
203 __le32 Length; 203 __le32 length;
204 __le32 HopPattern; 204 __le32 hop_pattern;
205 __le32 HopSet; 205 __le32 hop_set;
206 __le32 DwellTime; 206 __le32 dwell_time;
207} __attribute__((packed)); 207} __attribute__((packed));
208 208
209struct ndis_80211_conf { 209struct ndis_80211_conf {
210 __le32 Length; 210 __le32 length;
211 __le32 BeaconPeriod; 211 __le32 beacon_period;
212 __le32 ATIMWindow; 212 __le32 atim_window;
213 __le32 DSConfig; 213 __le32 ds_config;
214 struct ndis_80211_conf_freq_hop FHConfig; 214 struct ndis_80211_conf_freq_hop fh_config;
215} __attribute__((packed)); 215} __attribute__((packed));
216 216
217struct ndis_80211_bssid_ex { 217struct ndis_80211_bssid_ex {
218 __le32 Length; 218 __le32 length;
219 u8 MacAddress[6]; 219 u8 mac[6];
220 u8 Padding[2]; 220 u8 padding[2];
221 struct ndis_80211_ssid Ssid; 221 struct ndis_80211_ssid ssid;
222 __le32 Privacy; 222 __le32 privacy;
223 __le32 Rssi; 223 __le32 rssi;
224 __le32 NetworkTypeInUse; 224 __le32 net_type;
225 struct ndis_80211_conf Configuration; 225 struct ndis_80211_conf config;
226 __le32 InfrastructureMode; 226 __le32 net_infra;
227 u8 SupportedRates[NDIS_802_11_LENGTH_RATES_EX]; 227 u8 rates[NDIS_802_11_LENGTH_RATES_EX];
228 __le32 IELength; 228 __le32 ie_length;
229 u8 IEs[0]; 229 u8 ies[0];
230} __attribute__((packed)); 230} __attribute__((packed));
231 231
232struct ndis_80211_bssid_list_ex { 232struct ndis_80211_bssid_list_ex {
233 __le32 NumberOfItems; 233 __le32 num_items;
234 struct ndis_80211_bssid_ex Bssid[0]; 234 struct ndis_80211_bssid_ex bssid[0];
235} __attribute__((packed)); 235} __attribute__((packed));
236 236
237struct ndis_80211_fixed_ies { 237struct ndis_80211_fixed_ies {
238 u8 Timestamp[8]; 238 u8 timestamp[8];
239 __le16 BeaconInterval; 239 __le16 beacon_interval;
240 __le16 Capabilities; 240 __le16 capabilities;
241} __attribute__((packed)); 241} __attribute__((packed));
242 242
243struct ndis_80211_wep_key { 243struct ndis_80211_wep_key {
244 __le32 Length; 244 __le32 size;
245 __le32 KeyIndex; 245 __le32 index;
246 __le32 KeyLength; 246 __le32 length;
247 u8 KeyMaterial[32]; 247 u8 material[32];
248} __attribute__((packed)); 248} __attribute__((packed));
249 249
250struct ndis_80211_key { 250struct ndis_80211_key {
251 __le32 Length; 251 __le32 size;
252 __le32 KeyIndex; 252 __le32 index;
253 __le32 KeyLength; 253 __le32 length;
254 u8 Bssid[6]; 254 u8 bssid[6];
255 u8 Padding[6]; 255 u8 padding[6];
256 u8 KeyRSC[8]; 256 u8 rsc[8];
257 u8 KeyMaterial[32]; 257 u8 material[32];
258} __attribute__((packed)); 258} __attribute__((packed));
259 259
260struct ndis_80211_remove_key { 260struct ndis_80211_remove_key {
261 __le32 Length; 261 __le32 size;
262 __le32 KeyIndex; 262 __le32 index;
263 u8 Bssid[6]; 263 u8 bssid[6];
264} __attribute__((packed)); 264} __attribute__((packed));
265 265
266struct ndis_config_param { 266struct ndis_config_param {
267 __le32 ParameterNameOffset; 267 __le32 name_offs;
268 __le32 ParameterNameLength; 268 __le32 name_length;
269 __le32 ParameterType; 269 __le32 type;
270 __le32 ParameterValueOffset; 270 __le32 value_offs;
271 __le32 ParameterValueLength; 271 __le32 value_length;
272} __attribute__((packed)); 272} __attribute__((packed));
273 273
274/* these have to match what is in wpa_supplicant */ 274/* these have to match what is in wpa_supplicant */
@@ -512,12 +512,11 @@ static int rndis_set_config_parameter(struct usbnet *dev, char *param,
512 devdbg(dev, "setting config parameter: %s, value: %d", 512 devdbg(dev, "setting config parameter: %s, value: %d",
513 param, *(u32 *)value); 513 param, *(u32 *)value);
514 514
515 infobuf->ParameterNameOffset = cpu_to_le32(sizeof(*infobuf)); 515 infobuf->name_offs = cpu_to_le32(sizeof(*infobuf));
516 infobuf->ParameterNameLength = cpu_to_le32(param_len); 516 infobuf->name_length = cpu_to_le32(param_len);
517 infobuf->ParameterType = cpu_to_le32(value_type); 517 infobuf->type = cpu_to_le32(value_type);
518 infobuf->ParameterValueOffset = cpu_to_le32(sizeof(*infobuf) + 518 infobuf->value_offs = cpu_to_le32(sizeof(*infobuf) + param_len);
519 param_len); 519 infobuf->value_length = cpu_to_le32(value_len);
520 infobuf->ParameterValueLength = cpu_to_le32(value_len);
521 520
522 /* simple string to unicode string conversion */ 521 /* simple string to unicode string conversion */
523 unibuf = (void *)infobuf + sizeof(*infobuf); 522 unibuf = (void *)infobuf + sizeof(*infobuf);
@@ -631,14 +630,14 @@ static int get_essid(struct usbnet *usbdev, struct ndis_80211_ssid *ssid)
631 ret = rndis_query_oid(usbdev, OID_802_11_SSID, ssid, &len); 630 ret = rndis_query_oid(usbdev, OID_802_11_SSID, ssid, &len);
632 631
633 if (ret != 0) 632 if (ret != 0)
634 ssid->SsidLength = 0; 633 ssid->length = 0;
635 634
636#ifdef DEBUG 635#ifdef DEBUG
637 { 636 {
638 unsigned char tmp[NDIS_802_11_LENGTH_SSID + 1]; 637 unsigned char tmp[NDIS_802_11_LENGTH_SSID + 1];
639 638
640 memcpy(tmp, ssid->Ssid, le32_to_cpu(ssid->SsidLength)); 639 memcpy(tmp, ssid->essid, le32_to_cpu(ssid->length));
641 tmp[le32_to_cpu(ssid->SsidLength)] = 0; 640 tmp[le32_to_cpu(ssid->length)] = 0;
642 devdbg(usbdev, "get_essid: '%s', ret: %d", tmp, ret); 641 devdbg(usbdev, "get_essid: '%s', ret: %d", tmp, ret);
643 } 642 }
644#endif 643#endif
@@ -707,12 +706,12 @@ static int disassociate(struct usbnet *usbdev, int reset_ssid)
707 /* disassociate causes radio to be turned off; if reset_ssid 706 /* disassociate causes radio to be turned off; if reset_ssid
708 * is given, set random ssid to enable radio */ 707 * is given, set random ssid to enable radio */
709 if (reset_ssid) { 708 if (reset_ssid) {
710 ssid.SsidLength = cpu_to_le32(sizeof(ssid.Ssid)); 709 ssid.length = cpu_to_le32(sizeof(ssid.essid));
711 get_random_bytes(&ssid.Ssid[2], sizeof(ssid.Ssid)-2); 710 get_random_bytes(&ssid.essid[2], sizeof(ssid.essid)-2);
712 ssid.Ssid[0] = 0x1; 711 ssid.essid[0] = 0x1;
713 ssid.Ssid[1] = 0xff; 712 ssid.essid[1] = 0xff;
714 for (i = 2; i < sizeof(ssid.Ssid); i++) 713 for (i = 2; i < sizeof(ssid.essid); i++)
715 ssid.Ssid[i] = 0x1 + (ssid.Ssid[i] * 0xfe / 0xff); 714 ssid.essid[i] = 0x1 + (ssid.essid[i] * 0xfe / 0xff);
716 ret = set_essid(usbdev, &ssid); 715 ret = set_essid(usbdev, &ssid);
717 } 716 }
718 return ret; 717 return ret;
@@ -900,13 +899,13 @@ static int add_wep_key(struct usbnet *usbdev, char *key, int key_len, int index)
900 899
901 memset(&ndis_key, 0, sizeof(ndis_key)); 900 memset(&ndis_key, 0, sizeof(ndis_key));
902 901
903 ndis_key.Length = cpu_to_le32(sizeof(ndis_key)); 902 ndis_key.size = cpu_to_le32(sizeof(ndis_key));
904 ndis_key.KeyLength = cpu_to_le32(key_len); 903 ndis_key.length = cpu_to_le32(key_len);
905 ndis_key.KeyIndex = cpu_to_le32(index); 904 ndis_key.index = cpu_to_le32(index);
906 memcpy(&ndis_key.KeyMaterial, key, key_len); 905 memcpy(&ndis_key.material, key, key_len);
907 906
908 if (index == priv->encr_tx_key_index) { 907 if (index == priv->encr_tx_key_index) {
909 ndis_key.KeyIndex |= cpu_to_le32(1 << 31); 908 ndis_key.index |= cpu_to_le32(1 << 31);
910 ret = set_encr_mode(usbdev, IW_AUTH_CIPHER_WEP104, 909 ret = set_encr_mode(usbdev, IW_AUTH_CIPHER_WEP104,
911 IW_AUTH_CIPHER_NONE); 910 IW_AUTH_CIPHER_NONE);
912 if (ret) 911 if (ret)
@@ -947,17 +946,17 @@ static int remove_key(struct usbnet *usbdev, int index, u8 bssid[ETH_ALEN])
947 priv->wpa_cipher_pair == IW_AUTH_CIPHER_CCMP || 946 priv->wpa_cipher_pair == IW_AUTH_CIPHER_CCMP ||
948 priv->wpa_cipher_group == IW_AUTH_CIPHER_TKIP || 947 priv->wpa_cipher_group == IW_AUTH_CIPHER_TKIP ||
949 priv->wpa_cipher_group == IW_AUTH_CIPHER_CCMP) { 948 priv->wpa_cipher_group == IW_AUTH_CIPHER_CCMP) {
950 remove_key.Length = cpu_to_le32(sizeof(remove_key)); 949 remove_key.size = cpu_to_le32(sizeof(remove_key));
951 remove_key.KeyIndex = cpu_to_le32(index); 950 remove_key.index = cpu_to_le32(index);
952 if (bssid) { 951 if (bssid) {
953 /* pairwise key */ 952 /* pairwise key */
954 if (memcmp(bssid, ffff_bssid, ETH_ALEN) != 0) 953 if (memcmp(bssid, ffff_bssid, ETH_ALEN) != 0)
955 remove_key.KeyIndex |= cpu_to_le32(1 << 30); 954 remove_key.index |= cpu_to_le32(1 << 30);
956 memcpy(remove_key.Bssid, bssid, 955 memcpy(remove_key.bssid, bssid,
957 sizeof(remove_key.Bssid)); 956 sizeof(remove_key.bssid));
958 } else 957 } else
959 memset(remove_key.Bssid, 0xff, 958 memset(remove_key.bssid, 0xff,
960 sizeof(remove_key.Bssid)); 959 sizeof(remove_key.bssid));
961 960
962 ret = rndis_set_oid(usbdev, OID_802_11_REMOVE_KEY, &remove_key, 961 ret = rndis_set_oid(usbdev, OID_802_11_REMOVE_KEY, &remove_key,
963 sizeof(remove_key)); 962 sizeof(remove_key));
@@ -1187,11 +1186,11 @@ static int rndis_iw_set_essid(struct net_device *dev,
1187 if (length > NDIS_802_11_LENGTH_SSID) 1186 if (length > NDIS_802_11_LENGTH_SSID)
1188 length = NDIS_802_11_LENGTH_SSID; 1187 length = NDIS_802_11_LENGTH_SSID;
1189 1188
1190 ssid.SsidLength = cpu_to_le32(length); 1189 ssid.length = cpu_to_le32(length);
1191 if (length > 0) 1190 if (length > 0)
1192 memcpy(ssid.Ssid, essid, length); 1191 memcpy(ssid.essid, essid, length);
1193 else 1192 else
1194 memset(ssid.Ssid, 0, NDIS_802_11_LENGTH_SSID); 1193 memset(ssid.essid, 0, NDIS_802_11_LENGTH_SSID);
1195 1194
1196 set_assoc_params(usbdev); 1195 set_assoc_params(usbdev);
1197 1196
@@ -1211,10 +1210,10 @@ static int rndis_iw_get_essid(struct net_device *dev,
1211 1210
1212 ret = get_essid(usbdev, &ssid); 1211 ret = get_essid(usbdev, &ssid);
1213 1212
1214 if (ret == 0 && le32_to_cpu(ssid.SsidLength) > 0) { 1213 if (ret == 0 && le32_to_cpu(ssid.length) > 0) {
1215 wrqu->essid.flags = 1; 1214 wrqu->essid.flags = 1;
1216 wrqu->essid.length = le32_to_cpu(ssid.SsidLength); 1215 wrqu->essid.length = le32_to_cpu(ssid.length);
1217 memcpy(essid, ssid.Ssid, wrqu->essid.length); 1216 memcpy(essid, ssid.essid, wrqu->essid.length);
1218 essid[wrqu->essid.length] = 0; 1217 essid[wrqu->essid.length] = 0;
1219 } else { 1218 } else {
1220 memset(essid, 0, sizeof(NDIS_802_11_LENGTH_SSID)); 1219 memset(essid, 0, sizeof(NDIS_802_11_LENGTH_SSID));
@@ -1525,54 +1524,54 @@ static int rndis_iw_set_encode_ext(struct net_device *dev,
1525 ext->alg == IW_ENCODE_ALG_NONE || ext->key_len == 0) 1524 ext->alg == IW_ENCODE_ALG_NONE || ext->key_len == 0)
1526 return remove_key(usbdev, keyidx, NULL); 1525 return remove_key(usbdev, keyidx, NULL);
1527 1526
1528 if (ext->key_len > sizeof(ndis_key.KeyMaterial)) 1527 if (ext->key_len > sizeof(ndis_key.material))
1529 return -1; 1528 return -1;
1530 1529
1531 memset(&ndis_key, 0, sizeof(ndis_key)); 1530 memset(&ndis_key, 0, sizeof(ndis_key));
1532 1531
1533 ndis_key.Length = cpu_to_le32(sizeof(ndis_key) - 1532 ndis_key.size = cpu_to_le32(sizeof(ndis_key) -
1534 sizeof(ndis_key.KeyMaterial) + ext->key_len); 1533 sizeof(ndis_key.material) + ext->key_len);
1535 ndis_key.KeyLength = cpu_to_le32(ext->key_len); 1534 ndis_key.length = cpu_to_le32(ext->key_len);
1536 ndis_key.KeyIndex = cpu_to_le32(keyidx); 1535 ndis_key.index = cpu_to_le32(keyidx);
1537 1536
1538 if (ext->ext_flags & IW_ENCODE_EXT_RX_SEQ_VALID) { 1537 if (ext->ext_flags & IW_ENCODE_EXT_RX_SEQ_VALID) {
1539 memcpy(ndis_key.KeyRSC, ext->rx_seq, 6); 1538 memcpy(ndis_key.rsc, ext->rx_seq, 6);
1540 ndis_key.KeyIndex |= cpu_to_le32(1 << 29); 1539 ndis_key.index |= cpu_to_le32(1 << 29);
1541 } 1540 }
1542 1541
1543 addr = ext->addr.sa_data; 1542 addr = ext->addr.sa_data;
1544 if (ext->ext_flags & IW_ENCODE_EXT_GROUP_KEY) { 1543 if (ext->ext_flags & IW_ENCODE_EXT_GROUP_KEY) {
1545 /* group key */ 1544 /* group key */
1546 if (priv->infra_mode == ndis_80211_infra_adhoc) 1545 if (priv->infra_mode == ndis_80211_infra_adhoc)
1547 memset(ndis_key.Bssid, 0xff, ETH_ALEN); 1546 memset(ndis_key.bssid, 0xff, ETH_ALEN);
1548 else 1547 else
1549 get_bssid(usbdev, ndis_key.Bssid); 1548 get_bssid(usbdev, ndis_key.bssid);
1550 } else { 1549 } else {
1551 /* pairwise key */ 1550 /* pairwise key */
1552 ndis_key.KeyIndex |= cpu_to_le32(1 << 30); 1551 ndis_key.index |= cpu_to_le32(1 << 30);
1553 memcpy(ndis_key.Bssid, addr, ETH_ALEN); 1552 memcpy(ndis_key.bssid, addr, ETH_ALEN);
1554 } 1553 }
1555 1554
1556 if (ext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY) 1555 if (ext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY)
1557 ndis_key.KeyIndex |= cpu_to_le32(1 << 31); 1556 ndis_key.index |= cpu_to_le32(1 << 31);
1558 1557
1559 if (ext->alg == IW_ENCODE_ALG_TKIP && ext->key_len == 32) { 1558 if (ext->alg == IW_ENCODE_ALG_TKIP && ext->key_len == 32) {
1560 /* wpa_supplicant gives us the Michael MIC RX/TX keys in 1559 /* wpa_supplicant gives us the Michael MIC RX/TX keys in
1561 * different order than NDIS spec, so swap the order here. */ 1560 * different order than NDIS spec, so swap the order here. */
1562 memcpy(ndis_key.KeyMaterial, ext->key, 16); 1561 memcpy(ndis_key.material, ext->key, 16);
1563 memcpy(ndis_key.KeyMaterial + 16, ext->key + 24, 8); 1562 memcpy(ndis_key.material + 16, ext->key + 24, 8);
1564 memcpy(ndis_key.KeyMaterial + 24, ext->key + 16, 8); 1563 memcpy(ndis_key.material + 24, ext->key + 16, 8);
1565 } else 1564 } else
1566 memcpy(ndis_key.KeyMaterial, ext->key, ext->key_len); 1565 memcpy(ndis_key.material, ext->key, ext->key_len);
1567 1566
1568 ret = rndis_set_oid(usbdev, OID_802_11_ADD_KEY, &ndis_key, 1567 ret = rndis_set_oid(usbdev, OID_802_11_ADD_KEY, &ndis_key,
1569 le32_to_cpu(ndis_key.Length)); 1568 le32_to_cpu(ndis_key.size));
1570 devdbg(usbdev, "SIOCSIWENCODEEXT: OID_802_11_ADD_KEY -> %08X", ret); 1569 devdbg(usbdev, "SIOCSIWENCODEEXT: OID_802_11_ADD_KEY -> %08X", ret);
1571 if (ret != 0) 1570 if (ret != 0)
1572 return ret; 1571 return ret;
1573 1572
1574 priv->encr_key_len[keyidx] = ext->key_len; 1573 priv->encr_key_len[keyidx] = ext->key_len;
1575 memcpy(&priv->encr_keys[keyidx], ndis_key.KeyMaterial, ext->key_len); 1574 memcpy(&priv->encr_keys[keyidx], ndis_key.material, ext->key_len);
1576 if (ext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY) 1575 if (ext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY)
1577 priv->encr_tx_key_index = keyidx; 1576 priv->encr_tx_key_index = keyidx;
1578 1577
@@ -1617,27 +1616,24 @@ static char *rndis_translate_scan(struct net_device *dev,
1617 unsigned char sbuf[32]; 1616 unsigned char sbuf[32];
1618 DECLARE_MAC_BUF(mac); 1617 DECLARE_MAC_BUF(mac);
1619 1618
1620 bssid_len = le32_to_cpu(bssid->Length); 1619 bssid_len = le32_to_cpu(bssid->length);
1621 1620
1622 devdbg(usbdev, "BSSID %s", print_mac(mac, bssid->MacAddress)); 1621 devdbg(usbdev, "BSSID %s", print_mac(mac, bssid->mac));
1623 iwe.cmd = SIOCGIWAP; 1622 iwe.cmd = SIOCGIWAP;
1624 iwe.u.ap_addr.sa_family = ARPHRD_ETHER; 1623 iwe.u.ap_addr.sa_family = ARPHRD_ETHER;
1625 memcpy(iwe.u.ap_addr.sa_data, bssid->MacAddress, ETH_ALEN); 1624 memcpy(iwe.u.ap_addr.sa_data, bssid->mac, ETH_ALEN);
1626 cev = iwe_stream_add_event(cev, end_buf, &iwe, IW_EV_ADDR_LEN); 1625 cev = iwe_stream_add_event(cev, end_buf, &iwe, IW_EV_ADDR_LEN);
1627 1626
1628 devdbg(usbdev, "SSID(%d) %s", 1627 devdbg(usbdev, "SSID(%d) %s", le32_to_cpu(bssid->ssid.length),
1629 le32_to_cpu(bssid->Ssid.SsidLength), 1628 bssid->ssid.essid);
1630 bssid->Ssid.Ssid);
1631 iwe.cmd = SIOCGIWESSID; 1629 iwe.cmd = SIOCGIWESSID;
1632 iwe.u.essid.length = le32_to_cpu(bssid->Ssid.SsidLength); 1630 iwe.u.essid.length = le32_to_cpu(bssid->ssid.length);
1633 iwe.u.essid.flags = 1; 1631 iwe.u.essid.flags = 1;
1634 cev = iwe_stream_add_point(cev, end_buf, &iwe, 1632 cev = iwe_stream_add_point(cev, end_buf, &iwe, bssid->ssid.essid);
1635 bssid->Ssid.Ssid);
1636 1633
1637 devdbg(usbdev, "MODE %d", 1634 devdbg(usbdev, "MODE %d", le32_to_cpu(bssid->net_infra));
1638 le32_to_cpu(bssid->InfrastructureMode));
1639 iwe.cmd = SIOCGIWMODE; 1635 iwe.cmd = SIOCGIWMODE;
1640 switch (le32_to_cpu(bssid->InfrastructureMode)) { 1636 switch (le32_to_cpu(bssid->net_infra)) {
1641 case ndis_80211_infra_adhoc: 1637 case ndis_80211_infra_adhoc:
1642 iwe.u.mode = IW_MODE_ADHOC; 1638 iwe.u.mode = IW_MODE_ADHOC;
1643 break; 1639 break;
@@ -1651,26 +1647,24 @@ static char *rndis_translate_scan(struct net_device *dev,
1651 } 1647 }
1652 cev = iwe_stream_add_event(cev, end_buf, &iwe, IW_EV_UINT_LEN); 1648 cev = iwe_stream_add_event(cev, end_buf, &iwe, IW_EV_UINT_LEN);
1653 1649
1654 devdbg(usbdev, "FREQ %d kHz", 1650 devdbg(usbdev, "FREQ %d kHz", le32_to_cpu(bssid->config.ds_config));
1655 le32_to_cpu(bssid->Configuration.DSConfig));
1656 iwe.cmd = SIOCGIWFREQ; 1651 iwe.cmd = SIOCGIWFREQ;
1657 dsconfig_to_freq(le32_to_cpu(bssid->Configuration.DSConfig), 1652 dsconfig_to_freq(le32_to_cpu(bssid->config.ds_config), &iwe.u.freq);
1658 &iwe.u.freq);
1659 cev = iwe_stream_add_event(cev, end_buf, &iwe, IW_EV_FREQ_LEN); 1653 cev = iwe_stream_add_event(cev, end_buf, &iwe, IW_EV_FREQ_LEN);
1660 1654
1661 devdbg(usbdev, "QUAL %d", le32_to_cpu(bssid->Rssi)); 1655 devdbg(usbdev, "QUAL %d", le32_to_cpu(bssid->rssi));
1662 iwe.cmd = IWEVQUAL; 1656 iwe.cmd = IWEVQUAL;
1663 iwe.u.qual.qual = level_to_qual(le32_to_cpu(bssid->Rssi)); 1657 iwe.u.qual.qual = level_to_qual(le32_to_cpu(bssid->rssi));
1664 iwe.u.qual.level = le32_to_cpu(bssid->Rssi); 1658 iwe.u.qual.level = le32_to_cpu(bssid->rssi);
1665 iwe.u.qual.updated = IW_QUAL_QUAL_UPDATED 1659 iwe.u.qual.updated = IW_QUAL_QUAL_UPDATED
1666 | IW_QUAL_LEVEL_UPDATED 1660 | IW_QUAL_LEVEL_UPDATED
1667 | IW_QUAL_NOISE_INVALID; 1661 | IW_QUAL_NOISE_INVALID;
1668 cev = iwe_stream_add_event(cev, end_buf, &iwe, IW_EV_QUAL_LEN); 1662 cev = iwe_stream_add_event(cev, end_buf, &iwe, IW_EV_QUAL_LEN);
1669 1663
1670 devdbg(usbdev, "ENCODE %d", le32_to_cpu(bssid->Privacy)); 1664 devdbg(usbdev, "ENCODE %d", le32_to_cpu(bssid->privacy));
1671 iwe.cmd = SIOCGIWENCODE; 1665 iwe.cmd = SIOCGIWENCODE;
1672 iwe.u.data.length = 0; 1666 iwe.u.data.length = 0;
1673 if (le32_to_cpu(bssid->Privacy) == ndis_80211_priv_accept_all) 1667 if (le32_to_cpu(bssid->privacy) == ndis_80211_priv_accept_all)
1674 iwe.u.data.flags = IW_ENCODE_DISABLED; 1668 iwe.u.data.flags = IW_ENCODE_DISABLED;
1675 else 1669 else
1676 iwe.u.data.flags = IW_ENCODE_ENABLED | IW_ENCODE_NOKEY; 1670 iwe.u.data.flags = IW_ENCODE_ENABLED | IW_ENCODE_NOKEY;
@@ -1680,10 +1674,10 @@ static char *rndis_translate_scan(struct net_device *dev,
1680 devdbg(usbdev, "RATES:"); 1674 devdbg(usbdev, "RATES:");
1681 current_val = cev + IW_EV_LCP_LEN; 1675 current_val = cev + IW_EV_LCP_LEN;
1682 iwe.cmd = SIOCGIWRATE; 1676 iwe.cmd = SIOCGIWRATE;
1683 for (i = 0; i < sizeof(bssid->SupportedRates); i++) { 1677 for (i = 0; i < sizeof(bssid->rates); i++) {
1684 if (bssid->SupportedRates[i] & 0x7f) { 1678 if (bssid->rates[i] & 0x7f) {
1685 iwe.u.bitrate.value = 1679 iwe.u.bitrate.value =
1686 ((bssid->SupportedRates[i] & 0x7f) * 1680 ((bssid->rates[i] & 0x7f) *
1687 500000); 1681 500000);
1688 devdbg(usbdev, " %d", iwe.u.bitrate.value); 1682 devdbg(usbdev, " %d", iwe.u.bitrate.value);
1689 current_val = iwe_stream_add_value(cev, 1683 current_val = iwe_stream_add_value(cev,
@@ -1695,23 +1689,23 @@ static char *rndis_translate_scan(struct net_device *dev,
1695 if ((current_val - cev) > IW_EV_LCP_LEN) 1689 if ((current_val - cev) > IW_EV_LCP_LEN)
1696 cev = current_val; 1690 cev = current_val;
1697 1691
1698 beacon = le32_to_cpu(bssid->Configuration.BeaconPeriod); 1692 beacon = le32_to_cpu(bssid->config.beacon_period);
1699 devdbg(usbdev, "BCN_INT %d", beacon); 1693 devdbg(usbdev, "BCN_INT %d", beacon);
1700 iwe.cmd = IWEVCUSTOM; 1694 iwe.cmd = IWEVCUSTOM;
1701 snprintf(sbuf, sizeof(sbuf), "bcn_int=%d", beacon); 1695 snprintf(sbuf, sizeof(sbuf), "bcn_int=%d", beacon);
1702 iwe.u.data.length = strlen(sbuf); 1696 iwe.u.data.length = strlen(sbuf);
1703 cev = iwe_stream_add_point(cev, end_buf, &iwe, sbuf); 1697 cev = iwe_stream_add_point(cev, end_buf, &iwe, sbuf);
1704 1698
1705 atim = le32_to_cpu(bssid->Configuration.ATIMWindow); 1699 atim = le32_to_cpu(bssid->config.atim_window);
1706 devdbg(usbdev, "ATIM %d", atim); 1700 devdbg(usbdev, "ATIM %d", atim);
1707 iwe.cmd = IWEVCUSTOM; 1701 iwe.cmd = IWEVCUSTOM;
1708 snprintf(sbuf, sizeof(sbuf), "atim=%u", atim); 1702 snprintf(sbuf, sizeof(sbuf), "atim=%u", atim);
1709 iwe.u.data.length = strlen(sbuf); 1703 iwe.u.data.length = strlen(sbuf);
1710 cev = iwe_stream_add_point(cev, end_buf, &iwe, sbuf); 1704 cev = iwe_stream_add_point(cev, end_buf, &iwe, sbuf);
1711 1705
1712 ie = (void *)(bssid->IEs + sizeof(struct ndis_80211_fixed_ies)); 1706 ie = (void *)(bssid->ies + sizeof(struct ndis_80211_fixed_ies));
1713 ie_len = min(bssid_len - (int)sizeof(*bssid), 1707 ie_len = min(bssid_len - (int)sizeof(*bssid),
1714 (int)le32_to_cpu(bssid->IELength)); 1708 (int)le32_to_cpu(bssid->ie_length));
1715 ie_len -= sizeof(struct ndis_80211_fixed_ies); 1709 ie_len -= sizeof(struct ndis_80211_fixed_ies);
1716 while (ie_len >= sizeof(*ie) && sizeof(*ie) + ie->len <= ie_len) { 1710 while (ie_len >= sizeof(*ie) && sizeof(*ie) + ie->len <= ie_len) {
1717 if ((ie->id == MFIE_TYPE_GENERIC && ie->len >= 4 && 1711 if ((ie->id == MFIE_TYPE_GENERIC && ie->len >= 4 &&
@@ -1758,16 +1752,16 @@ static int rndis_iw_get_scan(struct net_device *dev,
1758 goto out; 1752 goto out;
1759 1753
1760 bssid_list = buf; 1754 bssid_list = buf;
1761 bssid = bssid_list->Bssid; 1755 bssid = bssid_list->bssid;
1762 bssid_len = le32_to_cpu(bssid->Length); 1756 bssid_len = le32_to_cpu(bssid->length);
1763 count = le32_to_cpu(bssid_list->NumberOfItems); 1757 count = le32_to_cpu(bssid_list->num_items);
1764 devdbg(usbdev, "SIOCGIWSCAN: %d BSSIDs found", count); 1758 devdbg(usbdev, "SIOCGIWSCAN: %d BSSIDs found", count);
1765 1759
1766 while (count && ((void *)bssid + bssid_len) <= (buf + len)) { 1760 while (count && ((void *)bssid + bssid_len) <= (buf + len)) {
1767 cev = rndis_translate_scan(dev, cev, extra + IW_SCAN_MAX_DATA, 1761 cev = rndis_translate_scan(dev, cev, extra + IW_SCAN_MAX_DATA,
1768 bssid); 1762 bssid);
1769 bssid = (void *)bssid + bssid_len; 1763 bssid = (void *)bssid + bssid_len;
1770 bssid_len = le32_to_cpu(bssid->Length); 1764 bssid_len = le32_to_cpu(bssid->length);
1771 count--; 1765 count--;
1772 } 1766 }
1773 1767
@@ -1960,7 +1954,7 @@ static int rndis_iw_set_freq(struct net_device *dev,
1960 return 0; 1954 return 0;
1961 } 1955 }
1962 1956
1963 config.DSConfig = cpu_to_le32(dsconfig); 1957 config.ds_config = cpu_to_le32(dsconfig);
1964 1958
1965 devdbg(usbdev, "SIOCSIWFREQ: %d * 10^%d", wrqu->freq.m, wrqu->freq.e); 1959 devdbg(usbdev, "SIOCSIWFREQ: %d * 10^%d", wrqu->freq.m, wrqu->freq.e);
1966 return rndis_set_oid(usbdev, OID_802_11_CONFIGURATION, &config, 1960 return rndis_set_oid(usbdev, OID_802_11_CONFIGURATION, &config,
@@ -1978,7 +1972,7 @@ static int rndis_iw_get_freq(struct net_device *dev,
1978 len = sizeof(config); 1972 len = sizeof(config);
1979 ret = rndis_query_oid(usbdev, OID_802_11_CONFIGURATION, &config, &len); 1973 ret = rndis_query_oid(usbdev, OID_802_11_CONFIGURATION, &config, &len);
1980 if (ret == 0) 1974 if (ret == 0)
1981 dsconfig_to_freq(le32_to_cpu(config.DSConfig), &wrqu->freq); 1975 dsconfig_to_freq(le32_to_cpu(config.ds_config), &wrqu->freq);
1982 1976
1983 devdbg(usbdev, "SIOCGIWFREQ: %d", wrqu->freq.m); 1977 devdbg(usbdev, "SIOCGIWFREQ: %d", wrqu->freq.m);
1984 return ret; 1978 return ret;