MINOR: quic/pacing: implement quic_pacer engine

Extend quic_pacer engine to support pacing emission. Several functions
are defined.
* quic_pacing_sent_done() to notify engine about an emission of one or
  several datagrams
* quic_pacing_expired() to check if emission should be delayed or can be
  conducted immediately
This commit is contained in:
Amaury Denoyelle 2024-11-18 14:57:39 +01:00
parent 3e11492c99
commit ab82fab442
6 changed files with 33 additions and 1 deletions

View File

@ -123,6 +123,9 @@ struct quic_cc_algo {
void (*state_trace)(struct buffer *buf, const struct quic_cc *cc);
void (*state_cli)(struct buffer *buf, const struct quic_cc_path *path);
void (*hystart_start_round)(struct quic_cc *cc, uint64_t pn);
/* Defined only if pacing is used. */
uint (*pacing_rate)(const struct quic_cc *cc);
};
#endif /* USE_QUIC */

View File

@ -37,6 +37,9 @@ void quic_cc_init(struct quic_cc *cc, struct quic_cc_algo *algo, struct quic_con
void quic_cc_event(struct quic_cc *cc, struct quic_cc_event *ev);
void quic_cc_state_trace(struct buffer *buf, const struct quic_cc *cc);
/* Pacing callbacks */
uint quic_cc_default_pacing_rate(const struct quic_cc *cc);
static inline const char *quic_cc_state_str(enum quic_cc_algo_state_type state)
{
switch (state) {
@ -107,6 +110,5 @@ static inline size_t quic_cc_path_prep_data(struct quic_cc_path *path)
return path->cwnd - path->prep_in_flight;
}
#endif /* USE_QUIC */
#endif /* _PROTO_QUIC_CC_H */

View File

@ -6,6 +6,7 @@
struct quic_pacer {
const struct quic_cc *cc; /* Congestion controler algo used for this connection */
ullong next; /* Nanosecond timestamp at which the next emission should be conducted */
};
#endif /* _HAPROXY_QUIC_PACING_T_H */

View File

@ -10,6 +10,11 @@ static inline void quic_pacing_init(struct quic_pacer *pacer,
const struct quic_cc *cc)
{
pacer->cc = cc;
pacer->next = 0;
}
int quic_pacing_expired(const struct quic_pacer *pacer);
void quic_pacing_sent_done(struct quic_pacer *pacer);
#endif /* _HAPROXY_QUIC_PACING_H */

View File

@ -47,3 +47,10 @@ void quic_cc_state_trace(struct buffer *buf, const struct quic_cc *cc)
{
cc->algo->state_trace(buf, cc);
}
/* Return rate in nanoseconds between each datagram emission for a smooth pacing. */
uint quic_cc_default_pacing_rate(const struct quic_cc *cc)
{
struct quic_cc_path *path = container_of(cc, struct quic_cc_path, cc);
return path->loss.srtt * 1000000 / (path->cwnd / path->mtu + 1);
}

View File

@ -1 +1,15 @@
#include <haproxy/quic_pacing.h>
#include <haproxy/quic_tx.h>
/* Returns true if <pacer> timer is expired and emission can be retried. */
int quic_pacing_expired(const struct quic_pacer *pacer)
{
return !pacer->next || pacer->next <= now_mono_time();
}
/* Notify <pacer> about an emission of one datagram. */
void quic_pacing_sent_done(struct quic_pacer *pacer)
{
pacer->next = now_mono_time() + pacer->cc->algo->pacing_rate(pacer->cc);
}