aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/wireless/sme.c18
1 files changed, 16 insertions, 2 deletions
diff --git a/net/wireless/sme.c b/net/wireless/sme.c
index 0b776b769c0f..340934f714b2 100644
--- a/net/wireless/sme.c
+++ b/net/wireless/sme.c
@@ -658,14 +658,28 @@ int __cfg80211_connect(struct cfg80211_registered_device *rdev,
658 658
659 if (connkeys && connkeys->def >= 0) { 659 if (connkeys && connkeys->def >= 0) {
660 int idx; 660 int idx;
661 u32 cipher;
661 662
662 idx = connkeys->def; 663 idx = connkeys->def;
664 cipher = connkeys->params[idx].cipher;
663 /* If given a WEP key we may need it for shared key auth */ 665 /* If given a WEP key we may need it for shared key auth */
664 if (connkeys->params[idx].cipher == WLAN_CIPHER_SUITE_WEP40 || 666 if (cipher == WLAN_CIPHER_SUITE_WEP40 ||
665 connkeys->params[idx].cipher == WLAN_CIPHER_SUITE_WEP104) { 667 cipher == WLAN_CIPHER_SUITE_WEP104) {
666 connect->key_idx = idx; 668 connect->key_idx = idx;
667 connect->key = connkeys->params[idx].key; 669 connect->key = connkeys->params[idx].key;
668 connect->key_len = connkeys->params[idx].key_len; 670 connect->key_len = connkeys->params[idx].key_len;
671
672 /*
673 * If ciphers are not set (e.g. when going through
674 * iwconfig), we have to set them appropriately here.
675 */
676 if (connect->crypto.cipher_group == 0)
677 connect->crypto.cipher_group = cipher;
678
679 if (connect->crypto.n_ciphers_pairwise == 0) {
680 connect->crypto.n_ciphers_pairwise = 1;
681 connect->crypto.ciphers_pairwise[0] = cipher;
682 }
669 } 683 }
670 } 684 }
671 685