diff options
author | Yu Watanabe <watanabe.yu+github@gmail.com> | 2022-11-17 10:27:57 +0100 |
---|---|---|
committer | Yu Watanabe <watanabe.yu+github@gmail.com> | 2022-11-18 23:08:22 +0100 |
commit | 8c9206363370ae99c880ab17693881655574089a (patch) | |
tree | 153c8054a0e6e3a5de7e35fd405d0cd7e6d605b0 /src/network/tc | |
parent | network: tc-cake: add support to specify RTT (diff) | |
download | systemd-8c9206363370ae99c880ab17693881655574089a.tar.xz systemd-8c9206363370ae99c880ab17693881655574089a.zip |
network: tc-cake: add support to specify ACK filter
Diffstat (limited to 'src/network/tc')
-rw-r--r-- | src/network/tc/cake.c | 67 | ||||
-rw-r--r-- | src/network/tc/cake.h | 10 |
2 files changed, 77 insertions, 0 deletions
diff --git a/src/network/tc/cake.c b/src/network/tc/cake.c index c056ec9e04..a22a11cce3 100644 --- a/src/network/tc/cake.c +++ b/src/network/tc/cake.c @@ -27,6 +27,7 @@ static int cake_init(QDisc *qdisc) { c->preset = _CAKE_PRESET_INVALID; c->wash = -1; c->split_gso = -1; + c->ack_filter = _CAKE_ACK_FILTER_INVALID; return 0; } @@ -124,6 +125,12 @@ static int cake_fill_message(Link *link, QDisc *qdisc, sd_netlink_message *req) return r; } + if (c->ack_filter >= 0) { + r = sd_netlink_message_append_u32(req, TCA_CAKE_ACK_FILTER, c->ack_filter); + if (r < 0) + return r; + } + r = sd_netlink_message_close_container(req); if (r < 0) return r; @@ -669,6 +676,66 @@ int config_parse_cake_rtt( return 0; } +static const char * const cake_ack_filter_table[_CAKE_ACK_FILTER_MAX] = { + [CAKE_ACK_FILTER_NO] = "no", + [CAKE_ACK_FILTER_YES] = "yes", + [CAKE_ACK_FILTER_AGGRESSIVE] = "aggressive", +}; + +DEFINE_PRIVATE_STRING_TABLE_LOOKUP_FROM_STRING_WITH_BOOLEAN(cake_ack_filter, CakeAckFilter, CAKE_ACK_FILTER_YES); + +int config_parse_cake_ack_filter( + const char *unit, + const char *filename, + unsigned line, + const char *section, + unsigned section_line, + const char *lvalue, + int ltype, + const char *rvalue, + void *data, + void *userdata) { + + _cleanup_(qdisc_free_or_set_invalidp) QDisc *qdisc = NULL; + CommonApplicationsKeptEnhanced *c; + CakeAckFilter ack_filter; + Network *network = ASSERT_PTR(data); + int r; + + assert(filename); + assert(lvalue); + assert(rvalue); + + r = qdisc_new_static(QDISC_KIND_CAKE, network, filename, section_line, &qdisc); + if (r == -ENOMEM) + return log_oom(); + if (r < 0) { + log_syntax(unit, LOG_WARNING, filename, line, r, + "More than one kind of queueing discipline, ignoring assignment: %m"); + return 0; + } + + c = CAKE(qdisc); + + if (isempty(rvalue)) { + c->ack_filter = _CAKE_ACK_FILTER_INVALID; + TAKE_PTR(qdisc); + return 0; + } + + ack_filter = cake_ack_filter_from_string(rvalue); + if (ack_filter < 0) { + log_syntax(unit, LOG_WARNING, filename, line, ack_filter, + "Failed to parse '%s=', ignoring assignment: %s", + lvalue, rvalue); + return 0; + } + + c->ack_filter = ack_filter; + TAKE_PTR(qdisc); + return 0; +} + const QDiscVTable cake_vtable = { .object_size = sizeof(CommonApplicationsKeptEnhanced), .tca_kind = "cake", diff --git a/src/network/tc/cake.h b/src/network/tc/cake.h index 418d9744a3..5ca6dc6470 100644 --- a/src/network/tc/cake.h +++ b/src/network/tc/cake.h @@ -38,6 +38,14 @@ typedef enum CakePriorityQueueingPreset { _CAKE_PRESET_INVALID = -EINVAL, } CakePriorityQueueingPreset; +typedef enum CakeAckFilter { + CAKE_ACK_FILTER_NO = CAKE_ACK_NONE, + CAKE_ACK_FILTER_YES = CAKE_ACK_FILTER, + CAKE_ACK_FILTER_AGGRESSIVE = CAKE_ACK_AGGRESSIVE, + _CAKE_ACK_FILTER_MAX, + _CAKE_ACK_FILTER_INVALID = -EINVAL, +} CakeAckFilter; + typedef struct CommonApplicationsKeptEnhanced { QDisc meta; @@ -64,6 +72,7 @@ typedef struct CommonApplicationsKeptEnhanced { int wash; int split_gso; usec_t rtt; + CakeAckFilter ack_filter; } CommonApplicationsKeptEnhanced; DEFINE_QDISC_CAST(CAKE, CommonApplicationsKeptEnhanced); @@ -78,3 +87,4 @@ CONFIG_PARSER_PROTOTYPE(config_parse_cake_flow_isolation_mode); CONFIG_PARSER_PROTOTYPE(config_parse_cake_priority_queueing_preset); CONFIG_PARSER_PROTOTYPE(config_parse_cake_fwmark); CONFIG_PARSER_PROTOTYPE(config_parse_cake_rtt); +CONFIG_PARSER_PROTOTYPE(config_parse_cake_ack_filter); |