diff options
author | David S. Miller <davem@davemloft.net> | 2005-07-05 18:19:38 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2005-07-05 18:19:38 -0400 |
commit | 55c97f3e990c1ff63957c64f6cb10711a09fd70e (patch) | |
tree | 003c5ca17005c8b22cc4cbe0b10721fc4ea676fd /net/ipv4/tcp_output.c | |
parent | a2e2a59c93cc8ba39caa9011c2573f429e40ccd9 (diff) |
[TCP]: Fix __tcp_push_pending_frames() 'nonagle' handling.
'nonagle' should be passed to the tcp_snd_test() function
as 'TCP_NAGLE_PUSH' if we are checking an SKB not at the
tail of the write_queue. This is because Nagle does not
apply to such frames since we cannot possibly tack more
data onto them.
However, while doing this __tcp_push_pending_frames() makes
all of the packets in the write_queue use this modified
'nonagle' value.
Fix the bug and simplify this function by just calling
tcp_write_xmit() directly if sk_send_head is non-NULL.
As a result, we can now make tcp_data_snd_check() just call
tcp_push_pending_frames() instead of the specialized
__tcp_data_snd_check().
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/tcp_output.c')
-rw-r--r-- | net/ipv4/tcp_output.c | 15 |
1 files changed, 1 insertions, 14 deletions
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index e292e11c7319..ce1d7cfbecfc 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c | |||
@@ -894,24 +894,11 @@ void __tcp_push_pending_frames(struct sock *sk, struct tcp_sock *tp, | |||
894 | struct sk_buff *skb = sk->sk_send_head; | 894 | struct sk_buff *skb = sk->sk_send_head; |
895 | 895 | ||
896 | if (skb) { | 896 | if (skb) { |
897 | if (!tcp_skb_is_last(sk, skb)) | 897 | if (tcp_write_xmit(sk, cur_mss, nonagle)) |
898 | nonagle = TCP_NAGLE_PUSH; | ||
899 | if (!tcp_snd_test(sk, skb, cur_mss, nonagle) || | ||
900 | tcp_write_xmit(sk, cur_mss, nonagle)) | ||
901 | tcp_check_probe_timer(sk, tp); | 898 | tcp_check_probe_timer(sk, tp); |
902 | } | 899 | } |
903 | } | 900 | } |
904 | 901 | ||
905 | void __tcp_data_snd_check(struct sock *sk, struct sk_buff *skb) | ||
906 | { | ||
907 | struct tcp_sock *tp = tcp_sk(sk); | ||
908 | |||
909 | if (after(TCP_SKB_CB(skb)->end_seq, tp->snd_una + tp->snd_wnd) || | ||
910 | tcp_packets_in_flight(tp) >= tp->snd_cwnd || | ||
911 | tcp_write_xmit(sk, tcp_current_mss(sk, 1), tp->nonagle)) | ||
912 | tcp_check_probe_timer(sk, tp); | ||
913 | } | ||
914 | |||
915 | /* This function returns the amount that we can raise the | 902 | /* This function returns the amount that we can raise the |
916 | * usable window based on the following constraints | 903 | * usable window based on the following constraints |
917 | * | 904 | * |