diff options
Diffstat (limited to 'net/ipv4/tcp_output.c')
-rw-r--r-- | net/ipv4/tcp_output.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index f46d24b8410f..cbb83acd830a 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c | |||
@@ -687,7 +687,7 @@ int tcp_fragment(struct sock *sk, struct sk_buff *skb, u32 len, unsigned int mss | |||
687 | 687 | ||
688 | BUG_ON(len > skb->len); | 688 | BUG_ON(len > skb->len); |
689 | 689 | ||
690 | tcp_clear_all_retrans_hints(tp); | 690 | tcp_clear_retrans_hints_partial(tp); |
691 | nsize = skb_headlen(skb) - len; | 691 | nsize = skb_headlen(skb) - len; |
692 | if (nsize < 0) | 692 | if (nsize < 0) |
693 | nsize = 0; | 693 | nsize = 0; |
@@ -1718,9 +1718,6 @@ static void tcp_retrans_try_collapse(struct sock *sk, struct sk_buff *skb, int m | |||
1718 | BUG_ON(tcp_skb_pcount(skb) != 1 || | 1718 | BUG_ON(tcp_skb_pcount(skb) != 1 || |
1719 | tcp_skb_pcount(next_skb) != 1); | 1719 | tcp_skb_pcount(next_skb) != 1); |
1720 | 1720 | ||
1721 | /* changing transmit queue under us so clear hints */ | ||
1722 | tcp_clear_all_retrans_hints(tp); | ||
1723 | |||
1724 | /* Ok. We will be able to collapse the packet. */ | 1721 | /* Ok. We will be able to collapse the packet. */ |
1725 | tcp_unlink_write_queue(next_skb, sk); | 1722 | tcp_unlink_write_queue(next_skb, sk); |
1726 | 1723 | ||
@@ -1759,6 +1756,13 @@ static void tcp_retrans_try_collapse(struct sock *sk, struct sk_buff *skb, int m | |||
1759 | 1756 | ||
1760 | tcp_adjust_fackets_out(tp, skb, tcp_skb_pcount(next_skb)); | 1757 | tcp_adjust_fackets_out(tp, skb, tcp_skb_pcount(next_skb)); |
1761 | tp->packets_out -= tcp_skb_pcount(next_skb); | 1758 | tp->packets_out -= tcp_skb_pcount(next_skb); |
1759 | |||
1760 | /* changed transmit queue under us so clear hints */ | ||
1761 | tcp_clear_retrans_hints_partial(tp); | ||
1762 | /* manually tune sacktag skb hint */ | ||
1763 | if (tp->fastpath_skb_hint == next_skb) | ||
1764 | tp->fastpath_skb_hint = skb; | ||
1765 | |||
1762 | sk_stream_free_skb(sk, next_skb); | 1766 | sk_stream_free_skb(sk, next_skb); |
1763 | } | 1767 | } |
1764 | } | 1768 | } |