diff options
author | Emmanuel Grumbach <emmanuel.grumbach@intel.com> | 2008-05-15 01:54:09 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-05-21 21:48:01 -0400 |
commit | ccc038abe4cb00cf56aeae5b1df47fcc4ed4136c (patch) | |
tree | 0c35fec8a1c9e7179f9b756d30c3f8af02d9bfa5 /drivers/net/wireless/iwlwifi/iwl-tx.c | |
parent | a98410139a2ef6553ae5d73bf12bb9a68d0b38b9 (diff) |
iwlwifi: clean up and bug fix for security
This patch cleans up code in security.
1) uses the new pointer to ieee80211_key_conf passed with the tx_control.
2) resolves bug reported by Mirco Tischler (sends ADD_STA in ASYNC mode)
3) resolves bug reported by Volker Braun regarding dynamic WEP
4) drops a WEP packet which has been garbaged by firmware. This can
happen upon rekeying.
Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/iwlwifi/iwl-tx.c')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-tx.c | 41 |
1 files changed, 12 insertions, 29 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-tx.c b/drivers/net/wireless/iwlwifi/iwl-tx.c index a37ced58c66..f32cddabdf6 100644 --- a/drivers/net/wireless/iwlwifi/iwl-tx.c +++ b/drivers/net/wireless/iwlwifi/iwl-tx.c | |||
@@ -639,16 +639,12 @@ static void iwl_tx_cmd_build_hwcrypto(struct iwl_priv *priv, | |||
639 | struct sk_buff *skb_frag, | 639 | struct sk_buff *skb_frag, |
640 | int sta_id) | 640 | int sta_id) |
641 | { | 641 | { |
642 | struct iwl_hw_key *keyinfo = &priv->stations[sta_id].keyinfo; | 642 | struct ieee80211_key_conf *keyconf = ctl->hw_key; |
643 | struct iwl_wep_key *wepkey; | ||
644 | int keyidx = 0; | ||
645 | 643 | ||
646 | BUG_ON(ctl->hw_key->hw_key_idx > 3); | 644 | switch (keyconf->alg) { |
647 | |||
648 | switch (keyinfo->alg) { | ||
649 | case ALG_CCMP: | 645 | case ALG_CCMP: |
650 | tx_cmd->sec_ctl = TX_CMD_SEC_CCM; | 646 | tx_cmd->sec_ctl = TX_CMD_SEC_CCM; |
651 | memcpy(tx_cmd->key, keyinfo->key, keyinfo->keylen); | 647 | memcpy(tx_cmd->key, keyconf->key, keyconf->keylen); |
652 | if (ctl->flags & IEEE80211_TXCTL_AMPDU) | 648 | if (ctl->flags & IEEE80211_TXCTL_AMPDU) |
653 | tx_cmd->tx_flags |= TX_CMD_FLG_AGG_CCMP_MSK; | 649 | tx_cmd->tx_flags |= TX_CMD_FLG_AGG_CCMP_MSK; |
654 | IWL_DEBUG_TX("tx_cmd with aes hwcrypto\n"); | 650 | IWL_DEBUG_TX("tx_cmd with aes hwcrypto\n"); |
@@ -656,39 +652,26 @@ static void iwl_tx_cmd_build_hwcrypto(struct iwl_priv *priv, | |||
656 | 652 | ||
657 | case ALG_TKIP: | 653 | case ALG_TKIP: |
658 | tx_cmd->sec_ctl = TX_CMD_SEC_TKIP; | 654 | tx_cmd->sec_ctl = TX_CMD_SEC_TKIP; |
659 | ieee80211_get_tkip_key(keyinfo->conf, skb_frag, | 655 | ieee80211_get_tkip_key(keyconf, skb_frag, |
660 | IEEE80211_TKIP_P2_KEY, tx_cmd->key); | 656 | IEEE80211_TKIP_P2_KEY, tx_cmd->key); |
661 | IWL_DEBUG_TX("tx_cmd with tkip hwcrypto\n"); | 657 | IWL_DEBUG_TX("tx_cmd with tkip hwcrypto\n"); |
662 | break; | 658 | break; |
663 | 659 | ||
664 | case ALG_WEP: | 660 | case ALG_WEP: |
665 | wepkey = &priv->wep_keys[ctl->hw_key->hw_key_idx]; | ||
666 | tx_cmd->sec_ctl = 0; | ||
667 | if (priv->default_wep_key) { | ||
668 | /* the WEP key was sent as static */ | ||
669 | keyidx = ctl->hw_key->hw_key_idx; | ||
670 | memcpy(&tx_cmd->key[3], wepkey->key, | ||
671 | wepkey->key_size); | ||
672 | if (wepkey->key_size == WEP_KEY_LEN_128) | ||
673 | tx_cmd->sec_ctl |= TX_CMD_SEC_KEY128; | ||
674 | } else { | ||
675 | /* the WEP key was sent as dynamic */ | ||
676 | keyidx = keyinfo->keyidx; | ||
677 | memcpy(&tx_cmd->key[3], keyinfo->key, | ||
678 | keyinfo->keylen); | ||
679 | if (keyinfo->keylen == WEP_KEY_LEN_128) | ||
680 | tx_cmd->sec_ctl |= TX_CMD_SEC_KEY128; | ||
681 | } | ||
682 | |||
683 | tx_cmd->sec_ctl |= (TX_CMD_SEC_WEP | | 661 | tx_cmd->sec_ctl |= (TX_CMD_SEC_WEP | |
684 | (keyidx & TX_CMD_SEC_MSK) << TX_CMD_SEC_SHIFT); | 662 | (keyconf->keyidx & TX_CMD_SEC_MSK) << TX_CMD_SEC_SHIFT); |
663 | |||
664 | if (keyconf->keylen == WEP_KEY_LEN_128) | ||
665 | tx_cmd->sec_ctl |= TX_CMD_SEC_KEY128; | ||
666 | |||
667 | memcpy(&tx_cmd->key[3], keyconf->key, keyconf->keylen); | ||
685 | 668 | ||
686 | IWL_DEBUG_TX("Configuring packet for WEP encryption " | 669 | IWL_DEBUG_TX("Configuring packet for WEP encryption " |
687 | "with key %d\n", keyidx); | 670 | "with key %d\n", keyconf->keyidx); |
688 | break; | 671 | break; |
689 | 672 | ||
690 | default: | 673 | default: |
691 | printk(KERN_ERR "Unknown encode alg %d\n", keyinfo->alg); | 674 | printk(KERN_ERR "Unknown encode alg %d\n", keyconf->alg); |
692 | break; | 675 | break; |
693 | } | 676 | } |
694 | } | 677 | } |