diff options
author | Neal Cardwell <ncardwell@google.com> | 2012-02-13 15:22:08 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-02-14 14:38:57 -0500 |
commit | 0af2a0d0576205dda778d25c6c344fc6508fc81d (patch) | |
tree | 3f3b3d70ed8d614c2b64ddeaaac27f526e844497 /net | |
parent | fbcf88b8833ce2c404b9a0e7caab82b20312cbbc (diff) |
tcp: fix tcp_shifted_skb() adjustment of lost_cnt_hint for FACK
This commit ensures that lost_cnt_hint is correctly updated in
tcp_shifted_skb() for FACK TCP senders. The lost_cnt_hint adjustment
in tcp_sacktag_one() only applies to non-FACK senders, so FACK senders
need their own adjustment.
This applies the spirit of 1e5289e121372a3494402b1b131b41bfe1cf9b7f -
except now that the sequence range passed into tcp_sacktag_one() is
correct we need only have a special case adjustment for FACK.
Signed-off-by: Neal Cardwell <ncardwell@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r-- | net/ipv4/tcp_input.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c index 8116d06e042c..53c8ce4046b2 100644 --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c | |||
@@ -1403,6 +1403,10 @@ static int tcp_shifted_skb(struct sock *sk, struct sk_buff *skb, | |||
1403 | 1403 | ||
1404 | BUG_ON(!pcount); | 1404 | BUG_ON(!pcount); |
1405 | 1405 | ||
1406 | /* Adjust hint for FACK. Non-FACK is handled in tcp_sacktag_one(). */ | ||
1407 | if (tcp_is_fack(tp) && (skb == tp->lost_skb_hint)) | ||
1408 | tp->lost_cnt_hint += pcount; | ||
1409 | |||
1406 | TCP_SKB_CB(prev)->end_seq += shifted; | 1410 | TCP_SKB_CB(prev)->end_seq += shifted; |
1407 | TCP_SKB_CB(skb)->seq += shifted; | 1411 | TCP_SKB_CB(skb)->seq += shifted; |
1408 | 1412 | ||