blob: ac4213d5686d070f701524fa53aafdc4a7f418e1 [file] [log] [blame]
nisseb8f9a322017-03-27 12:36:151/*
2 * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 04:47:3111#ifndef CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_
12#define CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_
nisseb8f9a322017-03-27 12:36:1513
Sebastian Jansson87609be2018-12-05 16:35:3514#include <atomic>
Sebastian Jansson91bb6672018-02-21 12:02:5115#include <map>
Sebastian Janssonc33c0fc2018-02-22 10:10:1816#include <memory>
Sebastian Jansson97f61ea2018-02-21 12:01:5517#include <string>
Stefan Holmerdbdb3a02018-07-17 14:03:4618#include <vector>
Sebastian Jansson97f61ea2018-02-21 12:01:5519
Ying Wang0810a7c2019-04-10 11:48:2420#include "api/network_state_predictor.h"
Tommi1050fbc2021-06-03 15:58:2821#include "api/sequence_checker.h"
Sebastian Janssondfce03a2018-05-18 16:05:1022#include "api/transport/network_control.h"
Christoffer Rodbro6404cdd2020-03-26 19:37:2123#include "api/units/data_rate.h"
Sebastian Jansson97f61ea2018-02-21 12:01:5524#include "call/rtp_bitrate_configurator.h"
Mirko Bonadei92ea95e2017-09-15 04:47:3125#include "call/rtp_transport_controller_send_interface.h"
Stefan Holmer9416ef82018-07-19 08:34:3826#include "call/rtp_video_sender.h"
Sebastian Jansson87609be2018-12-05 16:35:3527#include "modules/congestion_controller/rtp/control_handler.h"
28#include "modules/congestion_controller/rtp/transport_feedback_adapter.h"
JT Tehea992f82020-01-15 18:24:2029#include "modules/congestion_controller/rtp/transport_feedback_demuxer.h"
Erik Språng4314a492019-11-26 16:48:4930#include "modules/pacing/paced_sender.h"
Niels Möllerfd6c0912017-10-31 09:19:1031#include "modules/pacing/packet_router.h"
Erik Språng425d6aa2019-07-29 14:38:2732#include "modules/pacing/rtp_packet_pacer.h"
Erik Språng4314a492019-11-26 16:48:4933#include "modules/pacing/task_queue_paced_sender.h"
Sebastian Janssonc33c0fc2018-02-22 10:10:1834#include "modules/utility/include/process_thread.h"
Steve Anton10542f22019-01-11 17:11:0035#include "rtc_base/constructor_magic.h"
36#include "rtc_base/network_route.h"
Sebastian Jansson87609be2018-12-05 16:35:3537#include "rtc_base/race_checker.h"
Sebastian Janssone6256052018-05-04 12:08:1538#include "rtc_base/task_queue.h"
Sebastian Janssonecb68972019-01-18 09:30:5439#include "rtc_base/task_utils/repeating_task.h"
nissecae45d02017-04-24 12:53:2040
nisseb8f9a322017-03-27 12:36:1541namespace webrtc {
nissecae45d02017-04-24 12:53:2042class Clock;
Benjamin Wright192eeec2018-10-18 00:27:2543class FrameEncryptorInterface;
nissecae45d02017-04-24 12:53:2044class RtcEventLog;
nisseb8f9a322017-03-27 12:36:1545
nissecae45d02017-04-24 12:53:2046// TODO(nisse): When we get the underlying transports here, we should
47// have one object implementing RtpTransportControllerSendInterface
48// per transport, sharing the same congestion controller.
Sebastian Jansson317a5222018-03-16 14:36:3749class RtpTransportControllerSend final
50 : public RtpTransportControllerSendInterface,
Sebastian Jansson87609be2018-12-05 16:35:3551 public RtcpBandwidthObserver,
Sebastian Janssone1795f42019-07-24 09:38:0352 public TransportFeedbackObserver,
53 public NetworkStateEstimateObserver {
nisseb8f9a322017-03-27 12:36:1554 public:
Sebastian Janssondfce03a2018-05-18 16:05:1055 RtpTransportControllerSend(
56 Clock* clock,
57 RtcEventLog* event_log,
Ying Wang0810a7c2019-04-10 11:48:2458 NetworkStatePredictorFactoryInterface* predictor_factory,
Sebastian Janssondfce03a2018-05-18 16:05:1059 NetworkControllerFactoryInterface* controller_factory,
Sebastian Janssoned50e6c2019-03-01 13:45:2160 const BitrateConstraints& bitrate_config,
61 std::unique_ptr<ProcessThread> process_thread,
Erik Språng662678d2019-11-15 16:18:5262 TaskQueueFactory* task_queue_factory,
63 const WebRtcKeyValueConfig* trials);
Sebastian Jansson97f61ea2018-02-21 12:01:5564 ~RtpTransportControllerSend() override;
Sebastian Jansson19704ec2018-03-12 14:59:1265
Tommi1050fbc2021-06-03 15:58:2866 // TODO(tommi): Change to std::unique_ptr<>.
Stefan Holmer9416ef82018-07-19 08:34:3867 RtpVideoSenderInterface* CreateRtpVideoSender(
Stefan Holmerdbdb3a02018-07-17 14:03:4668 std::map<uint32_t, RtpState> suspended_ssrcs,
69 const std::map<uint32_t, RtpPayloadState>&
70 states, // move states into RtpTransportControllerSend
71 const RtpConfig& rtp_config,
Jiawei Ou55718122018-11-09 21:17:3972 int rtcp_report_interval_ms,
Stefan Holmerdbdb3a02018-07-17 14:03:4673 Transport* send_transport,
74 const RtpSenderObservers& observers,
Stefan Holmer64be7fa2018-10-04 13:21:5575 RtcEventLog* event_log,
Benjamin Wright192eeec2018-10-18 00:27:2576 std::unique_ptr<FecController> fec_controller,
Marina Cioceae77912b2020-02-27 15:16:5577 const RtpSenderFrameEncryptionConfig& frame_encryption_config,
78 rtc::scoped_refptr<FrameTransformerInterface> frame_transformer) override;
Stefan Holmer9416ef82018-07-19 08:34:3879 void DestroyRtpVideoSender(
80 RtpVideoSenderInterface* rtp_video_sender) override;
Stefan Holmerdbdb3a02018-07-17 14:03:4681
nissecae45d02017-04-24 12:53:2082 // Implements RtpTransportControllerSendInterface
Sebastian Janssone6256052018-05-04 12:08:1583 rtc::TaskQueue* GetWorkerQueue() override;
nisse76e62b02017-05-31 09:24:5284 PacketRouter* packet_router() override;
Sebastian Jansson4c1ffb82018-02-15 15:51:5885
Sebastian Janssone1795f42019-07-24 09:38:0386 NetworkStateEstimateObserver* network_state_estimate_observer() override;
nisse76e62b02017-05-31 09:24:5287 TransportFeedbackObserver* transport_feedback_observer() override;
Erik Språngaa59eca2019-07-24 12:52:5588 RtpPacketSender* packet_sender() override;
sprangdb2a9fc2017-08-09 13:42:3289
Sebastian Jansson93b1ea22019-09-18 16:31:5290 void SetAllocatedSendBitrateLimits(BitrateAllocationLimits limits) override;
Stefan Holmer5c8942a2017-08-22 14:16:4491
Sebastian Jansson4c1ffb82018-02-15 15:51:5892 void SetPacingFactor(float pacing_factor) override;
93 void SetQueueTimeLimit(int limit_ms) override;
Sebastian Janssonf2988552019-10-29 16:18:5194 StreamFeedbackProvider* GetStreamFeedbackProvider() override;
Sebastian Jansson19704ec2018-03-12 14:59:1295 void RegisterTargetTransferRateObserver(
96 TargetTransferRateObserver* observer) override;
Sebastian Jansson97f61ea2018-02-21 12:01:5597 void OnNetworkRouteChanged(const std::string& transport_name,
98 const rtc::NetworkRoute& network_route) override;
Sebastian Janssone4be6da2018-02-15 15:51:4199 void OnNetworkAvailability(bool network_available) override;
Sebastian Janssone4be6da2018-02-15 15:51:41100 RtcpBandwidthObserver* GetBandwidthObserver() override;
Sebastian Janssone4be6da2018-02-15 15:51:41101 int64_t GetPacerQueuingDelayMs() const override;
Erik Språng425d6aa2019-07-29 14:38:27102 absl::optional<Timestamp> GetFirstPacketTime() const override;
Sebastian Janssone4be6da2018-02-15 15:51:41103 void EnablePeriodicAlrProbing(bool enable) override;
104 void OnSentPacket(const rtc::SentPacket& sent_packet) override;
Sebastian Jansson607a6f12019-06-13 15:48:53105 void OnReceivedPacket(const ReceivedPacket& packet_msg) override;
nissecae45d02017-04-24 12:53:20106
Sebastian Jansson97f61ea2018-02-21 12:01:55107 void SetSdpBitrateParameters(const BitrateConstraints& constraints) override;
Yves Gerey665174f2018-06-19 13:03:05108 void SetClientBitratePreferences(const BitrateSettings& preferences) override;
Sebastian Jansson97f61ea2018-02-21 12:01:55109
Stefan Holmer64be7fa2018-10-04 13:21:55110 void OnTransportOverheadChanged(
Christoffer Rodbrob0ca5192020-03-26 08:22:24111 size_t transport_overhead_bytes_per_packet) override;
Stefan Holmer64be7fa2018-10-04 13:21:55112
Erik Språngaa59eca2019-07-24 12:52:55113 void AccountForAudioPacketsInPacedSender(bool account_for_audio) override;
Sebastian Janssonc3eb9fd2020-01-29 16:42:52114 void IncludeOverheadInPacedSender() override;
Erik Språng7703f232020-09-14 09:03:13115 void EnsureStarted() override;
Erik Språngaa59eca2019-07-24 12:52:55116
Sebastian Jansson87609be2018-12-05 16:35:35117 // Implements RtcpBandwidthObserver interface
118 void OnReceivedEstimatedBitrate(uint32_t bitrate) override;
119 void OnReceivedRtcpReceiverReport(const ReportBlockList& report_blocks,
120 int64_t rtt,
121 int64_t now_ms) override;
122
123 // Implements TransportFeedbackObserver interface
Erik Språng30a276b2019-04-23 10:00:11124 void OnAddPacket(const RtpPacketSendInfo& packet_info) override;
Sebastian Jansson87609be2018-12-05 16:35:35125 void OnTransportFeedback(const rtcp::TransportFeedback& feedback) override;
126
Sebastian Janssone1795f42019-07-24 09:38:03127 // Implements NetworkStateEstimateObserver interface
128 void OnRemoteNetworkEstimate(NetworkStateEstimate estimate) override;
129
nissecae45d02017-04-24 12:53:20130 private:
Erik Språng0f86c1f2021-10-26 14:19:03131 struct PacerSettings {
132 explicit PacerSettings(const WebRtcKeyValueConfig* trials);
133
134 bool use_task_queue_pacer() const { return !tq_disabled.Get(); }
135
136 FieldTrialFlag tq_disabled; // Kill-switch not normally used.
137 FieldTrialParameter<TimeDelta> holdback_window;
138 FieldTrialParameter<int> holdback_packets;
139 };
140
Sebastian Jansson87609be2018-12-05 16:35:35141 void MaybeCreateControllers() RTC_RUN_ON(task_queue_);
142 void UpdateInitialConstraints(TargetRateConstraints new_contraints)
143 RTC_RUN_ON(task_queue_);
144
145 void StartProcessPeriodicTasks() RTC_RUN_ON(task_queue_);
146 void UpdateControllerWithTimeInterval() RTC_RUN_ON(task_queue_);
Sebastian Jansson87609be2018-12-05 16:35:35147
Christoffer Rodbro6404cdd2020-03-26 19:37:21148 absl::optional<BitrateConstraints> ApplyOrLiftRelayCap(bool is_relayed);
149 bool IsRelevantRouteChange(const rtc::NetworkRoute& old_route,
150 const rtc::NetworkRoute& new_route) const;
Christoffer Rodbrob0ca5192020-03-26 08:22:24151 void UpdateBitrateConstraints(const BitrateConstraints& updated);
Sebastian Jansson87609be2018-12-05 16:35:35152 void UpdateStreamsConfig() RTC_RUN_ON(task_queue_);
Sebastian Jansson87609be2018-12-05 16:35:35153 void OnReceivedRtcpReceiverReportBlocks(const ReportBlockList& report_blocks,
154 int64_t now_ms)
155 RTC_RUN_ON(task_queue_);
Sebastian Jansson16180952018-12-12 15:49:10156 void PostUpdates(NetworkControlUpdate update) RTC_RUN_ON(task_queue_);
157 void UpdateControlState() RTC_RUN_ON(task_queue_);
Erik Språng425d6aa2019-07-29 14:38:27158 RtpPacketPacer* pacer();
159 const RtpPacketPacer* pacer() const;
Sebastian Jansson87609be2018-12-05 16:35:35160
Sebastian Janssonaa01f272019-01-30 10:28:59161 Clock* const clock_;
Sebastian Jansson166b45d2019-05-13 09:57:42162 RtcEventLog* const event_log_;
Tommi1050fbc2021-06-03 15:58:28163 SequenceChecker main_thread_;
nissecae45d02017-04-24 12:53:20164 PacketRouter packet_router_;
Tommi1050fbc2021-06-03 15:58:28165 std::vector<std::unique_ptr<RtpVideoSenderInterface>> video_rtp_senders_
166 RTC_GUARDED_BY(&main_thread_);
Sebastian Jansson97f61ea2018-02-21 12:01:55167 RtpBitrateConfigurator bitrate_configurator_;
Sebastian Jansson91bb6672018-02-21 12:02:51168 std::map<std::string, rtc::NetworkRoute> network_routes_;
Etienne Pierre-doray03bce3f2021-03-29 17:36:15169 bool pacer_started_;
Sebastian Janssonc33c0fc2018-02-22 10:10:18170 const std::unique_ptr<ProcessThread> process_thread_;
Erik Språng0f86c1f2021-10-26 14:19:03171 const PacerSettings pacer_settings_;
Erik Språng4314a492019-11-26 16:48:49172 std::unique_ptr<PacedSender> process_thread_pacer_;
173 std::unique_ptr<TaskQueuePacedSender> task_queue_pacer_;
Sebastian Jansson87609be2018-12-05 16:35:35174
175 TargetTransferRateObserver* observer_ RTC_GUARDED_BY(task_queue_);
JT Tehea992f82020-01-15 18:24:20176 TransportFeedbackDemuxer feedback_demuxer_;
Sebastian Jansson87609be2018-12-05 16:35:35177
Sebastian Jansson658f1812020-01-16 09:59:28178 TransportFeedbackAdapter transport_feedback_adapter_
179 RTC_GUARDED_BY(task_queue_);
Sebastian Jansson87609be2018-12-05 16:35:35180
181 NetworkControllerFactoryInterface* const controller_factory_override_
182 RTC_PT_GUARDED_BY(task_queue_);
183 const std::unique_ptr<NetworkControllerFactoryInterface>
184 controller_factory_fallback_ RTC_PT_GUARDED_BY(task_queue_);
185
186 std::unique_ptr<CongestionControlHandler> control_handler_
187 RTC_GUARDED_BY(task_queue_) RTC_PT_GUARDED_BY(task_queue_);
188
189 std::unique_ptr<NetworkControllerInterface> controller_
190 RTC_GUARDED_BY(task_queue_) RTC_PT_GUARDED_BY(task_queue_);
191
192 TimeDelta process_interval_ RTC_GUARDED_BY(task_queue_);
193
194 std::map<uint32_t, RTCPReportBlock> last_report_blocks_
195 RTC_GUARDED_BY(task_queue_);
196 Timestamp last_report_block_time_ RTC_GUARDED_BY(task_queue_);
197
198 NetworkControllerConfig initial_config_ RTC_GUARDED_BY(task_queue_);
199 StreamsConfig streams_config_ RTC_GUARDED_BY(task_queue_);
200
201 const bool reset_feedback_on_route_change_;
202 const bool send_side_bwe_with_overhead_;
Christoffer Rodbroc610e262019-01-08 09:49:19203 const bool add_pacing_to_cwin_;
Christoffer Rodbro6404cdd2020-03-26 19:37:21204 FieldTrialParameter<DataRate> relay_bandwidth_cap_;
Sebastian Jansson658f1812020-01-16 09:59:28205
206 size_t transport_overhead_bytes_per_packet_ RTC_GUARDED_BY(task_queue_);
Sebastian Jansson87609be2018-12-05 16:35:35207 bool network_available_ RTC_GUARDED_BY(task_queue_);
Sebastian Janssonecb68972019-01-18 09:30:54208 RepeatingTaskHandle pacer_queue_update_task_ RTC_GUARDED_BY(task_queue_);
209 RepeatingTaskHandle controller_task_ RTC_GUARDED_BY(task_queue_);
Sebastian Jansson87609be2018-12-05 16:35:35210
Sebastian Jansson658f1812020-01-16 09:59:28211 // Protected by internal locks.
Stefan Holmerdbdb3a02018-07-17 14:03:46212 RateLimiter retransmission_rate_limiter_;
213
Artem Titovea240272021-07-26 10:40:21214 // TODO(perkj): `task_queue_` is supposed to replace `process_thread_`.
215 // `task_queue_` is defined last to ensure all pending tasks are cancelled
Sebastian Janssone6256052018-05-04 12:08:15216 // and deleted before any other members.
217 rtc::TaskQueue task_queue_;
nissecae45d02017-04-24 12:53:20218 RTC_DISALLOW_COPY_AND_ASSIGN(RtpTransportControllerSend);
nisseb8f9a322017-03-27 12:36:15219};
220
221} // namespace webrtc
222
Mirko Bonadei92ea95e2017-09-15 04:47:31223#endif // CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_