提交 3393da82 编写于 作者: G Gerrit Renker 提交者: David S. Miller

[DCCP]: Simplify interface of dccp_sample_rtt

The third parameter of dccp_sample_rtt now becomes useless and is removed.

Also combined the subtraction of the timestamp echo and the elapsed time.
This is safe, since (a) presence of timestamp echo is tested first and (b)
elapsed time is either present and non-zero or it is not set and equals 0
due to the memset in dccp_parse_options.

To avoid measuring option-processing time, the timestamp for measuring the
initial Request/Response RTT sample is taken directly when the function is
called (the Linux implementation always adds a timestamp on the Request,
so there is no loss in doing this).
Signed-off-by: NGerrit Renker <gerrit@erg.abdn.ac.uk>
Signed-off-by: NIan McDonald <ian.mcdonald@jandi.co.nz>
Signed-off-by: NArnaldo Carvalho de Melo <acme@ghostprotocols.net>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 4c70f383
...@@ -448,7 +448,7 @@ static void ccid3_hc_tx_packet_recv(struct sock *sk, struct sk_buff *skb) ...@@ -448,7 +448,7 @@ static void ccid3_hc_tx_packet_recv(struct sock *sk, struct sk_buff *skb)
* Calculate new round trip sample as per [RFC 3448, 4.3] by * Calculate new round trip sample as per [RFC 3448, 4.3] by
* R_sample = (now - t_recvdata) - t_elapsed * R_sample = (now - t_recvdata) - t_elapsed
*/ */
r_sample = dccp_sample_rtt(sk, now, &packet->dccphtx_tstamp); r_sample = dccp_sample_rtt(sk, ktime_us_delta(now, packet->dccphtx_tstamp));
/* /*
* Update RTT estimate by * Update RTT estimate by
...@@ -881,9 +881,9 @@ static void ccid3_hc_rx_packet_recv(struct sock *sk, struct sk_buff *skb) ...@@ -881,9 +881,9 @@ static void ccid3_hc_rx_packet_recv(struct sock *sk, struct sk_buff *skb)
case DCCP_PKT_DATAACK: case DCCP_PKT_DATAACK:
if (opt_recv->dccpor_timestamp_echo == 0) if (opt_recv->dccpor_timestamp_echo == 0)
break; break;
r_sample = dccp_timestamp() - opt_recv->dccpor_timestamp_echo;
rtt_prev = hcrx->ccid3hcrx_rtt; rtt_prev = hcrx->ccid3hcrx_rtt;
now = ktime_get_real(); r_sample = dccp_sample_rtt(sk, 10 * r_sample);
r_sample = dccp_sample_rtt(sk, now, NULL);
if (hcrx->ccid3hcrx_state == TFRC_RSTATE_NO_DATA) if (hcrx->ccid3hcrx_state == TFRC_RSTATE_NO_DATA)
hcrx->ccid3hcrx_rtt = r_sample; hcrx->ccid3hcrx_rtt = r_sample;
......
...@@ -297,8 +297,7 @@ extern int dccp_v4_connect(struct sock *sk, struct sockaddr *uaddr, ...@@ -297,8 +297,7 @@ extern int dccp_v4_connect(struct sock *sk, struct sockaddr *uaddr,
extern int dccp_send_reset(struct sock *sk, enum dccp_reset_codes code); extern int dccp_send_reset(struct sock *sk, enum dccp_reset_codes code);
extern void dccp_send_close(struct sock *sk, const int active); extern void dccp_send_close(struct sock *sk, const int active);
extern int dccp_invalid_packet(struct sk_buff *skb); extern int dccp_invalid_packet(struct sk_buff *skb);
extern u32 dccp_sample_rtt(struct sock *sk, ktime_t t_recv, extern u32 dccp_sample_rtt(struct sock *sk, long delta);
ktime_t *t_history);
static inline int dccp_bad_service_code(const struct sock *sk, static inline int dccp_bad_service_code(const struct sock *sk,
const __be32 service) const __be32 service)
......
...@@ -280,6 +280,7 @@ static int dccp_rcv_request_sent_state_process(struct sock *sk, ...@@ -280,6 +280,7 @@ static int dccp_rcv_request_sent_state_process(struct sock *sk,
if (dh->dccph_type == DCCP_PKT_RESPONSE) { if (dh->dccph_type == DCCP_PKT_RESPONSE) {
const struct inet_connection_sock *icsk = inet_csk(sk); const struct inet_connection_sock *icsk = inet_csk(sk);
struct dccp_sock *dp = dccp_sk(sk); struct dccp_sock *dp = dccp_sk(sk);
long tstamp = dccp_timestamp();
/* Stop the REQUEST timer */ /* Stop the REQUEST timer */
inet_csk_clear_xmit_timer(sk, ICSK_TIME_RETRANS); inet_csk_clear_xmit_timer(sk, ICSK_TIME_RETRANS);
...@@ -300,11 +301,10 @@ static int dccp_rcv_request_sent_state_process(struct sock *sk, ...@@ -300,11 +301,10 @@ static int dccp_rcv_request_sent_state_process(struct sock *sk,
if (dccp_parse_options(sk, skb)) if (dccp_parse_options(sk, skb))
goto out_invalid_packet; goto out_invalid_packet;
/* Obtain RTT sample from SYN exchange (used by CCID 3) */ /* Obtain usec RTT sample from SYN exchange (used by CCID 3) */
if (dp->dccps_options_received.dccpor_timestamp_echo) if (likely(dp->dccps_options_received.dccpor_timestamp_echo))
dp->dccps_syn_rtt = dccp_sample_rtt(sk, dp->dccps_syn_rtt = dccp_sample_rtt(sk, 10 * (tstamp -
ktime_get_real(), dp->dccps_options_received.dccpor_timestamp_echo));
NULL);
if (dccp_msk(sk)->dccpms_send_ack_vector && if (dccp_msk(sk)->dccpms_send_ack_vector &&
dccp_ackvec_add(dp->dccps_hc_rx_ackvec, sk, dccp_ackvec_add(dp->dccps_hc_rx_ackvec, sk,
...@@ -585,36 +585,22 @@ int dccp_rcv_state_process(struct sock *sk, struct sk_buff *skb, ...@@ -585,36 +585,22 @@ int dccp_rcv_state_process(struct sock *sk, struct sk_buff *skb,
EXPORT_SYMBOL_GPL(dccp_rcv_state_process); EXPORT_SYMBOL_GPL(dccp_rcv_state_process);
/** /**
* dccp_sample_rtt - Sample RTT from packet exchange * dccp_sample_rtt - Validate and finalise computation of RTT sample
* * @delta: number of microseconds between packet and acknowledgment
* @sk: connected dccp_sock * The routine is kept generic to work in different contexts. It should be
* @t_recv: receive timestamp of packet with timestamp echo * called immediately when the ACK used for the RTT sample arrives.
* @t_hist: packet history timestamp or NULL
*/ */
u32 dccp_sample_rtt(struct sock *sk, ktime_t t_recv, ktime_t *t_hist) u32 dccp_sample_rtt(struct sock *sk, long delta)
{ {
struct dccp_sock *dp = dccp_sk(sk); /* dccpor_elapsed_time is either zeroed out or set and > 0 */
struct dccp_options_received *or = &dp->dccps_options_received; delta -= dccp_sk(sk)->dccps_options_received.dccpor_elapsed_time * 10;
s64 delta;
if (t_hist == NULL) {
if (!or->dccpor_timestamp_echo) {
DCCP_WARN("packet without timestamp echo\n");
return DCCP_SANE_RTT_MAX;
}
ktime_sub_us(t_recv, or->dccpor_timestamp_echo * 10);
delta = ktime_to_us(t_recv);
} else
delta = ktime_us_delta(t_recv, *t_hist);
delta -= or->dccpor_elapsed_time * 10; /* either set or 0 */
if (unlikely(delta <= 0)) { if (unlikely(delta <= 0)) {
DCCP_WARN("unusable RTT sample %ld, using min\n", (long)delta); DCCP_WARN("unusable RTT sample %ld, using min\n", delta);
return DCCP_SANE_RTT_MIN; return DCCP_SANE_RTT_MIN;
} }
if (unlikely(delta - (s64)DCCP_SANE_RTT_MAX > 0)) { if (unlikely(delta > DCCP_SANE_RTT_MAX)) {
DCCP_WARN("RTT sample %ld too large, using max\n", (long)delta); DCCP_WARN("RTT sample %ld too large, using max\n", delta);
return DCCP_SANE_RTT_MAX; return DCCP_SANE_RTT_MAX;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册