|
@@ -1414,8 +1414,9 @@ alloc_new_skb:
|
|
|
*/
|
|
|
skb->ip_summed = csummode;
|
|
|
skb->csum = 0;
|
|
|
- /* reserve for fragmentation */
|
|
|
- skb_reserve(skb, hh_len+sizeof(struct frag_hdr));
|
|
|
+ /* reserve for fragmentation and ipsec header */
|
|
|
+ skb_reserve(skb, hh_len + sizeof(struct frag_hdr) +
|
|
|
+ dst_exthdrlen);
|
|
|
|
|
|
if (sk->sk_type == SOCK_DGRAM)
|
|
|
skb_shinfo(skb)->tx_flags = tx_flags;
|
|
@@ -1423,9 +1424,9 @@ alloc_new_skb:
|
|
|
/*
|
|
|
* Find where to start putting bytes
|
|
|
*/
|
|
|
- data = skb_put(skb, fraglen + dst_exthdrlen);
|
|
|
- skb_set_network_header(skb, exthdrlen + dst_exthdrlen);
|
|
|
- data += fragheaderlen + dst_exthdrlen;
|
|
|
+ data = skb_put(skb, fraglen);
|
|
|
+ skb_set_network_header(skb, exthdrlen);
|
|
|
+ data += fragheaderlen;
|
|
|
skb->transport_header = (skb->network_header +
|
|
|
fragheaderlen);
|
|
|
if (fraggap) {
|