blob: 7025b033128e483e9887acf9b9c45d39dd5376c9 [file] [log] [blame]
nisseb8f9a322017-03-27 05:36:15 -07001/*
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 06:47:31 +020011#ifndef CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_
12#define CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_
nisseb8f9a322017-03-27 05:36:15 -070013
Sebastian Jansson87609be2018-12-05 17:35:35 +010014#include <atomic>
Sebastian Jansson91bb6672018-02-21 13:02:51 +010015#include <map>
Sebastian Janssonc33c0fc2018-02-22 11:10:18 +010016#include <memory>
Sebastian Jansson97f61ea2018-02-21 13:01:55 +010017#include <string>
Stefan Holmerdbdb3a02018-07-17 16:03:46 +020018#include <vector>
Sebastian Jansson97f61ea2018-02-21 13:01:55 +010019
Ying Wang0810a7c2019-04-10 13:48:24 +020020#include "api/network_state_predictor.h"
Sebastian Janssondfce03a2018-05-18 18:05:10 +020021#include "api/transport/network_control.h"
Christoffer Rodbro6404cdd2020-03-26 20:37:21 +010022#include "api/units/data_rate.h"
Sebastian Jansson97f61ea2018-02-21 13:01:55 +010023#include "call/rtp_bitrate_configurator.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020024#include "call/rtp_transport_controller_send_interface.h"
Stefan Holmer9416ef82018-07-19 10:34:38 +020025#include "call/rtp_video_sender.h"
Sebastian Jansson87609be2018-12-05 17:35:35 +010026#include "modules/congestion_controller/rtp/control_handler.h"
27#include "modules/congestion_controller/rtp/transport_feedback_adapter.h"
JT Tehea992f82020-01-15 18:24:20 +000028#include "modules/congestion_controller/rtp/transport_feedback_demuxer.h"
Erik Språng4314a492019-11-26 17:48:49 +010029#include "modules/pacing/paced_sender.h"
Niels Möllerfd6c0912017-10-31 10:19:10 +010030#include "modules/pacing/packet_router.h"
Erik Språng425d6aa2019-07-29 16:38:27 +020031#include "modules/pacing/rtp_packet_pacer.h"
Erik Språng4314a492019-11-26 17:48:49 +010032#include "modules/pacing/task_queue_paced_sender.h"
Sebastian Janssonc33c0fc2018-02-22 11:10:18 +010033#include "modules/utility/include/process_thread.h"
Steve Anton10542f22019-01-11 09:11:00 -080034#include "rtc_base/constructor_magic.h"
35#include "rtc_base/network_route.h"
Sebastian Jansson87609be2018-12-05 17:35:35 +010036#include "rtc_base/race_checker.h"
Sebastian Janssone6256052018-05-04 14:08:15 +020037#include "rtc_base/task_queue.h"
Sebastian Janssonecb68972019-01-18 10:30:54 +010038#include "rtc_base/task_utils/repeating_task.h"
nissecae45d02017-04-24 05:53:20 -070039
nisseb8f9a322017-03-27 05:36:15 -070040namespace webrtc {
nissecae45d02017-04-24 05:53:20 -070041class Clock;
Benjamin Wright192eeec2018-10-17 17:27:25 -070042class FrameEncryptorInterface;
nissecae45d02017-04-24 05:53:20 -070043class RtcEventLog;
nisseb8f9a322017-03-27 05:36:15 -070044
nissecae45d02017-04-24 05:53:20 -070045// TODO(nisse): When we get the underlying transports here, we should
46// have one object implementing RtpTransportControllerSendInterface
47// per transport, sharing the same congestion controller.
Sebastian Jansson317a5222018-03-16 15:36:37 +010048class RtpTransportControllerSend final
49 : public RtpTransportControllerSendInterface,
Sebastian Jansson87609be2018-12-05 17:35:35 +010050 public RtcpBandwidthObserver,
Sebastian Janssone1795f42019-07-24 11:38:03 +020051 public TransportFeedbackObserver,
52 public NetworkStateEstimateObserver {
nisseb8f9a322017-03-27 05:36:15 -070053 public:
Sebastian Janssondfce03a2018-05-18 18:05:10 +020054 RtpTransportControllerSend(
55 Clock* clock,
56 RtcEventLog* event_log,
Ying Wang0810a7c2019-04-10 13:48:24 +020057 NetworkStatePredictorFactoryInterface* predictor_factory,
Sebastian Janssondfce03a2018-05-18 18:05:10 +020058 NetworkControllerFactoryInterface* controller_factory,
Sebastian Janssoned50e6c2019-03-01 14:45:21 +010059 const BitrateConstraints& bitrate_config,
60 std::unique_ptr<ProcessThread> process_thread,
Erik Språng662678d2019-11-15 17:18:52 +010061 TaskQueueFactory* task_queue_factory,
62 const WebRtcKeyValueConfig* trials);
Sebastian Jansson97f61ea2018-02-21 13:01:55 +010063 ~RtpTransportControllerSend() override;
Sebastian Jansson19704ec2018-03-12 15:59:12 +010064
Stefan Holmer9416ef82018-07-19 10:34:38 +020065 RtpVideoSenderInterface* CreateRtpVideoSender(
Stefan Holmerdbdb3a02018-07-17 16:03:46 +020066 std::map<uint32_t, RtpState> suspended_ssrcs,
67 const std::map<uint32_t, RtpPayloadState>&
68 states, // move states into RtpTransportControllerSend
69 const RtpConfig& rtp_config,
Jiawei Ou55718122018-11-09 13:17:39 -080070 int rtcp_report_interval_ms,
Stefan Holmerdbdb3a02018-07-17 16:03:46 +020071 Transport* send_transport,
72 const RtpSenderObservers& observers,
Stefan Holmer64be7fa2018-10-04 15:21:55 +020073 RtcEventLog* event_log,
Benjamin Wright192eeec2018-10-17 17:27:25 -070074 std::unique_ptr<FecController> fec_controller,
Marina Cioceae77912b2020-02-27 16:16:55 +010075 const RtpSenderFrameEncryptionConfig& frame_encryption_config,
76 rtc::scoped_refptr<FrameTransformerInterface> frame_transformer) override;
Stefan Holmer9416ef82018-07-19 10:34:38 +020077 void DestroyRtpVideoSender(
78 RtpVideoSenderInterface* rtp_video_sender) override;
Stefan Holmerdbdb3a02018-07-17 16:03:46 +020079
nissecae45d02017-04-24 05:53:20 -070080 // Implements RtpTransportControllerSendInterface
Sebastian Janssone6256052018-05-04 14:08:15 +020081 rtc::TaskQueue* GetWorkerQueue() override;
nisse76e62b02017-05-31 02:24:52 -070082 PacketRouter* packet_router() override;
Sebastian Jansson4c1ffb82018-02-15 16:51:58 +010083
Sebastian Janssone1795f42019-07-24 11:38:03 +020084 NetworkStateEstimateObserver* network_state_estimate_observer() override;
nisse76e62b02017-05-31 02:24:52 -070085 TransportFeedbackObserver* transport_feedback_observer() override;
Erik Språngaa59eca2019-07-24 14:52:55 +020086 RtpPacketSender* packet_sender() override;
sprangdb2a9fc2017-08-09 06:42:32 -070087
Sebastian Jansson93b1ea22019-09-18 18:31:52 +020088 void SetAllocatedSendBitrateLimits(BitrateAllocationLimits limits) override;
Stefan Holmer5c8942a2017-08-22 16:16:44 +020089
Sebastian Jansson4c1ffb82018-02-15 16:51:58 +010090 void SetPacingFactor(float pacing_factor) override;
91 void SetQueueTimeLimit(int limit_ms) override;
Sebastian Janssonf2988552019-10-29 17:18:51 +010092 StreamFeedbackProvider* GetStreamFeedbackProvider() override;
Sebastian Jansson19704ec2018-03-12 15:59:12 +010093 void RegisterTargetTransferRateObserver(
94 TargetTransferRateObserver* observer) override;
Sebastian Jansson97f61ea2018-02-21 13:01:55 +010095 void OnNetworkRouteChanged(const std::string& transport_name,
96 const rtc::NetworkRoute& network_route) override;
Sebastian Janssone4be6da2018-02-15 16:51:41 +010097 void OnNetworkAvailability(bool network_available) override;
Sebastian Janssone4be6da2018-02-15 16:51:41 +010098 RtcpBandwidthObserver* GetBandwidthObserver() override;
Sebastian Janssone4be6da2018-02-15 16:51:41 +010099 int64_t GetPacerQueuingDelayMs() const override;
Erik Språng425d6aa2019-07-29 16:38:27 +0200100 absl::optional<Timestamp> GetFirstPacketTime() const override;
Sebastian Janssone4be6da2018-02-15 16:51:41 +0100101 void EnablePeriodicAlrProbing(bool enable) override;
102 void OnSentPacket(const rtc::SentPacket& sent_packet) override;
Sebastian Jansson607a6f12019-06-13 17:48:53 +0200103 void OnReceivedPacket(const ReceivedPacket& packet_msg) override;
nissecae45d02017-04-24 05:53:20 -0700104
Sebastian Jansson97f61ea2018-02-21 13:01:55 +0100105 void SetSdpBitrateParameters(const BitrateConstraints& constraints) override;
Yves Gerey665174f2018-06-19 15:03:05 +0200106 void SetClientBitratePreferences(const BitrateSettings& preferences) override;
Sebastian Jansson97f61ea2018-02-21 13:01:55 +0100107
Stefan Holmer64be7fa2018-10-04 15:21:55 +0200108 void OnTransportOverheadChanged(
Christoffer Rodbrob0ca5192020-03-26 09:22:24 +0100109 size_t transport_overhead_bytes_per_packet) override;
Stefan Holmer64be7fa2018-10-04 15:21:55 +0200110
Erik Språngaa59eca2019-07-24 14:52:55 +0200111 void AccountForAudioPacketsInPacedSender(bool account_for_audio) override;
Sebastian Janssonc3eb9fd2020-01-29 17:42:52 +0100112 void IncludeOverheadInPacedSender() override;
Erik Språng7703f232020-09-14 11:03:13 +0200113 void EnsureStarted() override;
Erik Språngaa59eca2019-07-24 14:52:55 +0200114
Sebastian Jansson87609be2018-12-05 17:35:35 +0100115 // Implements RtcpBandwidthObserver interface
116 void OnReceivedEstimatedBitrate(uint32_t bitrate) override;
117 void OnReceivedRtcpReceiverReport(const ReportBlockList& report_blocks,
118 int64_t rtt,
119 int64_t now_ms) override;
120
121 // Implements TransportFeedbackObserver interface
Erik Språng30a276b2019-04-23 12:00:11 +0200122 void OnAddPacket(const RtpPacketSendInfo& packet_info) override;
Sebastian Jansson87609be2018-12-05 17:35:35 +0100123 void OnTransportFeedback(const rtcp::TransportFeedback& feedback) override;
124
Sebastian Janssone1795f42019-07-24 11:38:03 +0200125 // Implements NetworkStateEstimateObserver interface
126 void OnRemoteNetworkEstimate(NetworkStateEstimate estimate) override;
127
nissecae45d02017-04-24 05:53:20 -0700128 private:
Sebastian Jansson87609be2018-12-05 17:35:35 +0100129 void MaybeCreateControllers() RTC_RUN_ON(task_queue_);
130 void UpdateInitialConstraints(TargetRateConstraints new_contraints)
131 RTC_RUN_ON(task_queue_);
132
133 void StartProcessPeriodicTasks() RTC_RUN_ON(task_queue_);
134 void UpdateControllerWithTimeInterval() RTC_RUN_ON(task_queue_);
Sebastian Jansson87609be2018-12-05 17:35:35 +0100135
Christoffer Rodbro6404cdd2020-03-26 20:37:21 +0100136 absl::optional<BitrateConstraints> ApplyOrLiftRelayCap(bool is_relayed);
137 bool IsRelevantRouteChange(const rtc::NetworkRoute& old_route,
138 const rtc::NetworkRoute& new_route) const;
Christoffer Rodbrob0ca5192020-03-26 09:22:24 +0100139 void UpdateBitrateConstraints(const BitrateConstraints& updated);
Sebastian Jansson87609be2018-12-05 17:35:35 +0100140 void UpdateStreamsConfig() RTC_RUN_ON(task_queue_);
Sebastian Jansson87609be2018-12-05 17:35:35 +0100141 void OnReceivedRtcpReceiverReportBlocks(const ReportBlockList& report_blocks,
142 int64_t now_ms)
143 RTC_RUN_ON(task_queue_);
Sebastian Jansson16180952018-12-12 16:49:10 +0100144 void PostUpdates(NetworkControlUpdate update) RTC_RUN_ON(task_queue_);
145 void UpdateControlState() RTC_RUN_ON(task_queue_);
Erik Språng425d6aa2019-07-29 16:38:27 +0200146 RtpPacketPacer* pacer();
147 const RtpPacketPacer* pacer() const;
Sebastian Jansson87609be2018-12-05 17:35:35 +0100148
Sebastian Janssonaa01f272019-01-30 11:28:59 +0100149 Clock* const clock_;
Sebastian Jansson166b45d2019-05-13 11:57:42 +0200150 RtcEventLog* const event_log_;
nissecae45d02017-04-24 05:53:20 -0700151 PacketRouter packet_router_;
Stefan Holmer9416ef82018-07-19 10:34:38 +0200152 std::vector<std::unique_ptr<RtpVideoSenderInterface>> video_rtp_senders_;
Sebastian Jansson97f61ea2018-02-21 13:01:55 +0100153 RtpBitrateConfigurator bitrate_configurator_;
Sebastian Jansson91bb6672018-02-21 13:02:51 +0100154 std::map<std::string, rtc::NetworkRoute> network_routes_;
Erik Språng7703f232020-09-14 11:03:13 +0200155 bool process_thread_started_;
Sebastian Janssonc33c0fc2018-02-22 11:10:18 +0100156 const std::unique_ptr<ProcessThread> process_thread_;
Erik Språng4314a492019-11-26 17:48:49 +0100157 const bool use_task_queue_pacer_;
158 std::unique_ptr<PacedSender> process_thread_pacer_;
159 std::unique_ptr<TaskQueuePacedSender> task_queue_pacer_;
Sebastian Jansson87609be2018-12-05 17:35:35 +0100160
161 TargetTransferRateObserver* observer_ RTC_GUARDED_BY(task_queue_);
JT Tehea992f82020-01-15 18:24:20 +0000162 TransportFeedbackDemuxer feedback_demuxer_;
Sebastian Jansson87609be2018-12-05 17:35:35 +0100163
Sebastian Jansson658f1812020-01-16 10:59:28 +0100164 TransportFeedbackAdapter transport_feedback_adapter_
165 RTC_GUARDED_BY(task_queue_);
Sebastian Jansson87609be2018-12-05 17:35:35 +0100166
167 NetworkControllerFactoryInterface* const controller_factory_override_
168 RTC_PT_GUARDED_BY(task_queue_);
169 const std::unique_ptr<NetworkControllerFactoryInterface>
170 controller_factory_fallback_ RTC_PT_GUARDED_BY(task_queue_);
171
172 std::unique_ptr<CongestionControlHandler> control_handler_
173 RTC_GUARDED_BY(task_queue_) RTC_PT_GUARDED_BY(task_queue_);
174
175 std::unique_ptr<NetworkControllerInterface> controller_
176 RTC_GUARDED_BY(task_queue_) RTC_PT_GUARDED_BY(task_queue_);
177
178 TimeDelta process_interval_ RTC_GUARDED_BY(task_queue_);
179
180 std::map<uint32_t, RTCPReportBlock> last_report_blocks_
181 RTC_GUARDED_BY(task_queue_);
182 Timestamp last_report_block_time_ RTC_GUARDED_BY(task_queue_);
183
184 NetworkControllerConfig initial_config_ RTC_GUARDED_BY(task_queue_);
185 StreamsConfig streams_config_ RTC_GUARDED_BY(task_queue_);
186
187 const bool reset_feedback_on_route_change_;
188 const bool send_side_bwe_with_overhead_;
Christoffer Rodbroc610e262019-01-08 10:49:19 +0100189 const bool add_pacing_to_cwin_;
Christoffer Rodbro6404cdd2020-03-26 20:37:21 +0100190 FieldTrialParameter<DataRate> relay_bandwidth_cap_;
Sebastian Jansson658f1812020-01-16 10:59:28 +0100191
192 size_t transport_overhead_bytes_per_packet_ RTC_GUARDED_BY(task_queue_);
Sebastian Jansson87609be2018-12-05 17:35:35 +0100193 bool network_available_ RTC_GUARDED_BY(task_queue_);
Sebastian Janssonecb68972019-01-18 10:30:54 +0100194 RepeatingTaskHandle pacer_queue_update_task_ RTC_GUARDED_BY(task_queue_);
195 RepeatingTaskHandle controller_task_ RTC_GUARDED_BY(task_queue_);
Sebastian Jansson87609be2018-12-05 17:35:35 +0100196
Sebastian Jansson658f1812020-01-16 10:59:28 +0100197 // Protected by internal locks.
Stefan Holmerdbdb3a02018-07-17 16:03:46 +0200198 RateLimiter retransmission_rate_limiter_;
199
Sebastian Janssone6256052018-05-04 14:08:15 +0200200 // TODO(perkj): |task_queue_| is supposed to replace |process_thread_|.
201 // |task_queue_| is defined last to ensure all pending tasks are cancelled
202 // and deleted before any other members.
203 rtc::TaskQueue task_queue_;
nissecae45d02017-04-24 05:53:20 -0700204 RTC_DISALLOW_COPY_AND_ASSIGN(RtpTransportControllerSend);
nisseb8f9a322017-03-27 05:36:15 -0700205};
206
207} // namespace webrtc
208
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200209#endif // CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_