aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/net/tcp.h45
1 files changed, 23 insertions, 22 deletions
diff --git a/include/net/tcp.h b/include/net/tcp.h
index b55b4891029e..ac37228b7001 100644
--- a/include/net/tcp.h
+++ b/include/net/tcp.h
@@ -890,30 +890,31 @@ static inline int tcp_prequeue(struct sock *sk, struct sk_buff *skb)
890{ 890{
891 struct tcp_sock *tp = tcp_sk(sk); 891 struct tcp_sock *tp = tcp_sk(sk);
892 892
893 if (!sysctl_tcp_low_latency && tp->ucopy.task) { 893 if (sysctl_tcp_low_latency || !tp->ucopy.task)
894 __skb_queue_tail(&tp->ucopy.prequeue, skb); 894 return 0;
895 tp->ucopy.memory += skb->truesize; 895
896 if (tp->ucopy.memory > sk->sk_rcvbuf) { 896 __skb_queue_tail(&tp->ucopy.prequeue, skb);
897 struct sk_buff *skb1; 897 tp->ucopy.memory += skb->truesize;
898 898 if (tp->ucopy.memory > sk->sk_rcvbuf) {
899 BUG_ON(sock_owned_by_user(sk)); 899 struct sk_buff *skb1;
900 900
901 while ((skb1 = __skb_dequeue(&tp->ucopy.prequeue)) != NULL) { 901 BUG_ON(sock_owned_by_user(sk));
902 sk_backlog_rcv(sk, skb1); 902
903 NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPPREQUEUEDROPPED); 903 while ((skb1 = __skb_dequeue(&tp->ucopy.prequeue)) != NULL) {
904 } 904 sk_backlog_rcv(sk, skb1);
905 905 NET_INC_STATS_BH(sock_net(sk),
906 tp->ucopy.memory = 0; 906 LINUX_MIB_TCPPREQUEUEDROPPED);
907 } else if (skb_queue_len(&tp->ucopy.prequeue) == 1) {
908 wake_up_interruptible(sk->sk_sleep);
909 if (!inet_csk_ack_scheduled(sk))
910 inet_csk_reset_xmit_timer(sk, ICSK_TIME_DACK,
911 (3 * TCP_RTO_MIN) / 4,
912 TCP_RTO_MAX);
913 } 907 }
914 return 1; 908
909 tp->ucopy.memory = 0;
910 } else if (skb_queue_len(&tp->ucopy.prequeue) == 1) {
911 wake_up_interruptible(sk->sk_sleep);
912 if (!inet_csk_ack_scheduled(sk))
913 inet_csk_reset_xmit_timer(sk, ICSK_TIME_DACK,
914 (3 * TCP_RTO_MIN) / 4,
915 TCP_RTO_MAX);
915 } 916 }
916 return 0; 917 return 1;
917} 918}
918 919
919 920