This adds the ability to the pacer to apply a congestion window by tracking sent data. This makes it more reliable when the congestion window is small enough to be filled at a high rate as there are less thread context switches that might affect the timing and performance. Outstanding data is not reduced by the pacer as it has no information about acknowledged packet feedback. This is by design as the pacer would also need to keep track of on which connection packets were sent or received, requiring a larger, more complex, change to the pacer. Bug: webrtc:8415 Change-Id: I4ecd303e835552ced042cd21186da910288a8258 Reviewed-on: https://webrtc-review.googlesource.com/51764 Reviewed-by: Philip Eliasson <philipel@webrtc.org> Commit-Queue: Sebastian Jansson <srte@webrtc.org> Cr-Commit-Position: refs/heads/master@{#22371}
74 lines
2.4 KiB
C++
74 lines
2.4 KiB
C++
/*
|
|
* Copyright (c) 2018 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 "modules/congestion_controller/rtp/pacer_controller.h"
|
|
|
|
#include "modules/congestion_controller/network_control/include/network_units.h"
|
|
#include "rtc_base/checks.h"
|
|
#include "rtc_base/logging.h"
|
|
|
|
namespace webrtc {
|
|
namespace webrtc_cc {
|
|
|
|
PacerController::PacerController(PacedSender* pacer) : pacer_(pacer) {
|
|
sequenced_checker_.Detach();
|
|
}
|
|
|
|
PacerController::~PacerController() = default;
|
|
|
|
void PacerController::OnCongestionWindow(CongestionWindow congestion_window) {
|
|
RTC_DCHECK_CALLED_SEQUENTIALLY(&sequenced_checker_);
|
|
if (congestion_window.enabled)
|
|
pacer_->SetCongestionWindow(congestion_window.data_window.bytes());
|
|
else
|
|
pacer_->SetCongestionWindow(PacedSender::kNoCongestionWindow);
|
|
}
|
|
|
|
void PacerController::OnNetworkAvailability(NetworkAvailability msg) {
|
|
RTC_DCHECK_CALLED_SEQUENTIALLY(&sequenced_checker_);
|
|
network_available_ = msg.network_available;
|
|
pacer_->UpdateOutstandingData(0);
|
|
SetPacerState(!msg.network_available);
|
|
}
|
|
|
|
void PacerController::OnNetworkRouteChange(NetworkRouteChange) {
|
|
RTC_DCHECK_CALLED_SEQUENTIALLY(&sequenced_checker_);
|
|
pacer_->UpdateOutstandingData(0);
|
|
}
|
|
|
|
void PacerController::OnPacerConfig(PacerConfig msg) {
|
|
RTC_DCHECK_CALLED_SEQUENTIALLY(&sequenced_checker_);
|
|
DataRate pacing_rate = msg.data_window / msg.time_window;
|
|
DataRate padding_rate = msg.pad_window / msg.time_window;
|
|
pacer_->SetPacingRates(pacing_rate.bps(), padding_rate.bps());
|
|
}
|
|
|
|
void PacerController::OnProbeClusterConfig(ProbeClusterConfig config) {
|
|
RTC_DCHECK_CALLED_SEQUENTIALLY(&sequenced_checker_);
|
|
int64_t bitrate_bps = config.target_data_rate.bps();
|
|
pacer_->CreateProbeCluster(bitrate_bps);
|
|
}
|
|
|
|
void PacerController::OnOutstandingData(OutstandingData msg) {
|
|
RTC_DCHECK_CALLED_SEQUENTIALLY(&sequenced_checker_);
|
|
pacer_->UpdateOutstandingData(msg.in_flight_data.bytes());
|
|
}
|
|
|
|
void PacerController::SetPacerState(bool paused) {
|
|
if (paused && !pacer_paused_)
|
|
pacer_->Pause();
|
|
else if (!paused && pacer_paused_)
|
|
pacer_->Resume();
|
|
pacer_paused_ = paused;
|
|
}
|
|
|
|
} // namespace webrtc_cc
|
|
} // namespace webrtc
|