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

1 // SPDX-License-Identifier: GPL-2.0-only
7 * Lison-Xu, Kahaled Harfoush, and Injong Rhee.
21 #define BICTCP_BETA_SCALE 1024 /* Scale factor beta calculation
22 * max_cwnd = snd_cwnd * beta
29 static int fast_convergence = 1;
30 static int max_increment = 16;
31 static int low_window = 14;
32 static int beta = 819; /* = 819/1024 (BICTCP_BETA_SCALE) */ variable
33 static int initial_ssthresh;
34 static int smooth_part = 20;
42 module_param(beta, int, 0644);
43 MODULE_PARM_DESC(beta, "beta for multiplicative increase");
47 MODULE_PARM_DESC(smooth_part, "log(B/(B*Smin))/log(B/(B-1))+B, # of RTT from Wmax-B to Wmax");
60 static inline void bictcp_reset(struct bictcp *ca) in bictcp_reset()
62 ca->cnt = 0; in bictcp_reset()
63 ca->last_max_cwnd = 0; in bictcp_reset()
64 ca->last_cwnd = 0; in bictcp_reset()
65 ca->last_time = 0; in bictcp_reset()
66 ca->epoch_start = 0; in bictcp_reset()
67 ca->delayed_ack = 2 << ACK_RATIO_SHIFT; in bictcp_reset()
70 static void bictcp_init(struct sock *sk) in bictcp_init()
77 tcp_sk(sk)->snd_ssthresh = initial_ssthresh; in bictcp_init()
83 static inline void bictcp_update(struct bictcp *ca, u32 cwnd) in bictcp_update()
85 if (ca->last_cwnd == cwnd && in bictcp_update()
86 (s32)(tcp_jiffies32 - ca->last_time) <= HZ / 32) in bictcp_update()
89 ca->last_cwnd = cwnd; in bictcp_update()
90 ca->last_time = tcp_jiffies32; in bictcp_update()
92 if (ca->epoch_start == 0) /* record the beginning of an epoch */ in bictcp_update()
93 ca->epoch_start = tcp_jiffies32; in bictcp_update()
97 ca->cnt = cwnd; in bictcp_update()
102 if (cwnd < ca->last_max_cwnd) { in bictcp_update()
103 __u32 dist = (ca->last_max_cwnd - cwnd) in bictcp_update()
108 ca->cnt = cwnd / max_increment; in bictcp_update()
111 ca->cnt = (cwnd * smooth_part) / BICTCP_B; in bictcp_update()
114 ca->cnt = cwnd / dist; in bictcp_update()
117 if (cwnd < ca->last_max_cwnd + BICTCP_B) in bictcp_update()
119 ca->cnt = (cwnd * smooth_part) / BICTCP_B; in bictcp_update()
120 else if (cwnd < ca->last_max_cwnd + max_increment*(BICTCP_B-1)) in bictcp_update()
122 ca->cnt = (cwnd * (BICTCP_B-1)) in bictcp_update()
123 / (cwnd - ca->last_max_cwnd); in bictcp_update()
126 ca->cnt = cwnd / max_increment; in bictcp_update()
130 if (ca->last_max_cwnd == 0) { in bictcp_update()
131 if (ca->cnt > 20) /* increase cwnd 5% per RTT */ in bictcp_update()
132 ca->cnt = 20; in bictcp_update()
135 ca->cnt = (ca->cnt << ACK_RATIO_SHIFT) / ca->delayed_ack; in bictcp_update()
136 if (ca->cnt == 0) /* cannot be zero */ in bictcp_update()
137 ca->cnt = 1; in bictcp_update()
140 static void bictcp_cong_avoid(struct sock *sk, u32 ack, u32 acked) in bictcp_cong_avoid()
154 tcp_cong_avoid_ai(tp, ca->cnt, acked); in bictcp_cong_avoid()
161 static u32 bictcp_recalc_ssthresh(struct sock *sk) in bictcp_recalc_ssthresh()
166 ca->epoch_start = 0; /* end of epoch */ in bictcp_recalc_ssthresh()
169 if (tcp_snd_cwnd(tp) < ca->last_max_cwnd && fast_convergence) in bictcp_recalc_ssthresh()
170 ca->last_max_cwnd = (tcp_snd_cwnd(tp) * (BICTCP_BETA_SCALE + beta)) in bictcp_recalc_ssthresh()
173 ca->last_max_cwnd = tcp_snd_cwnd(tp); in bictcp_recalc_ssthresh()
178 return max((tcp_snd_cwnd(tp) * beta) / BICTCP_BETA_SCALE, 2U); in bictcp_recalc_ssthresh()
181 static void bictcp_state(struct sock *sk, u8 new_state) in bictcp_state()
190 static void bictcp_acked(struct sock *sk, const struct ack_sample *sample) in bictcp_acked()
194 if (icsk->icsk_ca_state == TCP_CA_Open) { in bictcp_acked()
197 ca->delayed_ack += sample->pkts_acked - in bictcp_acked()
198 (ca->delayed_ack >> ACK_RATIO_SHIFT); in bictcp_acked()
202 static struct tcp_congestion_ops bictcp __read_mostly = {
213 static int __init bictcp_register(void) in bictcp_register()
219 static void __exit bictcp_unregister(void) in bictcp_unregister()