aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/wireless/rndis_wlan.c23
1 files changed, 18 insertions, 5 deletions
diff --git a/drivers/net/wireless/rndis_wlan.c b/drivers/net/wireless/rndis_wlan.c
index 4b3e04699a67..041680019a8e 100644
--- a/drivers/net/wireless/rndis_wlan.c
+++ b/drivers/net/wireless/rndis_wlan.c
@@ -196,6 +196,18 @@ enum ndis_80211_priv_filter {
196 ndis_80211_priv_8021x_wep 196 ndis_80211_priv_8021x_wep
197}; 197};
198 198
199enum ndis_80211_addkey_bits {
200 ndis_80211_addkey_8021x_auth = cpu_to_le32(1 << 28),
201 ndis_80211_addkey_set_init_recv_seq = cpu_to_le32(1 << 29),
202 ndis_80211_addkey_pairwise_key = cpu_to_le32(1 << 30),
203 ndis_80211_addkey_transmit_key = cpu_to_le32(1 << 31),
204};
205
206enum ndis_80211_addwep_bits {
207 ndis_80211_addwep_perclient_key = cpu_to_le32(1 << 30),
208 ndis_80211_addwep_transmit_key = cpu_to_le32(1 << 31),
209};
210
199struct ndis_80211_ssid { 211struct ndis_80211_ssid {
200 __le32 length; 212 __le32 length;
201 u8 essid[NDIS_802_11_LENGTH_SSID]; 213 u8 essid[NDIS_802_11_LENGTH_SSID];
@@ -998,7 +1010,7 @@ static int add_wep_key(struct usbnet *usbdev, char *key, int key_len, int index)
998 memcpy(&ndis_key.material, key, key_len); 1010 memcpy(&ndis_key.material, key, key_len);
999 1011
1000 if (index == priv->encr_tx_key_index) { 1012 if (index == priv->encr_tx_key_index) {
1001 ndis_key.index |= cpu_to_le32(1 << 31); 1013 ndis_key.index |= ndis_80211_addwep_transmit_key;
1002 ret = set_encr_mode(usbdev, IW_AUTH_CIPHER_WEP104, 1014 ret = set_encr_mode(usbdev, IW_AUTH_CIPHER_WEP104,
1003 IW_AUTH_CIPHER_NONE); 1015 IW_AUTH_CIPHER_NONE);
1004 if (ret) 1016 if (ret)
@@ -1044,7 +1056,8 @@ static int remove_key(struct usbnet *usbdev, int index, u8 bssid[ETH_ALEN])
1044 if (bssid) { 1056 if (bssid) {
1045 /* pairwise key */ 1057 /* pairwise key */
1046 if (memcmp(bssid, ffff_bssid, ETH_ALEN) != 0) 1058 if (memcmp(bssid, ffff_bssid, ETH_ALEN) != 0)
1047 remove_key.index |= cpu_to_le32(1 << 30); 1059 remove_key.index |=
1060 ndis_80211_addkey_pairwise_key;
1048 memcpy(remove_key.bssid, bssid, 1061 memcpy(remove_key.bssid, bssid,
1049 sizeof(remove_key.bssid)); 1062 sizeof(remove_key.bssid));
1050 } else 1063 } else
@@ -1626,7 +1639,7 @@ static int rndis_iw_set_encode_ext(struct net_device *dev,
1626 1639
1627 if (ext->ext_flags & IW_ENCODE_EXT_RX_SEQ_VALID) { 1640 if (ext->ext_flags & IW_ENCODE_EXT_RX_SEQ_VALID) {
1628 memcpy(ndis_key.rsc, ext->rx_seq, 6); 1641 memcpy(ndis_key.rsc, ext->rx_seq, 6);
1629 ndis_key.index |= cpu_to_le32(1 << 29); 1642 ndis_key.index |= ndis_80211_addkey_set_init_recv_seq;
1630 } 1643 }
1631 1644
1632 addr = ext->addr.sa_data; 1645 addr = ext->addr.sa_data;
@@ -1638,12 +1651,12 @@ static int rndis_iw_set_encode_ext(struct net_device *dev,
1638 get_bssid(usbdev, ndis_key.bssid); 1651 get_bssid(usbdev, ndis_key.bssid);
1639 } else { 1652 } else {
1640 /* pairwise key */ 1653 /* pairwise key */
1641 ndis_key.index |= cpu_to_le32(1 << 30); 1654 ndis_key.index |= ndis_80211_addkey_pairwise_key;
1642 memcpy(ndis_key.bssid, addr, ETH_ALEN); 1655 memcpy(ndis_key.bssid, addr, ETH_ALEN);
1643 } 1656 }
1644 1657
1645 if (ext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY) 1658 if (ext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY)
1646 ndis_key.index |= cpu_to_le32(1 << 31); 1659 ndis_key.index |= ndis_80211_addkey_transmit_key;
1647 1660
1648 if (ext->alg == IW_ENCODE_ALG_TKIP && ext->key_len == 32) { 1661 if (ext->alg == IW_ENCODE_ALG_TKIP && ext->key_len == 32) {
1649 /* wpa_supplicant gives us the Michael MIC RX/TX keys in 1662 /* wpa_supplicant gives us the Michael MIC RX/TX keys in