Lines Matching +full:static +full:- +full:beta

1 // SPDX-License-Identifier: GPL-2.0-only
8 * "CUBIC: A New TCP-Friendly High-Speed TCP Variant"
34 #define BICTCP_BETA_SCALE 1024 /* Scale factor beta calculation
35 * max_cwnd = snd_cwnd * beta
49 static int fast_convergence __read_mostly = 1;
50 static int beta __read_mostly = 717; /* = 717/1024 (BICTCP_BETA_SCALE) */
51 static int initial_ssthresh __read_mostly;
52 static int bic_scale __read_mostly = 41;
53 static int tcp_friendliness __read_mostly = 1;
55 static int hystart __read_mostly = 1;
56 static int hystart_detect __read_mostly = HYSTART_ACK_TRAIN | HYSTART_DELAY;
57 static int hystart_low_window __read_mostly = 16;
58 static int hystart_ack_delta_us __read_mostly = 2000;
60 static u32 cube_rtt_scale __read_mostly;
61 static u32 beta_scale __read_mostly;
62 static u64 cube_factor __read_mostly;
64 /* Note parameters that are used for precomputing scale factors are read-only */
67 module_param(beta, int, 0644);
68 MODULE_PARM_DESC(beta, "beta for multiplicative increase");
79 " 1: packet-train 2: delay 3: both packet-train and delay");
107 static inline void bictcp_reset(struct bictcp *ca) in bictcp_reset()
110 ca->found = 0; in bictcp_reset()
113 static inline u32 bictcp_clock_us(const struct sock *sk) in bictcp_clock_us()
115 return tcp_sk(sk)->tcp_mstamp; in bictcp_clock_us()
118 static inline void bictcp_hystart_reset(struct sock *sk) in bictcp_hystart_reset()
123 ca->round_start = ca->last_ack = bictcp_clock_us(sk); in bictcp_hystart_reset()
124 ca->end_seq = tp->snd_nxt; in bictcp_hystart_reset()
125 ca->curr_rtt = ~0U; in bictcp_hystart_reset()
126 ca->sample_cnt = 0; in bictcp_hystart_reset()
129 __bpf_kfunc static void cubictcp_init(struct sock *sk) in cubictcp_init()
139 tcp_sk(sk)->snd_ssthresh = initial_ssthresh; in cubictcp_init()
142 __bpf_kfunc static void cubictcp_cwnd_event(struct sock *sk, enum tcp_ca_event event) in cubictcp_cwnd_event()
149 delta = now - tcp_sk(sk)->lsndtime; in cubictcp_cwnd_event()
154 if (ca->epoch_start && delta > 0) { in cubictcp_cwnd_event()
155 ca->epoch_start += delta; in cubictcp_cwnd_event()
156 if (after(ca->epoch_start, now)) in cubictcp_cwnd_event()
157 ca->epoch_start = now; in cubictcp_cwnd_event()
164 * Newton-Raphson iteration.
167 static u32 cubic_root(u64 a) in cubic_root()
172 * Precomputed then refined by hand - Willy Tarreau in cubic_root()
175 * v = cbrt(x << 18) - 1 in cubic_root()
178 static const u8 v[] = { in cubic_root()
195 b = ((b * 84) >> 8) - 1; in cubic_root()
201 * Newton-Raphson iteration in cubic_root()
206 x = (2 * x + (u32)div64_u64(a, (u64)x * (u64)(x - 1))); in cubic_root()
214 static inline void bictcp_update(struct bictcp *ca, u32 cwnd, u32 acked) in bictcp_update()
219 ca->ack_cnt += acked; /* count the number of ACKed packets */ in bictcp_update()
221 if (ca->last_cwnd == cwnd && in bictcp_update()
222 (s32)(tcp_jiffies32 - ca->last_time) <= HZ / 32) in bictcp_update()
225 /* The CUBIC function can update ca->cnt at most once per jiffy. in bictcp_update()
226 * On all cwnd reduction events, ca->epoch_start is set to 0, in bictcp_update()
227 * which will force a recalculation of ca->cnt. in bictcp_update()
229 if (ca->epoch_start && tcp_jiffies32 == ca->last_time) in bictcp_update()
232 ca->last_cwnd = cwnd; in bictcp_update()
233 ca->last_time = tcp_jiffies32; in bictcp_update()
235 if (ca->epoch_start == 0) { in bictcp_update()
236 ca->epoch_start = tcp_jiffies32; /* record beginning */ in bictcp_update()
237 ca->ack_cnt = acked; /* start counting */ in bictcp_update()
238 ca->tcp_cwnd = cwnd; /* syn with cubic */ in bictcp_update()
240 if (ca->last_max_cwnd <= cwnd) { in bictcp_update()
241 ca->bic_K = 0; in bictcp_update()
242 ca->bic_origin_point = cwnd; in bictcp_update()
245 * (wmax-cwnd) * (srtt>>3 / HZ) / c * 2^(3*bictcp_HZ) in bictcp_update()
247 ca->bic_K = cubic_root(cube_factor in bictcp_update()
248 * (ca->last_max_cwnd - cwnd)); in bictcp_update()
249 ca->bic_origin_point = ca->last_max_cwnd; in bictcp_update()
253 /* cubic function - calc*/ in bictcp_update()
260 * time = (t - K) / 2^bictcp_HZ in bictcp_update()
267 t = (s32)(tcp_jiffies32 - ca->epoch_start); in bictcp_update()
268 t += usecs_to_jiffies(ca->delay_min); in bictcp_update()
273 if (t < ca->bic_K) /* t - K */ in bictcp_update()
274 offs = ca->bic_K - t; in bictcp_update()
276 offs = t - ca->bic_K; in bictcp_update()
278 /* c/rtt * (t-K)^3 */ in bictcp_update()
280 if (t < ca->bic_K) /* below origin*/ in bictcp_update()
281 bic_target = ca->bic_origin_point - delta; in bictcp_update()
283 bic_target = ca->bic_origin_point + delta; in bictcp_update()
285 /* cubic function - calc bictcp_cnt*/ in bictcp_update()
287 ca->cnt = cwnd / (bic_target - cwnd); in bictcp_update()
289 ca->cnt = 100 * cwnd; /* very small increment*/ in bictcp_update()
296 if (ca->last_max_cwnd == 0 && ca->cnt > 20) in bictcp_update()
297 ca->cnt = 20; /* increase cwnd 5% per RTT */ in bictcp_update()
305 while (ca->ack_cnt > delta) { /* update tcp cwnd */ in bictcp_update()
306 ca->ack_cnt -= delta; in bictcp_update()
307 ca->tcp_cwnd++; in bictcp_update()
310 if (ca->tcp_cwnd > cwnd) { /* if bic is slower than tcp */ in bictcp_update()
311 delta = ca->tcp_cwnd - cwnd; in bictcp_update()
313 if (ca->cnt > max_cnt) in bictcp_update()
314 ca->cnt = max_cnt; in bictcp_update()
321 ca->cnt = max(ca->cnt, 2U); in bictcp_update()
324 __bpf_kfunc static void cubictcp_cong_avoid(struct sock *sk, u32 ack, u32 acked) in cubictcp_cong_avoid()
338 tcp_cong_avoid_ai(tp, ca->cnt, acked); in cubictcp_cong_avoid()
341 __bpf_kfunc static u32 cubictcp_recalc_ssthresh(struct sock *sk) in cubictcp_recalc_ssthresh()
346 ca->epoch_start = 0; /* end of epoch */ in cubictcp_recalc_ssthresh()
349 if (tcp_snd_cwnd(tp) < ca->last_max_cwnd && fast_convergence) in cubictcp_recalc_ssthresh()
350 ca->last_max_cwnd = (tcp_snd_cwnd(tp) * (BICTCP_BETA_SCALE + beta)) in cubictcp_recalc_ssthresh()
353 ca->last_max_cwnd = tcp_snd_cwnd(tp); in cubictcp_recalc_ssthresh()
355 return max((tcp_snd_cwnd(tp) * beta) / BICTCP_BETA_SCALE, 2U); in cubictcp_recalc_ssthresh()
358 __bpf_kfunc static void cubictcp_state(struct sock *sk, u8 new_state) in cubictcp_state()
368 * slow start we begin with small TSO packets and ca->delay_min would
375 static u32 hystart_ack_delay(const struct sock *sk) in hystart_ack_delay()
379 rate = READ_ONCE(sk->sk_pacing_rate); in hystart_ack_delay()
383 div64_ul((u64)sk->sk_gso_max_size * 4 * USEC_PER_SEC, rate)); in hystart_ack_delay()
386 static void hystart_update(struct sock *sk, u32 delay) in hystart_update()
392 if (after(tp->snd_una, ca->end_seq)) in hystart_update()
398 /* first detection parameter - ack-train detection */ in hystart_update()
399 if ((s32)(now - ca->last_ack) <= hystart_ack_delta_us) { in hystart_update()
400 ca->last_ack = now; in hystart_update()
402 threshold = ca->delay_min + hystart_ack_delay(sk); in hystart_update()
405 * ca->delay_min/2. in hystart_update()
409 if (sk->sk_pacing_status == SK_PACING_NONE) in hystart_update()
412 if ((s32)(now - ca->round_start) > threshold) { in hystart_update()
413 ca->found = 1; in hystart_update()
415 now - ca->round_start, threshold, in hystart_update()
416 ca->delay_min, hystart_ack_delay(sk), tcp_snd_cwnd(tp)); in hystart_update()
422 tp->snd_ssthresh = tcp_snd_cwnd(tp); in hystart_update()
429 if (ca->curr_rtt > delay) in hystart_update()
430 ca->curr_rtt = delay; in hystart_update()
431 if (ca->sample_cnt < HYSTART_MIN_SAMPLES) { in hystart_update()
432 ca->sample_cnt++; in hystart_update()
434 if (ca->curr_rtt > ca->delay_min + in hystart_update()
435 HYSTART_DELAY_THRESH(ca->delay_min >> 3)) { in hystart_update()
436 ca->found = 1; in hystart_update()
442 tp->snd_ssthresh = tcp_snd_cwnd(tp); in hystart_update()
448 __bpf_kfunc static void cubictcp_acked(struct sock *sk, const struct ack_sample *sample) in cubictcp_acked()
455 if (sample->rtt_us < 0) in cubictcp_acked()
459 if (ca->epoch_start && (s32)(tcp_jiffies32 - ca->epoch_start) < HZ) in cubictcp_acked()
462 delay = sample->rtt_us; in cubictcp_acked()
467 if (ca->delay_min == 0 || ca->delay_min > delay) in cubictcp_acked()
468 ca->delay_min = delay; in cubictcp_acked()
471 if (!ca->found && tcp_in_slow_start(tp) && hystart && in cubictcp_acked()
476 static struct tcp_congestion_ops cubictcp __read_mostly = {
497 static const struct btf_kfunc_id_set tcp_cubic_kfunc_set = {
502 static int __init cubictcp_register(void) in cubictcp_register()
508 /* Precompute a bunch of the scaling factors that are used per-packet in cubictcp_register()
512 beta_scale = 8*(BICTCP_BETA_SCALE+beta) / 3 in cubictcp_register()
513 / (BICTCP_BETA_SCALE - beta); in cubictcp_register()
517 /* calculate the "K" for (wmax-cwnd) = c/rtt * K^3 in cubictcp_register()
518 * so K = cubic_root( (wmax-cwnd)*rtt/c ) in cubictcp_register()
527 * HZ < 1,000,00 (corresponding to 10 nano-second) in cubictcp_register()
542 static void __exit cubictcp_unregister(void) in cubictcp_unregister()