]> Git Repo - linux.git/commitdiff
[TCP]: TCP_DEFER_ACCEPT updates - defer timeout conflicts with max_thresh
authorPatrick McManus <[email protected]>
Fri, 21 Mar 2008 23:27:38 +0000 (16:27 -0700)
committerDavid S. Miller <[email protected]>
Fri, 21 Mar 2008 23:27:38 +0000 (16:27 -0700)
timeout associated with SO_DEFER_ACCEPT wasn't being honored if it was
less than the timeout allowed by the maximum syn-recv queue size
algorithm. Fix by using the SO_DEFER_ACCEPT value if the ack has
arrived.

Signed-off-by: Patrick McManus <[email protected]>
Acked-by: Eric Dumazet <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
net/ipv4/inet_connection_sock.c

index c0e0fa03fce1679c29a538e346af163ace09dfbd..f24c7d534081084b507fc5f179c7f9e787096efa 100644 (file)
@@ -461,8 +461,7 @@ void inet_csk_reqsk_queue_prune(struct sock *parent,
                reqp=&lopt->syn_table[i];
                while ((req = *reqp) != NULL) {
                        if (time_after_eq(now, req->expires)) {
-                               if ((req->retrans < thresh ||
-                                    (inet_rsk(req)->acked && req->retrans < max_retries))
+                               if ((req->retrans < (inet_rsk(req)->acked ? max_retries : thresh))
                                    && !req->rsk_ops->rtx_syn_ack(parent, req)) {
                                        unsigned long timeo;
 
This page took 0.052371 seconds and 4 git commands to generate.