webrtc/net/dcsctp/public
Victor Boivie 28d07ddbfd dcsctp: Compute RTO with higher precision
Since the code measuring the RTT has been converted to using TimeDelta
which internally stores the duration in microseconds, from DurationMs
which uses milliseconds, the RTO calculation can use the higher
precision to calculate lower non-zero durations on really fast networks
such within a data center.

Before this CL, which is from the initial drop of dcSCTP, the RTO
calculation was done using the algorithm from the paper "V. Jacobson:
Congestion avoidance and control", but now we're using the original
algorith from https://tools.ietf.org/html/rfc4960#section-6.3.1, which
comes from https://datatracker.ietf.org/doc/html/rfc6298#section-2.

Two issues were found and corrected:
 1. The min RTT variance that is specified in the config file was
    previously incorrectly divided by 8. That was not its intention,
    but we're keeping that behaviour as other clients have actually
    measured a good value to put there. This represents "G" in
    the "basic algorithm" above, and since that is multiplied with K,
    which is four, the default value of 220 wouldn't make sense if it
    wasn't scaled down, as that would make the RTO easily saturate to
    the RTO_max (800ms).
 2. The previous algorithm had large round-off errors (probably because
    the code used milliseconds), which makes fairly big changes to the
    calculated RTO in some situations.

Bug: webrtc:15593
Change-Id: I95a3e137c2bbbe7bf8b99c016381e9e63fd01d87
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/349000
Reviewed-by: Florent Castelli <orphis@webrtc.org>
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Commit-Queue: Victor Boivie <boivie@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#42170}
2024-04-25 07:53:24 +00:00
..
BUILD.gn dcsctp: Add Now() callback 2023-11-10 15:23:13 +00:00
dcsctp_handover_state.cc dcsctp: move HandoverReadinessStatus::ToString definition to build target public:socket 2021-09-20 12:25:15 +00:00
dcsctp_handover_state.h dcsctp: Add handover state for zero checksum 2023-04-24 10:06:40 +00:00
dcsctp_message.h Revert "dcsctp: Use rtc::CopyOnWriteBuffer" 2021-12-02 12:33:46 +00:00
dcsctp_options.h dcsctp: Compute RTO with higher precision 2024-04-25 07:53:24 +00:00
dcsctp_socket.h Add SendMany method to dcsctp socket 2023-12-15 21:35:14 +00:00
dcsctp_socket_factory.cc sctp: Fix data channel closing sequence 2022-05-05 08:44:58 +00:00
dcsctp_socket_factory.h sctp: Fix data channel closing sequence 2022-05-05 08:44:58 +00:00
mock_dcsctp_socket.h Add SendMany method to dcsctp socket 2023-12-15 21:35:14 +00:00
mock_dcsctp_socket_factory.h sctp: Fix data channel closing sequence 2022-05-05 08:44:58 +00:00
mock_dcsctp_socket_test.cc dcsctp: Add mocks 2021-06-29 10:19:11 +00:00
packet_observer.h dcsctp: Add public API 2021-04-08 08:53:44 +00:00
text_pcap_packet_observer.cc dcsctp: Extract logging packet observer as utility 2021-07-10 18:23:06 +00:00
text_pcap_packet_observer.h dcsctp: Extract logging packet observer as utility 2021-07-10 18:23:06 +00:00
timeout.h dcsctp: Add public API 2021-04-08 08:53:44 +00:00
types.h dcsctp: Update zero checksum option to v-06 draft 2024-02-19 10:25:17 +00:00
types_test.cc dcsctp: Add operators on TimeMs and DurationMs 2021-04-14 09:21:15 +00:00