mirror of
https://github.com/adulau/aha.git
synced 2025-01-01 05:36:24 +00:00
[TCP]: Fix truesize underflow
There is a problem with the TSO packet trimming code. The cause of this lies in the tcp_fragment() function. When we allocate a fragment for a completely non-linear packet the truesize is calculated for a payload length of zero. This means that truesize could in fact be less than the real payload length. When that happens the TSO packet trimming can cause truesize to become negative. This in turn can cause sk_forward_alloc to be -n * PAGE_SIZE which would trigger the warning. I've copied the code DaveM used in tso_fragment which should work here. Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
385910f2b2
commit
ef5cb9738b
1 changed files with 3 additions and 1 deletions
|
@ -551,7 +551,9 @@ int tcp_fragment(struct sock *sk, struct sk_buff *skb, u32 len, unsigned int mss
|
||||||
buff = sk_stream_alloc_skb(sk, nsize, GFP_ATOMIC);
|
buff = sk_stream_alloc_skb(sk, nsize, GFP_ATOMIC);
|
||||||
if (buff == NULL)
|
if (buff == NULL)
|
||||||
return -ENOMEM; /* We'll just try again later. */
|
return -ENOMEM; /* We'll just try again later. */
|
||||||
sk_charge_skb(sk, buff);
|
|
||||||
|
buff->truesize = skb->len - len;
|
||||||
|
skb->truesize -= buff->truesize;
|
||||||
|
|
||||||
/* Correct the sequence numbers. */
|
/* Correct the sequence numbers. */
|
||||||
TCP_SKB_CB(buff)->seq = TCP_SKB_CB(skb)->seq + len;
|
TCP_SKB_CB(buff)->seq = TCP_SKB_CB(skb)->seq + len;
|
||||||
|
|
Loading…
Reference in a new issue