306-mac80211-add-hdrlen-to-ieee80211_tx_data.patch 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. From: Janusz Dziedzic <[email protected]>
  2. Date: Fri, 19 Feb 2016 11:01:49 +0100
  3. Subject: [PATCH] mac80211: add hdrlen to ieee80211_tx_data
  4. Add hdrlen to ieee80211_tx_data and use this
  5. when wep/ccmd/tkip. This is preparation for
  6. aligned4 code.
  7. Signed-off-by: Janusz Dziedzic <[email protected]>
  8. ---
  9. --- a/net/mac80211/ieee80211_i.h
  10. +++ b/net/mac80211/ieee80211_i.h
  11. @@ -173,6 +173,7 @@ struct ieee80211_tx_data {
  12. struct ieee80211_tx_rate rate;
  13. unsigned int flags;
  14. + unsigned int hdrlen;
  15. };
  16. --- a/net/mac80211/tx.c
  17. +++ b/net/mac80211/tx.c
  18. @@ -922,7 +922,7 @@ ieee80211_tx_h_fragment(struct ieee80211
  19. struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
  20. struct ieee80211_hdr *hdr = (void *)skb->data;
  21. int frag_threshold = tx->local->hw.wiphy->frag_threshold;
  22. - int hdrlen;
  23. + int hdrlen = tx->hdrlen;
  24. int fragnum;
  25. /* no matter what happens, tx->skb moves to tx->skbs */
  26. @@ -943,8 +943,6 @@ ieee80211_tx_h_fragment(struct ieee80211
  27. if (WARN_ON(info->flags & IEEE80211_TX_CTL_AMPDU))
  28. return TX_DROP;
  29. - hdrlen = ieee80211_hdrlen(hdr->frame_control);
  30. -
  31. /* internal error, why isn't DONTFRAG set? */
  32. if (WARN_ON(skb->len + FCS_LEN <= frag_threshold))
  33. return TX_DROP;
  34. @@ -1176,6 +1174,8 @@ ieee80211_tx_prepare(struct ieee80211_su
  35. hdr = (struct ieee80211_hdr *) skb->data;
  36. + tx->hdrlen = ieee80211_hdrlen(hdr->frame_control);
  37. +
  38. if (likely(sta)) {
  39. if (!IS_ERR(sta))
  40. tx->sta = sta;
  41. --- a/net/mac80211/util.c
  42. +++ b/net/mac80211/util.c
  43. @@ -1226,6 +1226,7 @@ void ieee80211_send_auth(struct ieee8021
  44. struct ieee80211_local *local = sdata->local;
  45. struct sk_buff *skb;
  46. struct ieee80211_mgmt *mgmt;
  47. + unsigned int hdrlen;
  48. int err;
  49. /* 24 + 6 = header + auth_algo + auth_transaction + status_code */
  50. @@ -1250,8 +1251,10 @@ void ieee80211_send_auth(struct ieee8021
  51. memcpy(skb_put(skb, extra_len), extra, extra_len);
  52. if (auth_alg == WLAN_AUTH_SHARED_KEY && transaction == 3) {
  53. + hdrlen = ieee80211_hdrlen(mgmt->frame_control);
  54. mgmt->frame_control |= cpu_to_le16(IEEE80211_FCTL_PROTECTED);
  55. - err = ieee80211_wep_encrypt(local, skb, key, key_len, key_idx);
  56. + err = ieee80211_wep_encrypt(local, skb, hdrlen, key,
  57. + key_len, key_idx);
  58. WARN_ON(err);
  59. }
  60. --- a/net/mac80211/wep.c
  61. +++ b/net/mac80211/wep.c
  62. @@ -89,11 +89,11 @@ static void ieee80211_wep_get_iv(struct
  63. static u8 *ieee80211_wep_add_iv(struct ieee80211_local *local,
  64. struct sk_buff *skb,
  65. + unsigned int hdrlen,
  66. int keylen, int keyidx)
  67. {
  68. struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
  69. struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
  70. - unsigned int hdrlen;
  71. u8 *newhdr;
  72. hdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_PROTECTED);
  73. @@ -101,7 +101,6 @@ static u8 *ieee80211_wep_add_iv(struct i
  74. if (WARN_ON(skb_headroom(skb) < IEEE80211_WEP_IV_LEN))
  75. return NULL;
  76. - hdrlen = ieee80211_hdrlen(hdr->frame_control);
  77. newhdr = skb_push(skb, IEEE80211_WEP_IV_LEN);
  78. memmove(newhdr, newhdr + IEEE80211_WEP_IV_LEN, hdrlen);
  79. @@ -160,6 +159,7 @@ int ieee80211_wep_encrypt_data(struct cr
  80. */
  81. int ieee80211_wep_encrypt(struct ieee80211_local *local,
  82. struct sk_buff *skb,
  83. + unsigned int hdrlen,
  84. const u8 *key, int keylen, int keyidx)
  85. {
  86. u8 *iv;
  87. @@ -169,7 +169,7 @@ int ieee80211_wep_encrypt(struct ieee802
  88. if (WARN_ON(skb_tailroom(skb) < IEEE80211_WEP_ICV_LEN))
  89. return -1;
  90. - iv = ieee80211_wep_add_iv(local, skb, keylen, keyidx);
  91. + iv = ieee80211_wep_add_iv(local, skb, hdrlen, keylen, keyidx);
  92. if (!iv)
  93. return -1;
  94. @@ -306,13 +306,14 @@ static int wep_encrypt_skb(struct ieee80
  95. struct ieee80211_key_conf *hw_key = info->control.hw_key;
  96. if (!hw_key) {
  97. - if (ieee80211_wep_encrypt(tx->local, skb, tx->key->conf.key,
  98. + if (ieee80211_wep_encrypt(tx->local, skb, tx->hdrlen,
  99. + tx->key->conf.key,
  100. tx->key->conf.keylen,
  101. tx->key->conf.keyidx))
  102. return -1;
  103. } else if ((hw_key->flags & IEEE80211_KEY_FLAG_GENERATE_IV) ||
  104. (hw_key->flags & IEEE80211_KEY_FLAG_PUT_IV_SPACE)) {
  105. - if (!ieee80211_wep_add_iv(tx->local, skb,
  106. + if (!ieee80211_wep_add_iv(tx->local, skb, tx->hdrlen,
  107. tx->key->conf.keylen,
  108. tx->key->conf.keyidx))
  109. return -1;
  110. --- a/net/mac80211/wep.h
  111. +++ b/net/mac80211/wep.h
  112. @@ -22,6 +22,7 @@ int ieee80211_wep_encrypt_data(struct cr
  113. size_t klen, u8 *data, size_t data_len);
  114. int ieee80211_wep_encrypt(struct ieee80211_local *local,
  115. struct sk_buff *skb,
  116. + unsigned int hdrlen,
  117. const u8 *key, int keylen, int keyidx);
  118. int ieee80211_wep_decrypt_data(struct crypto_cipher *tfm, u8 *rc4key,
  119. size_t klen, u8 *data, size_t data_len);
  120. --- a/net/mac80211/wpa.c
  121. +++ b/net/mac80211/wpa.c
  122. @@ -43,7 +43,7 @@ ieee80211_tx_h_michael_mic_add(struct ie
  123. skb->len < 24 || !ieee80211_is_data_present(hdr->frame_control))
  124. return TX_CONTINUE;
  125. - hdrlen = ieee80211_hdrlen(hdr->frame_control);
  126. + hdrlen = tx->hdrlen;
  127. if (skb->len < hdrlen)
  128. return TX_DROP;
  129. @@ -186,7 +186,6 @@ mic_fail_no_key:
  130. static int tkip_encrypt_skb(struct ieee80211_tx_data *tx, struct sk_buff *skb)
  131. {
  132. - struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
  133. struct ieee80211_key *key = tx->key;
  134. struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
  135. unsigned int hdrlen;
  136. @@ -201,7 +200,7 @@ static int tkip_encrypt_skb(struct ieee8
  137. return 0;
  138. }
  139. - hdrlen = ieee80211_hdrlen(hdr->frame_control);
  140. + hdrlen = tx->hdrlen;
  141. len = skb->len - hdrlen;
  142. if (info->control.hw_key)
  143. @@ -418,7 +417,7 @@ static int ccmp_encrypt_skb(struct ieee8
  144. return 0;
  145. }
  146. - hdrlen = ieee80211_hdrlen(hdr->frame_control);
  147. + hdrlen = tx->hdrlen;
  148. len = skb->len - hdrlen;
  149. if (info->control.hw_key)
  150. @@ -651,7 +650,7 @@ static int gcmp_encrypt_skb(struct ieee8
  151. return 0;
  152. }
  153. - hdrlen = ieee80211_hdrlen(hdr->frame_control);
  154. + hdrlen = tx->hdrlen;
  155. len = skb->len - hdrlen;
  156. if (info->control.hw_key)
  157. @@ -791,7 +790,6 @@ static ieee80211_tx_result
  158. ieee80211_crypto_cs_encrypt(struct ieee80211_tx_data *tx,
  159. struct sk_buff *skb)
  160. {
  161. - struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
  162. struct ieee80211_key *key = tx->key;
  163. struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
  164. int hdrlen;
  165. @@ -807,8 +805,7 @@ ieee80211_crypto_cs_encrypt(struct ieee8
  166. pskb_expand_head(skb, iv_len, 0, GFP_ATOMIC)))
  167. return TX_DROP;
  168. - hdrlen = ieee80211_hdrlen(hdr->frame_control);
  169. -
  170. + hdrlen = tx->hdrlen;
  171. pos = skb_push(skb, iv_len);
  172. memmove(pos, pos + iv_len, hdrlen);