]> git.karo-electronics.de Git - linux-beck.git/commitdiff
ath6kl: Fix default key installation in AP mode
authorEdward Lu <elu@qca.qualcomm.com>
Tue, 30 Aug 2011 18:58:07 +0000 (21:58 +0300)
committerKalle Valo <kvalo@qca.qualcomm.com>
Wed, 31 Aug 2011 07:13:02 +0000 (10:13 +0300)
Signed-off-by: Edward Lu <elu@qca.qualcomm.com>
Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com>
Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
drivers/net/wireless/ath/ath6kl/cfg80211.c

index af8e9ccb256d2eb233b285c7c42a59f00135d4f3..a3aa1505894734543c9f2714ae8f1210c35263ea 100644 (file)
@@ -1025,6 +1025,7 @@ static int ath6kl_cfg80211_set_default_key(struct wiphy *wiphy,
        struct ath6kl_key *key = NULL;
        int status = 0;
        u8 key_usage;
+       enum crypto_type key_type = NONE_CRYPT;
 
        ath6kl_dbg(ATH6KL_DBG_WLAN_CFG, "%s: index %d\n", __func__, key_index);
 
@@ -1049,12 +1050,16 @@ static int ath6kl_cfg80211_set_default_key(struct wiphy *wiphy,
        key_usage = GROUP_USAGE;
        if (ar->prwise_crypto == WEP_CRYPT)
                key_usage |= TX_USAGE;
+       if (unicast)
+               key_type = ar->prwise_crypto;
+       if (multicast)
+               key_type = ar->grp_crypto;
 
        if (ar->nw_type == AP_NETWORK && !test_bit(CONNECTED, &ar->flag))
                return 0; /* Delay until AP mode has been started */
 
        status = ath6kl_wmi_addkey_cmd(ar->wmi, ar->def_txkey_index,
-                                      ar->prwise_crypto, key_usage,
+                                      key_type, key_usage,
                                       key->key_len, key->seq, key->key,
                                       KEY_OP_INIT_VAL, NULL,
                                       SYNC_BOTH_WMIFLAG);
@@ -1617,8 +1622,11 @@ static int ath6kl_ap_beacon(struct wiphy *wiphy, struct net_device *dev,
                        break;
                }
        }
-       if (p.prwise_crypto_type == 0)
+       if (p.prwise_crypto_type == 0) {
                p.prwise_crypto_type = NONE_CRYPT;
+               ath6kl_set_cipher(ar, 0, true);
+       } else if (info->crypto.n_ciphers_pairwise == 1)
+               ath6kl_set_cipher(ar, info->crypto.ciphers_pairwise[0], true);
 
        switch (info->crypto.cipher_group) {
        case WLAN_CIPHER_SUITE_WEP40:
@@ -1635,6 +1643,7 @@ static int ath6kl_ap_beacon(struct wiphy *wiphy, struct net_device *dev,
                p.grp_crypto_type = NONE_CRYPT;
                break;
        }
+       ath6kl_set_cipher(ar, info->crypto.cipher_group, false);
 
        p.nw_type = AP_NETWORK;
        ar->nw_type = ar->next_mode;