aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/dccp/ccids/ccid3.c17
-rw-r--r--net/dccp/ccids/ccid3.h19
2 files changed, 21 insertions, 15 deletions
diff --git a/net/dccp/ccids/ccid3.c b/net/dccp/ccids/ccid3.c
index b4cc62e2e2bb..eb1bda08eeb2 100644
--- a/net/dccp/ccids/ccid3.c
+++ b/net/dccp/ccids/ccid3.c
@@ -93,19 +93,16 @@ static inline u64 rfc3390_initial_rate(struct sock *sk)
93 return scaled_div(w_init << 6, hctx->rtt); 93 return scaled_div(w_init << 6, hctx->rtt);
94} 94}
95 95
96/* 96/**
97 * Recalculate t_ipi and delta (should be called whenever X changes) 97 * ccid3_update_send_interval - Calculate new t_ipi = s / X_inst
98 * This respects the granularity of X_inst (64 * bytes/second).
98 */ 99 */
99static void ccid3_update_send_interval(struct ccid3_hc_tx_sock *hctx) 100static void ccid3_update_send_interval(struct ccid3_hc_tx_sock *hctx)
100{ 101{
101 /* Calculate new t_ipi = s / X_inst (X_inst is in 64 * bytes/second) */
102 hctx->t_ipi = scaled_div32(((u64)hctx->s) << 6, hctx->x); 102 hctx->t_ipi = scaled_div32(((u64)hctx->s) << 6, hctx->x);
103 103
104 /* Calculate new delta by delta = min(t_ipi / 2, t_gran / 2) */ 104 ccid3_pr_debug("t_ipi=%u, s=%u, X=%u\n", hctx->t_ipi,
105 hctx->delta = min_t(u32, hctx->t_ipi / 2, TFRC_OPSYS_HALF_TIME_GRAN); 105 hctx->s, (unsigned)(hctx->x >> 6));
106
107 ccid3_pr_debug("t_ipi=%u, delta=%u, s=%u, X=%u\n", hctx->t_ipi,
108 hctx->delta, hctx->s, (unsigned)(hctx->x >> 6));
109} 106}
110 107
111static u32 ccid3_hc_tx_idle_rtt(struct ccid3_hc_tx_sock *hctx, ktime_t now) 108static u32 ccid3_hc_tx_idle_rtt(struct ccid3_hc_tx_sock *hctx, ktime_t now)
@@ -340,8 +337,8 @@ static int ccid3_hc_tx_send_packet(struct sock *sk, struct sk_buff *skb)
340 * else 337 * else
341 * // send the packet in (t_nom - t_now) milliseconds. 338 * // send the packet in (t_nom - t_now) milliseconds.
342 */ 339 */
343 if (delay - (s64)hctx->delta >= 1000) 340 if (delay >= TFRC_T_DELTA)
344 return (u32)delay / 1000L; 341 return (u32)delay / USEC_PER_MSEC;
345 342
346 ccid3_hc_tx_update_win_count(hctx, now); 343 ccid3_hc_tx_update_win_count(hctx, now);
347 break; 344 break;
diff --git a/net/dccp/ccids/ccid3.h b/net/dccp/ccids/ccid3.h
index 0cfcfff8f5fb..92a5e1688a07 100644
--- a/net/dccp/ccids/ccid3.h
+++ b/net/dccp/ccids/ccid3.h
@@ -47,12 +47,23 @@
47/* Two seconds as per RFC 3448 4.2 */ 47/* Two seconds as per RFC 3448 4.2 */
48#define TFRC_INITIAL_TIMEOUT (2 * USEC_PER_SEC) 48#define TFRC_INITIAL_TIMEOUT (2 * USEC_PER_SEC)
49 49
50/* In usecs - half the scheduling granularity as per RFC3448 4.6 */
51#define TFRC_OPSYS_HALF_TIME_GRAN (USEC_PER_SEC / (2 * HZ))
52
53/* Parameter t_mbi from [RFC 3448, 4.3]: backoff interval in seconds */ 50/* Parameter t_mbi from [RFC 3448, 4.3]: backoff interval in seconds */
54#define TFRC_T_MBI 64 51#define TFRC_T_MBI 64
55 52
53/*
54 * The t_delta parameter (RFC 3448, 4.6): delays of less than %USEC_PER_MSEC are
55 * rounded down to 0, since sk_reset_timer() here uses millisecond granularity.
56 * Hence we can use a constant t_delta = %USEC_PER_MSEC when HZ >= 500. A coarse
57 * resolution of HZ < 500 means that the error is below one timer tick (t_gran)
58 * when using the constant t_delta = t_gran / 2 = %USEC_PER_SEC / (2 * HZ).
59 */
60#if (HZ >= 500)
61# define TFRC_T_DELTA USEC_PER_MSEC
62#else
63# define TFRC_T_DELTA (USEC_PER_SEC / (2 * HZ))
64#warning Coarse CONFIG_HZ resolution -- higher value recommended for TFRC.
65#endif
66
56enum ccid3_options { 67enum ccid3_options {
57 TFRC_OPT_LOSS_EVENT_RATE = 192, 68 TFRC_OPT_LOSS_EVENT_RATE = 192,
58 TFRC_OPT_LOSS_INTERVALS = 193, 69 TFRC_OPT_LOSS_INTERVALS = 193,
@@ -92,7 +103,6 @@ enum ccid3_hc_tx_states {
92 * @no_feedback_timer - Handle to no feedback timer 103 * @no_feedback_timer - Handle to no feedback timer
93 * @t_ld - Time last doubled during slow start 104 * @t_ld - Time last doubled during slow start
94 * @t_nom - Nominal send time of next packet 105 * @t_nom - Nominal send time of next packet
95 * @delta - Send timer delta (RFC 3448, 4.6) in usecs
96 * @hist - Packet history 106 * @hist - Packet history
97 * @options_received - Parsed set of retrieved options 107 * @options_received - Parsed set of retrieved options
98 */ 108 */
@@ -111,7 +121,6 @@ struct ccid3_hc_tx_sock {
111 struct timer_list no_feedback_timer; 121 struct timer_list no_feedback_timer;
112 ktime_t t_ld; 122 ktime_t t_ld;
113 ktime_t t_nom; 123 ktime_t t_nom;
114 u32 delta;
115 struct tfrc_tx_hist_entry *hist; 124 struct tfrc_tx_hist_entry *hist;
116 struct ccid3_options_received options_received; 125 struct ccid3_options_received options_received;
117}; 126};