aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/iwlwifi
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2010-03-30 05:43:05 -0400
committerReinette Chatre <reinette.chatre@intel.com>2010-04-09 14:27:41 -0400
commit43a61261d7f571f760611711cd4e6b64ef661ad1 (patch)
tree6caf10fa75e408efbbde317f42ef7cf17dd58f5e /drivers/net/wireless/iwlwifi
parent335348b1702cf78c9e79987a3d66e85a05c98b5c (diff)
iwlwifi: remove wrong key use check
Default WEP keys and regular keys are not allocated from the same space in the firmware, so we shouldn't use the same bits to indicate in use. For default WEP keys, however, mac80211 won't allow using the same key index twice, so the check is not necessary at all -- add/remove are perfectly nested due to those checks. Other keys are allocated in the device in a global array that only has a certain number of slots, so for that we need to keep the allocation bitmap; but the 802.11 key index isn't relevant there. Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Reinette Chatre <reinette.chatre@intel.com>
Diffstat (limited to 'drivers/net/wireless/iwlwifi')
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-sta.c8
1 files changed, 0 insertions, 8 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-sta.c b/drivers/net/wireless/iwlwifi/iwl-sta.c
index be3d222d8f2b..a43493f2abcf 100644
--- a/drivers/net/wireless/iwlwifi/iwl-sta.c
+++ b/drivers/net/wireless/iwlwifi/iwl-sta.c
@@ -822,10 +822,6 @@ int iwl_remove_default_wep_key(struct iwl_priv *priv,
822 IWL_DEBUG_WEP(priv, "Removing default WEP key: idx=%d\n", 822 IWL_DEBUG_WEP(priv, "Removing default WEP key: idx=%d\n",
823 keyconf->keyidx); 823 keyconf->keyidx);
824 824
825 if (!test_and_clear_bit(keyconf->keyidx, &priv->ucode_key_table))
826 IWL_ERR(priv, "index %d not used in uCode key table.\n",
827 keyconf->keyidx);
828
829 memset(&priv->wep_keys[keyconf->keyidx], 0, sizeof(priv->wep_keys[0])); 825 memset(&priv->wep_keys[keyconf->keyidx], 0, sizeof(priv->wep_keys[0]));
830 if (iwl_is_rfkill(priv)) { 826 if (iwl_is_rfkill(priv)) {
831 IWL_DEBUG_WEP(priv, "Not sending REPLY_WEPKEY command due to RFKILL.\n"); 827 IWL_DEBUG_WEP(priv, "Not sending REPLY_WEPKEY command due to RFKILL.\n");
@@ -857,10 +853,6 @@ int iwl_set_default_wep_key(struct iwl_priv *priv,
857 keyconf->hw_key_idx = HW_KEY_DEFAULT; 853 keyconf->hw_key_idx = HW_KEY_DEFAULT;
858 priv->stations[IWL_AP_ID].keyinfo.alg = ALG_WEP; 854 priv->stations[IWL_AP_ID].keyinfo.alg = ALG_WEP;
859 855
860 if (test_and_set_bit(keyconf->keyidx, &priv->ucode_key_table))
861 IWL_ERR(priv, "index %d already used in uCode key table.\n",
862 keyconf->keyidx);
863
864 priv->wep_keys[keyconf->keyidx].key_size = keyconf->keylen; 856 priv->wep_keys[keyconf->keyidx].key_size = keyconf->keylen;
865 memcpy(&priv->wep_keys[keyconf->keyidx].key, &keyconf->key, 857 memcpy(&priv->wep_keys[keyconf->keyidx].key, &keyconf->key,
866 keyconf->keylen); 858 keyconf->keylen);