aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/dccp/ccids/ccid3.c38
1 files changed, 17 insertions, 21 deletions
diff --git a/net/dccp/ccids/ccid3.c b/net/dccp/ccids/ccid3.c
index 9297fca78683..4342caf53251 100644
--- a/net/dccp/ccids/ccid3.c
+++ b/net/dccp/ccids/ccid3.c
@@ -100,19 +100,24 @@ static void ccid3_hc_tx_set_state(struct sock *sk,
100 hctx->ccid3hctx_state = state; 100 hctx->ccid3hctx_state = state;
101} 101}
102 102
103/* Calculate new t_ipi (inter packet interval) by t_ipi = s / X_inst */ 103/*
104static inline void ccid3_calc_new_t_ipi(struct ccid3_hc_tx_sock *hctx) 104 * Recalculate scheduled nominal send time t_nom, inter-packet interval
105 * t_ipi, and delta value. Should be called after each change to X.
106 */
107static inline void ccid3_update_send_time(struct ccid3_hc_tx_sock *hctx)
105{ 108{
109 timeval_sub_usecs(&hctx->ccid3hctx_t_nom, hctx->ccid3hctx_t_ipi);
110
111 /* Calculate new t_ipi (inter packet interval) by t_ipi = s / X_inst */
106 hctx->ccid3hctx_t_ipi = usecs_div(hctx->ccid3hctx_s, hctx->ccid3hctx_x); 112 hctx->ccid3hctx_t_ipi = usecs_div(hctx->ccid3hctx_s, hctx->ccid3hctx_x);
107}
108 113
109/* Calculate new delta by delta = min(t_ipi / 2, t_gran / 2) */ 114 /* Update nominal send time with regard to the new t_ipi */
110static inline void ccid3_calc_new_delta(struct ccid3_hc_tx_sock *hctx) 115 timeval_add_usecs(&hctx->ccid3hctx_t_nom, hctx->ccid3hctx_t_ipi);
111{ 116
117 /* Calculate new delta by delta = min(t_ipi / 2, t_gran / 2) */
112 hctx->ccid3hctx_delta = min_t(u32, hctx->ccid3hctx_t_ipi / 2, 118 hctx->ccid3hctx_delta = min_t(u32, hctx->ccid3hctx_t_ipi / 2,
113 TFRC_OPSYS_HALF_TIME_GRAN); 119 TFRC_OPSYS_HALF_TIME_GRAN);
114} 120}
115
116/* 121/*
117 * Update X by 122 * Update X by
118 * If (p > 0) 123 * If (p > 0)
@@ -126,6 +131,7 @@ static inline void ccid3_calc_new_delta(struct ccid3_hc_tx_sock *hctx)
126static void ccid3_hc_tx_update_x(struct sock *sk) 131static void ccid3_hc_tx_update_x(struct sock *sk)
127{ 132{
128 struct ccid3_hc_tx_sock *hctx = ccid3_hc_tx_sk(sk); 133 struct ccid3_hc_tx_sock *hctx = ccid3_hc_tx_sk(sk);
134 const __u32 old_x = hctx->ccid3hctx_x;
129 135
130 /* To avoid large error in calcX */ 136 /* To avoid large error in calcX */
131 if (hctx->ccid3hctx_p >= TFRC_SMALLEST_P) { 137 if (hctx->ccid3hctx_p >= TFRC_SMALLEST_P) {
@@ -149,6 +155,8 @@ static void ccid3_hc_tx_update_x(struct sock *sk)
149 hctx->ccid3hctx_t_ld = now; 155 hctx->ccid3hctx_t_ld = now;
150 } 156 }
151 } 157 }
158 if (hctx->ccid3hctx_x != old_x)
159 ccid3_update_send_time(hctx);
152} 160}
153 161
154static void ccid3_hc_tx_no_feedback_timer(unsigned long data) 162static void ccid3_hc_tx_no_feedback_timer(unsigned long data)
@@ -184,11 +192,7 @@ static void ccid3_hc_tx_no_feedback_timer(unsigned long data)
184 /* The value of R is still undefined and so we can not recompute 192 /* The value of R is still undefined and so we can not recompute
185 * the timout value. Keep initial value as per [RFC 4342, 5]. */ 193 * the timout value. Keep initial value as per [RFC 4342, 5]. */
186 next_tmout = TFRC_INITIAL_TIMEOUT; 194 next_tmout = TFRC_INITIAL_TIMEOUT;
187 /* 195 ccid3_update_send_time(hctx);
188 * FIXME - not sure above calculation is correct. See section
189 * 5 of CCID3 11 should adjust tx_t_ipi and double that to
190 * achieve it really
191 */
192 break; 196 break;
193 case TFRC_SSTATE_FBACK: 197 case TFRC_SSTATE_FBACK:
194 /* 198 /*
@@ -479,17 +483,9 @@ static void ccid3_hc_tx_packet_recv(struct sock *sk, struct sk_buff *skb)
479 /* unschedule no feedback timer */ 483 /* unschedule no feedback timer */
480 sk_stop_timer(sk, &hctx->ccid3hctx_no_feedback_timer); 484 sk_stop_timer(sk, &hctx->ccid3hctx_no_feedback_timer);
481 485
482 /* Update sending rate */ 486 /* Update sending rate (and likely t_ipi, t_nom, and delta) */
483 ccid3_hc_tx_update_x(sk); 487 ccid3_hc_tx_update_x(sk);
484 488
485 /* Update next send time */
486 timeval_sub_usecs(&hctx->ccid3hctx_t_nom,
487 hctx->ccid3hctx_t_ipi);
488 ccid3_calc_new_t_ipi(hctx);
489 timeval_add_usecs(&hctx->ccid3hctx_t_nom,
490 hctx->ccid3hctx_t_ipi);
491 ccid3_calc_new_delta(hctx);
492
493 /* remove all packets older than the one acked from history */ 489 /* remove all packets older than the one acked from history */
494 dccp_tx_hist_purge_older(ccid3_tx_hist, 490 dccp_tx_hist_purge_older(ccid3_tx_hist,
495 &hctx->ccid3hctx_hist, packet); 491 &hctx->ccid3hctx_hist, packet);