2017-04-24 05:53:20 -07:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2017 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.
|
|
|
|
|
*/
|
2018-02-21 13:02:51 +01:00
|
|
|
#include <utility>
|
2017-04-24 05:53:20 -07:00
|
|
|
|
2017-09-15 06:47:31 +02:00
|
|
|
#include "call/rtp_transport_controller_send.h"
|
2018-02-28 16:48:26 +01:00
|
|
|
#include "modules/congestion_controller/include/send_side_congestion_controller.h"
|
2018-02-22 11:10:18 +01:00
|
|
|
#include "rtc_base/location.h"
|
2018-02-21 13:01:55 +01:00
|
|
|
#include "rtc_base/logging.h"
|
2018-02-28 16:48:26 +01:00
|
|
|
#include "rtc_base/ptr_util.h"
|
2017-04-24 05:53:20 -07:00
|
|
|
|
|
|
|
|
namespace webrtc {
|
|
|
|
|
|
|
|
|
|
RtpTransportControllerSend::RtpTransportControllerSend(
|
|
|
|
|
Clock* clock,
|
2018-02-21 13:01:55 +01:00
|
|
|
webrtc::RtcEventLog* event_log,
|
|
|
|
|
const BitrateConstraints& bitrate_config)
|
2017-08-22 16:16:44 +02:00
|
|
|
: pacer_(clock, &packet_router_, event_log),
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_(
|
|
|
|
|
rtc::MakeUnique<SendSideCongestionController>(clock,
|
|
|
|
|
nullptr /* observer */,
|
|
|
|
|
event_log,
|
|
|
|
|
&pacer_)),
|
2018-02-22 11:10:18 +01:00
|
|
|
bitrate_configurator_(bitrate_config),
|
|
|
|
|
process_thread_(ProcessThread::Create("SendControllerThread")) {
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_->SignalNetworkState(kNetworkDown);
|
|
|
|
|
send_side_cc_->SetBweBitrates(bitrate_config.min_bitrate_bps,
|
|
|
|
|
bitrate_config.start_bitrate_bps,
|
|
|
|
|
bitrate_config.max_bitrate_bps);
|
2018-02-22 11:10:18 +01:00
|
|
|
|
|
|
|
|
process_thread_->RegisterModule(&pacer_, RTC_FROM_HERE);
|
2018-02-28 16:48:26 +01:00
|
|
|
process_thread_->RegisterModule(send_side_cc_.get(), RTC_FROM_HERE);
|
2018-02-22 11:10:18 +01:00
|
|
|
process_thread_->Start();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
RtpTransportControllerSend::~RtpTransportControllerSend() {
|
|
|
|
|
process_thread_->Stop();
|
2018-02-28 16:48:26 +01:00
|
|
|
process_thread_->DeRegisterModule(send_side_cc_.get());
|
2018-02-22 11:10:18 +01:00
|
|
|
process_thread_->DeRegisterModule(&pacer_);
|
2018-02-21 13:01:55 +01:00
|
|
|
}
|
2017-04-24 05:53:20 -07:00
|
|
|
|
2017-05-31 02:24:52 -07:00
|
|
|
PacketRouter* RtpTransportControllerSend::packet_router() {
|
|
|
|
|
return &packet_router_;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TransportFeedbackObserver*
|
|
|
|
|
RtpTransportControllerSend::transport_feedback_observer() {
|
2018-02-28 16:48:26 +01:00
|
|
|
return send_side_cc_.get();
|
2017-05-31 02:24:52 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
RtpPacketSender* RtpTransportControllerSend::packet_sender() {
|
2017-08-22 16:16:44 +02:00
|
|
|
return &pacer_;
|
2017-05-31 02:24:52 -07:00
|
|
|
}
|
|
|
|
|
|
2017-08-09 06:42:32 -07:00
|
|
|
const RtpKeepAliveConfig& RtpTransportControllerSend::keepalive_config() const {
|
|
|
|
|
return keepalive_;
|
|
|
|
|
}
|
|
|
|
|
|
2017-08-22 16:16:44 +02:00
|
|
|
void RtpTransportControllerSend::SetAllocatedSendBitrateLimits(
|
|
|
|
|
int min_send_bitrate_bps,
|
2018-02-28 17:04:18 +01:00
|
|
|
int max_padding_bitrate_bps,
|
|
|
|
|
int total_bitrate_bps) {
|
Revert "Revert "Revert "Reland "Moved congestion controller to task queue.""""
This reverts commit 65792c5a5c542201f7b9feefded505842692e6ed.
Reason for revert: <INSERT REASONING HERE>
Original change's description:
> Revert "Revert "Reland "Moved congestion controller to task queue."""
>
> This reverts commit 4e849f6925b2ac44b0957a228d7131fc391fca54.
>
> Reason for revert: <INSERT REASONING HERE>
>
> Original change's description:
> > Revert "Reland "Moved congestion controller to task queue.""
> >
> > This reverts commit 57daeb7ac7f3d80992905b53fea500953fcfd793.
> >
> > Reason for revert: Cause increased congestion and deadlocks in downstream project
> >
> > Original change's description:
> > > Reland "Moved congestion controller to task queue."
> > >
> > > This is a reland of 0cbcba7ea0dced1a7f353c64d6cf91d46ccb29f9.
> > >
> > > Original change's description:
> > > > Moved congestion controller to task queue.
> > > >
> > > > The goal of this work is to make it easier to experiment with the
> > > > bandwidth estimation implementation. For this reason network control
> > > > functionality is moved from SendSideCongestionController(SSCC),
> > > > PacedSender and BitrateController to the newly created
> > > > GoogCcNetworkController which implements the newly created
> > > > NetworkControllerInterface. This allows the implementation to be
> > > > replaced at runtime in the future.
> > > >
> > > > This is the first part of a split of a larger CL, see:
> > > > https://webrtc-review.googlesource.com/c/src/+/39788/8
> > > > For further explanations.
> > > >
> > > > Bug: webrtc:8415
> > > > Change-Id: I770189c04cc31b313bd4e57821acff55fbcb1ad3
> > > > Reviewed-on: https://webrtc-review.googlesource.com/43840
> > > > Commit-Queue: Sebastian Jansson <srte@webrtc.org>
> > > > Reviewed-by: Björn Terelius <terelius@webrtc.org>
> > > > Reviewed-by: Stefan Holmer <stefan@webrtc.org>
> > > > Cr-Commit-Position: refs/heads/master@{#21868}
> > >
> > > Bug: webrtc:8415
> > > Change-Id: I1d1756a30deed5b421b1c91c1918a13b6bb455da
> > > Reviewed-on: https://webrtc-review.googlesource.com/48000
> > > Reviewed-by: Stefan Holmer <stefan@webrtc.org>
> > > Commit-Queue: Sebastian Jansson <srte@webrtc.org>
> > > Cr-Commit-Position: refs/heads/master@{#21899}
> >
> > TBR=terelius@webrtc.org,stefan@webrtc.org,srte@webrtc.org
> >
> > # Not skipping CQ checks because original CL landed > 1 day ago.
> >
> > Bug: webrtc:8415
> > Change-Id: Ida8074dcac2cc28b3629228eb22846d8a8e81b83
> > Reviewed-on: https://webrtc-review.googlesource.com/52980
> > Reviewed-by: Danil Chapovalov <danilchap@webrtc.org>
> > Commit-Queue: Danil Chapovalov <danilchap@webrtc.org>
> > Cr-Commit-Position: refs/heads/master@{#22017}
>
> TBR=danilchap@webrtc.org,terelius@webrtc.org,stefan@webrtc.org,srte@webrtc.org
>
> Change-Id: I3393b74370c4f4d0955f50728005b2b925be169b
> No-Presubmit: true
> No-Tree-Checks: true
> No-Try: true
> Bug: webrtc:8415
> Reviewed-on: https://webrtc-review.googlesource.com/53262
> Reviewed-by: Sebastian Jansson <srte@webrtc.org>
> Commit-Queue: Sebastian Jansson <srte@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#22023}
TBR=danilchap@webrtc.org,terelius@webrtc.org,stefan@webrtc.org,srte@webrtc.org
Change-Id: Id68ad986ee51142b7be3381d0793709b4392fe2c
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: webrtc:8415
Reviewed-on: https://webrtc-review.googlesource.com/53360
Reviewed-by: Sebastian Jansson <srte@webrtc.org>
Commit-Queue: Sebastian Jansson <srte@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#22024}
2018-02-14 16:53:38 +00:00
|
|
|
pacer_.SetSendBitrateLimits(min_send_bitrate_bps, max_padding_bitrate_bps);
|
2017-08-22 16:16:44 +02:00
|
|
|
}
|
|
|
|
|
|
2017-08-09 06:42:32 -07:00
|
|
|
void RtpTransportControllerSend::SetKeepAliveConfig(
|
|
|
|
|
const RtpKeepAliveConfig& config) {
|
|
|
|
|
keepalive_ = config;
|
|
|
|
|
}
|
2018-02-15 16:51:58 +01:00
|
|
|
void RtpTransportControllerSend::SetPacingFactor(float pacing_factor) {
|
|
|
|
|
pacer_.SetPacingFactor(pacing_factor);
|
|
|
|
|
}
|
|
|
|
|
void RtpTransportControllerSend::SetQueueTimeLimit(int limit_ms) {
|
|
|
|
|
pacer_.SetQueueTimeLimit(limit_ms);
|
|
|
|
|
}
|
2018-02-15 16:51:41 +01:00
|
|
|
CallStatsObserver* RtpTransportControllerSend::GetCallStatsObserver() {
|
2018-02-28 16:48:26 +01:00
|
|
|
return send_side_cc_.get();
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
void RtpTransportControllerSend::RegisterPacketFeedbackObserver(
|
|
|
|
|
PacketFeedbackObserver* observer) {
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_->RegisterPacketFeedbackObserver(observer);
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
void RtpTransportControllerSend::DeRegisterPacketFeedbackObserver(
|
|
|
|
|
PacketFeedbackObserver* observer) {
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_->DeRegisterPacketFeedbackObserver(observer);
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
void RtpTransportControllerSend::RegisterNetworkObserver(
|
|
|
|
|
NetworkChangedObserver* observer) {
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_->RegisterNetworkObserver(observer);
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
void RtpTransportControllerSend::OnNetworkRouteChanged(
|
2018-02-21 13:01:55 +01:00
|
|
|
const std::string& transport_name,
|
|
|
|
|
const rtc::NetworkRoute& network_route) {
|
2018-02-21 13:02:51 +01:00
|
|
|
// Check if the network route is connected.
|
|
|
|
|
if (!network_route.connected) {
|
|
|
|
|
RTC_LOG(LS_INFO) << "Transport " << transport_name << " is disconnected";
|
|
|
|
|
// TODO(honghaiz): Perhaps handle this in SignalChannelNetworkState and
|
|
|
|
|
// consider merging these two methods.
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Check whether the network route has changed on each transport.
|
|
|
|
|
auto result =
|
|
|
|
|
network_routes_.insert(std::make_pair(transport_name, network_route));
|
|
|
|
|
auto kv = result.first;
|
|
|
|
|
bool inserted = result.second;
|
|
|
|
|
if (inserted) {
|
|
|
|
|
// No need to reset BWE if this is the first time the network connects.
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (kv->second != network_route) {
|
|
|
|
|
kv->second = network_route;
|
|
|
|
|
BitrateConstraints bitrate_config = bitrate_configurator_.GetConfig();
|
|
|
|
|
RTC_LOG(LS_INFO) << "Network route changed on transport " << transport_name
|
|
|
|
|
<< ": new local network id "
|
|
|
|
|
<< network_route.local_network_id
|
|
|
|
|
<< " new remote network id "
|
|
|
|
|
<< network_route.remote_network_id
|
|
|
|
|
<< " Reset bitrates to min: "
|
|
|
|
|
<< bitrate_config.min_bitrate_bps
|
|
|
|
|
<< " bps, start: " << bitrate_config.start_bitrate_bps
|
|
|
|
|
<< " bps, max: " << bitrate_config.max_bitrate_bps
|
|
|
|
|
<< " bps.";
|
|
|
|
|
RTC_DCHECK_GT(bitrate_config.start_bitrate_bps, 0);
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_->OnNetworkRouteChanged(
|
2018-02-21 13:02:51 +01:00
|
|
|
network_route, bitrate_config.start_bitrate_bps,
|
|
|
|
|
bitrate_config.min_bitrate_bps, bitrate_config.max_bitrate_bps);
|
|
|
|
|
}
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
void RtpTransportControllerSend::OnNetworkAvailability(bool network_available) {
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_->SignalNetworkState(network_available ? kNetworkUp
|
|
|
|
|
: kNetworkDown);
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
RtcpBandwidthObserver* RtpTransportControllerSend::GetBandwidthObserver() {
|
2018-02-28 16:48:26 +01:00
|
|
|
return send_side_cc_->GetBandwidthObserver();
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
bool RtpTransportControllerSend::AvailableBandwidth(uint32_t* bandwidth) const {
|
2018-02-28 16:48:26 +01:00
|
|
|
return send_side_cc_->AvailableBandwidth(bandwidth);
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
int64_t RtpTransportControllerSend::GetPacerQueuingDelayMs() const {
|
2018-02-28 16:48:26 +01:00
|
|
|
return send_side_cc_->GetPacerQueuingDelayMs();
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
int64_t RtpTransportControllerSend::GetFirstPacketTimeMs() const {
|
2018-02-28 16:48:26 +01:00
|
|
|
return send_side_cc_->GetFirstPacketTimeMs();
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
void RtpTransportControllerSend::EnablePeriodicAlrProbing(bool enable) {
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_->EnablePeriodicAlrProbing(enable);
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
|
|
|
|
void RtpTransportControllerSend::OnSentPacket(
|
|
|
|
|
const rtc::SentPacket& sent_packet) {
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_->OnSentPacket(sent_packet);
|
2018-02-15 16:51:41 +01:00
|
|
|
}
|
2017-08-09 06:42:32 -07:00
|
|
|
|
2018-02-21 13:01:55 +01:00
|
|
|
void RtpTransportControllerSend::SetSdpBitrateParameters(
|
|
|
|
|
const BitrateConstraints& constraints) {
|
|
|
|
|
rtc::Optional<BitrateConstraints> updated =
|
|
|
|
|
bitrate_configurator_.UpdateWithSdpParameters(constraints);
|
|
|
|
|
if (updated.has_value()) {
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_->SetBweBitrates(updated->min_bitrate_bps,
|
|
|
|
|
updated->start_bitrate_bps,
|
|
|
|
|
updated->max_bitrate_bps);
|
2018-02-21 13:01:55 +01:00
|
|
|
} else {
|
|
|
|
|
RTC_LOG(LS_VERBOSE)
|
2018-02-21 13:07:13 +01:00
|
|
|
<< "WebRTC.RtpTransportControllerSend.SetSdpBitrateParameters: "
|
2018-02-21 13:01:55 +01:00
|
|
|
<< "nothing to update";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void RtpTransportControllerSend::SetClientBitratePreferences(
|
|
|
|
|
const BitrateConstraintsMask& preferences) {
|
|
|
|
|
rtc::Optional<BitrateConstraints> updated =
|
|
|
|
|
bitrate_configurator_.UpdateWithClientPreferences(preferences);
|
|
|
|
|
if (updated.has_value()) {
|
2018-02-28 16:48:26 +01:00
|
|
|
send_side_cc_->SetBweBitrates(updated->min_bitrate_bps,
|
|
|
|
|
updated->start_bitrate_bps,
|
|
|
|
|
updated->max_bitrate_bps);
|
2018-02-21 13:01:55 +01:00
|
|
|
} else {
|
|
|
|
|
RTC_LOG(LS_VERBOSE)
|
2018-02-21 13:07:13 +01:00
|
|
|
<< "WebRTC.RtpTransportControllerSend.SetClientBitratePreferences: "
|
2018-02-21 13:01:55 +01:00
|
|
|
<< "nothing to update";
|
|
|
|
|
}
|
|
|
|
|
}
|
2017-04-24 05:53:20 -07:00
|
|
|
} // namespace webrtc
|