blob: b4b0fd7fefff3dd767ca9497ce57cecf904772a3 [file] [log] [blame]
* Copyright (c) 2021 The WebRTC project authors. All Rights Reserved.
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
#include <cstdint>
#include <functional>
#include "net/dcsctp/public/dcsctp_options.h"
namespace dcsctp {
// Manages updating of the Retransmission Timeout (RTO) SCTP variable, which is
// used directly as the base timeout for T3-RTX and for other timers, such as
// delayed ack.
// When a round-trip-time (RTT) is calculated (outside this class), `Observe`
// is called, which calculates the retransmission timeout (RTO) value. The RTO
// value will become larger if the RTT is high and/or the RTT values are varying
// a lot, which is an indicator of a bad connection.
class RetransmissionTimeout {
static constexpr int kRttShift = 3;
static constexpr int kRttVarShift = 2;
explicit RetransmissionTimeout(const DcSctpOptions& options);
// To be called when a RTT has been measured, to update the RTO value.
void ObserveRTT(webrtc::TimeDelta measured_rtt);
// Returns the Retransmission Timeout (RTO) value, in milliseconds.
webrtc::TimeDelta rto() const { return webrtc::TimeDelta::Millis(rto_); }
// Returns the smoothed RTT value, in milliseconds.
webrtc::TimeDelta srtt() const {
return webrtc::TimeDelta::Millis(scaled_srtt_ >> kRttShift);
const webrtc::TimeDelta min_rto_;
const webrtc::TimeDelta max_rto_;
const webrtc::TimeDelta max_rtt_;
const int64_t min_rtt_variance_;
// If this is the first measurement
bool first_measurement_ = true;
// Smoothed Round-Trip Time, shifted by kRttShift
int64_t scaled_srtt_;
// Round-Trip Time Variation, shifted by kRttVarShift
int64_t scaled_rtt_var_ = 0;
// Retransmission Timeout
int64_t rto_;
} // namespace dcsctp