diff options
author | Benoit Papillault <benoit.papillault@free.fr> | 2009-11-24 09:49:18 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-11-28 15:04:50 -0500 |
commit | 1bc1488067ee2c295b933ef6decd6035230f1a1c (patch) | |
tree | 3e378bdeee251367d08fec654056e046b9853c6b /drivers/net/wireless/ath/ath9k/common.c | |
parent | e7824a50662f7f79b1a739f705b4d906c31cf221 (diff) |
ath9k: Proper padding/unpadding for the TX/RX path.
Software padding is done on the TX path and software unpadding is done on the
RX path. This patch corrects the position where the padding occurs. A specific
function computes the pad position and this function is used in the TX and RX
path. This patch has been tested by generating every possible 802.11 frames
with every possible frame_control field and a varying length. This patch is
useful for analyzing non standard 802.11 frames going over the air
Signed-off-by: Benoit Papillault <benoit.papillault@free.fr>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/ath/ath9k/common.c')
-rw-r--r-- | drivers/net/wireless/ath/ath9k/common.c | 24 |
1 files changed, 15 insertions, 9 deletions
diff --git a/drivers/net/wireless/ath/ath9k/common.c b/drivers/net/wireless/ath/ath9k/common.c index d96751ccee9..4d775ae141d 100644 --- a/drivers/net/wireless/ath/ath9k/common.c +++ b/drivers/net/wireless/ath/ath9k/common.c | |||
@@ -236,16 +236,8 @@ void ath9k_cmn_rx_skb_postprocess(struct ath_common *common, | |||
236 | /* see if any padding is done by the hw and remove it */ | 236 | /* see if any padding is done by the hw and remove it */ |
237 | hdr = (struct ieee80211_hdr *) skb->data; | 237 | hdr = (struct ieee80211_hdr *) skb->data; |
238 | hdrlen = ieee80211_get_hdrlen_from_skb(skb); | 238 | hdrlen = ieee80211_get_hdrlen_from_skb(skb); |
239 | padpos = 24; | ||
240 | fc = hdr->frame_control; | 239 | fc = hdr->frame_control; |
241 | if ((fc & cpu_to_le16(IEEE80211_FCTL_FROMDS|IEEE80211_FCTL_TODS)) == | 240 | padpos = ath9k_cmn_padpos(hdr->frame_control); |
242 | cpu_to_le16(IEEE80211_FCTL_FROMDS|IEEE80211_FCTL_TODS)) { | ||
243 | padpos += 6; /* ETH_ALEN */ | ||
244 | } | ||
245 | if ((fc & cpu_to_le16(IEEE80211_STYPE_QOS_DATA|IEEE80211_FCTL_FTYPE)) == | ||
246 | cpu_to_le16(IEEE80211_STYPE_QOS_DATA|IEEE80211_FTYPE_DATA)) { | ||
247 | padpos += 2; | ||
248 | } | ||
249 | 241 | ||
250 | /* The MAC header is padded to have 32-bit boundary if the | 242 | /* The MAC header is padded to have 32-bit boundary if the |
251 | * packet payload is non-zero. The general calculation for | 243 | * packet payload is non-zero. The general calculation for |
@@ -280,6 +272,20 @@ void ath9k_cmn_rx_skb_postprocess(struct ath_common *common, | |||
280 | } | 272 | } |
281 | EXPORT_SYMBOL(ath9k_cmn_rx_skb_postprocess); | 273 | EXPORT_SYMBOL(ath9k_cmn_rx_skb_postprocess); |
282 | 274 | ||
275 | int ath9k_cmn_padpos(__le16 frame_control) | ||
276 | { | ||
277 | int padpos = 24; | ||
278 | if (ieee80211_has_a4(frame_control)) { | ||
279 | padpos += ETH_ALEN; | ||
280 | } | ||
281 | if (ieee80211_is_data_qos(frame_control)) { | ||
282 | padpos += IEEE80211_QOS_CTL_LEN; | ||
283 | } | ||
284 | |||
285 | return padpos; | ||
286 | } | ||
287 | EXPORT_SYMBOL(ath9k_cmn_padpos); | ||
288 | |||
283 | static int __init ath9k_cmn_init(void) | 289 | static int __init ath9k_cmn_init(void) |
284 | { | 290 | { |
285 | return 0; | 291 | return 0; |