diff options
author | Johannes Berg <johannes.berg@intel.com> | 2010-03-30 05:43:05 -0400 |
---|---|---|
committer | Reinette Chatre <reinette.chatre@intel.com> | 2010-04-09 14:27:41 -0400 |
commit | 43a61261d7f571f760611711cd4e6b64ef661ad1 (patch) | |
tree | 6caf10fa75e408efbbde317f42ef7cf17dd58f5e /drivers/net/wireless/iwlwifi/iwl-sta.c | |
parent | 335348b1702cf78c9e79987a3d66e85a05c98b5c (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/iwl-sta.c')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-sta.c | 8 |
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); |