dccp: make implementation of Syn-RTT symmetric
authorGerrit Renker <gerrit@erg.abdn.ac.uk>
Tue, 22 Jun 2010 01:14:35 +0000 (01:14 +0000)
committerDavid S. Miller <davem@davemloft.net>
Sat, 26 Jun 2010 04:33:15 +0000 (21:33 -0700)
This patch is thanks to Andre Noll who reported the issue and helped testing.

The Syn-RTT sampled during the initial handshake currently only works for
the client sending the DCCP-Request. TFRC penalizes the absence of an RTT
sample with a very slow initial speed (1 packet per second), which delays
slow-start significantly, resulting in sluggish performance.

This patch mirrors the "Syn RTT" principle by adding a timestamp also onto
the DCCP-Response, producing an RTT sample  when the (Data)Ack completing
the handshake arrives.

Also changed the documentation to 'TFRC' since Syn RTTs are also used by CCID-4.

Signed-off-by: Gerrit Renker <gerrit@erg.abdn.ac.uk>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/dccp/input.c
net/dccp/options.c

index 6beb6a7d6fbab77ebd161e09a910959dc57805df..10c957a88f4f7c9c65da3cf2ba825686349c03f4 100644 (file)
@@ -430,7 +430,7 @@ static int dccp_rcv_request_sent_state_process(struct sock *sk,
                if (dccp_parse_options(sk, NULL, skb))
                        return 1;
 
-               /* Obtain usec RTT sample from SYN exchange (used by CCID 3) */
+               /* Obtain usec RTT sample from SYN exchange (used by TFRC). */
                if (likely(dp->dccps_options_received.dccpor_timestamp_echo))
                        dp->dccps_syn_rtt = dccp_sample_rtt(sk, 10 * (tstamp -
                            dp->dccps_options_received.dccpor_timestamp_echo));
@@ -535,6 +535,8 @@ static int dccp_rcv_respond_partopen_state_process(struct sock *sk,
                                                   const struct dccp_hdr *dh,
                                                   const unsigned len)
 {
+       struct dccp_sock *dp = dccp_sk(sk);
+       u32 sample = dp->dccps_options_received.dccpor_timestamp_echo;
        int queued = 0;
 
        switch (dh->dccph_type) {
@@ -559,7 +561,14 @@ static int dccp_rcv_respond_partopen_state_process(struct sock *sk,
                if (sk->sk_state == DCCP_PARTOPEN)
                        inet_csk_clear_xmit_timer(sk, ICSK_TIME_DACK);
 
-               dccp_sk(sk)->dccps_osr = DCCP_SKB_CB(skb)->dccpd_seq;
+               /* Obtain usec RTT sample from SYN exchange (used by TFRC). */
+               if (likely(sample)) {
+                       long delta = dccp_timestamp() - sample;
+
+                       dp->dccps_syn_rtt = dccp_sample_rtt(sk, 10 * delta);
+               }
+
+               dp->dccps_osr = DCCP_SKB_CB(skb)->dccpd_seq;
                dccp_set_state(sk, DCCP_OPEN);
 
                if (dh->dccph_type == DCCP_PKT_DATAACK ||
index 4973badb5d55318a0c730bb2cf78eafa445067b5..bfda087bd90dd792f8190840878379d304152c1d 100644 (file)
@@ -529,7 +529,7 @@ int dccp_insert_options(struct sock *sk, struct sk_buff *skb)
                if (DCCP_SKB_CB(skb)->dccpd_type == DCCP_PKT_REQUEST) {
                        /*
                         * Obtain RTT sample from Request/Response exchange.
-                        * This is currently used in CCID 3 initialisation.
+                        * This is currently used for TFRC initialisation.
                         */
                        if (dccp_insert_option_timestamp(skb))
                                return -1;
@@ -562,6 +562,10 @@ int dccp_insert_options_rsk(struct dccp_request_sock *dreq, struct sk_buff *skb)
        if (dccp_feat_insert_opts(NULL, dreq, skb))
                return -1;
 
+       /* Obtain RTT sample from Response/Ack exchange (used by TFRC). */
+       if (dccp_insert_option_timestamp(skb))
+               return -1;
+
        if (dreq->dreq_timestamp_echo != 0 &&
            dccp_insert_option_timestamp_echo(NULL, dreq, skb))
                return -1;