diff options
Diffstat (limited to 'drivers/net/wireless/rt2x00/rt2x00crypto.c')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00crypto.c | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2x00crypto.c b/drivers/net/wireless/rt2x00/rt2x00crypto.c index aee9cba13eb3..0b41845d9543 100644 --- a/drivers/net/wireless/rt2x00/rt2x00crypto.c +++ b/drivers/net/wireless/rt2x00/rt2x00crypto.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | Copyright (C) 2004 - 2008 rt2x00 SourceForge Project | 2 | Copyright (C) 2004 - 2009 rt2x00 SourceForge Project |
3 | <http://rt2x00.serialmonkey.com> | 3 | <http://rt2x00.serialmonkey.com> |
4 | 4 | ||
5 | This program is free software; you can redistribute it and/or modify | 5 | This program is free software; you can redistribute it and/or modify |
@@ -49,9 +49,14 @@ enum cipher rt2x00crypto_key_to_cipher(struct ieee80211_key_conf *key) | |||
49 | void rt2x00crypto_create_tx_descriptor(struct queue_entry *entry, | 49 | void rt2x00crypto_create_tx_descriptor(struct queue_entry *entry, |
50 | struct txentry_desc *txdesc) | 50 | struct txentry_desc *txdesc) |
51 | { | 51 | { |
52 | struct rt2x00_dev *rt2x00dev = entry->queue->rt2x00dev; | ||
52 | struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(entry->skb); | 53 | struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(entry->skb); |
53 | struct ieee80211_key_conf *hw_key = tx_info->control.hw_key; | 54 | struct ieee80211_key_conf *hw_key = tx_info->control.hw_key; |
54 | 55 | ||
56 | if (!test_bit(CONFIG_SUPPORT_HW_CRYPTO, &rt2x00dev->flags) || | ||
57 | !hw_key || entry->skb->do_not_encrypt) | ||
58 | return; | ||
59 | |||
55 | __set_bit(ENTRY_TXD_ENCRYPT, &txdesc->flags); | 60 | __set_bit(ENTRY_TXD_ENCRYPT, &txdesc->flags); |
56 | 61 | ||
57 | txdesc->cipher = rt2x00crypto_key_to_cipher(hw_key); | 62 | txdesc->cipher = rt2x00crypto_key_to_cipher(hw_key); |
@@ -69,11 +74,17 @@ void rt2x00crypto_create_tx_descriptor(struct queue_entry *entry, | |||
69 | __set_bit(ENTRY_TXD_ENCRYPT_MMIC, &txdesc->flags); | 74 | __set_bit(ENTRY_TXD_ENCRYPT_MMIC, &txdesc->flags); |
70 | } | 75 | } |
71 | 76 | ||
72 | unsigned int rt2x00crypto_tx_overhead(struct ieee80211_tx_info *tx_info) | 77 | unsigned int rt2x00crypto_tx_overhead(struct rt2x00_dev *rt2x00dev, |
78 | struct sk_buff *skb) | ||
73 | { | 79 | { |
80 | struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb); | ||
74 | struct ieee80211_key_conf *key = tx_info->control.hw_key; | 81 | struct ieee80211_key_conf *key = tx_info->control.hw_key; |
75 | unsigned int overhead = 0; | 82 | unsigned int overhead = 0; |
76 | 83 | ||
84 | if (!test_bit(CONFIG_SUPPORT_HW_CRYPTO, &rt2x00dev->flags) || | ||
85 | !key || skb->do_not_encrypt) | ||
86 | return overhead; | ||
87 | |||
77 | /* | 88 | /* |
78 | * Extend frame length to include IV/EIV/ICV/MMIC, | 89 | * Extend frame length to include IV/EIV/ICV/MMIC, |
79 | * note that these lengths should only be added when | 90 | * note that these lengths should only be added when |