bpf: Support TCP_RTO_MAX_MS for bpf_setsockopt
authorJason Xing <kerneljasonxing@gmail.com>
Wed, 19 Feb 2025 08:13:31 +0000 (16:13 +0800)
committerMartin KaFai Lau <martin.lau@kernel.org>
Wed, 19 Feb 2025 20:30:51 +0000 (12:30 -0800)
commit6810c771d3165e6320f991220f0c92519e6bace7
tree6a3e17bcef9cd8034476e9b5ea08a096a0c05586
parent7a7e0197133d18cfd9931e7d3a842d0f5730223f
bpf: Support TCP_RTO_MAX_MS for bpf_setsockopt

Some applications don't want to wait for too long because the
time of retransmission increases exponentially and can reach more
than 10 seconds, for example. Eric implements the core logic
on supporting rto max feature in the stack previously. Based on that,
we can support it for BPF use.

This patch reuses the same logic of TCP_RTO_MAX_MS in do_tcp_setsockopt()
and do_tcp_getsockopt(). BPF program can call bpf_{set/get}sockopt()
to set/get the maximum value of RTO.

Signed-off-by: Jason Xing <kerneljasonxing@gmail.com>
Signed-off-by: Martin KaFai Lau <martin.lau@kernel.org>
Reviewed-by: Kuniyuki Iwashima <kuniyu@amazon.com>
Link: https://patch.msgid.link/20250219081333.56378-2-kerneljasonxing@gmail.com
net/core/filter.c