nisse | b8f9a32 | 2017-03-27 12:36:15 | [diff] [blame] | 1 | /* |
| 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 Bonadei | 92ea95e | 2017-09-15 04:47:31 | [diff] [blame] | 11 | #ifndef CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_ |
| 12 | #define CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_ |
nisse | b8f9a32 | 2017-03-27 12:36:15 | [diff] [blame] | 13 | |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 14 | #include <atomic> |
Sebastian Jansson | 91bb667 | 2018-02-21 12:02:51 | [diff] [blame] | 15 | #include <map> |
Sebastian Jansson | c33c0fc | 2018-02-22 10:10:18 | [diff] [blame] | 16 | #include <memory> |
Sebastian Jansson | 97f61ea | 2018-02-21 12:01:55 | [diff] [blame] | 17 | #include <string> |
Stefan Holmer | dbdb3a0 | 2018-07-17 14:03:46 | [diff] [blame] | 18 | #include <vector> |
Sebastian Jansson | 97f61ea | 2018-02-21 12:01:55 | [diff] [blame] | 19 | |
Ying Wang | 0810a7c | 2019-04-10 11:48:24 | [diff] [blame] | 20 | #include "api/network_state_predictor.h" |
Sebastian Jansson | dfce03a | 2018-05-18 16:05:10 | [diff] [blame] | 21 | #include "api/transport/network_control.h" |
Christoffer Rodbro | 6404cdd | 2020-03-26 19:37:21 | [diff] [blame] | 22 | #include "api/units/data_rate.h" |
Sebastian Jansson | 97f61ea | 2018-02-21 12:01:55 | [diff] [blame] | 23 | #include "call/rtp_bitrate_configurator.h" |
Mirko Bonadei | 92ea95e | 2017-09-15 04:47:31 | [diff] [blame] | 24 | #include "call/rtp_transport_controller_send_interface.h" |
Stefan Holmer | 9416ef8 | 2018-07-19 08:34:38 | [diff] [blame] | 25 | #include "call/rtp_video_sender.h" |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 26 | #include "modules/congestion_controller/rtp/control_handler.h" |
| 27 | #include "modules/congestion_controller/rtp/transport_feedback_adapter.h" |
JT Teh | ea992f8 | 2020-01-15 18:24:20 | [diff] [blame] | 28 | #include "modules/congestion_controller/rtp/transport_feedback_demuxer.h" |
Erik Språng | 4314a49 | 2019-11-26 16:48:49 | [diff] [blame] | 29 | #include "modules/pacing/paced_sender.h" |
Niels Möller | fd6c091 | 2017-10-31 09:19:10 | [diff] [blame] | 30 | #include "modules/pacing/packet_router.h" |
Erik Språng | 425d6aa | 2019-07-29 14:38:27 | [diff] [blame] | 31 | #include "modules/pacing/rtp_packet_pacer.h" |
Erik Språng | 4314a49 | 2019-11-26 16:48:49 | [diff] [blame] | 32 | #include "modules/pacing/task_queue_paced_sender.h" |
Sebastian Jansson | c33c0fc | 2018-02-22 10:10:18 | [diff] [blame] | 33 | #include "modules/utility/include/process_thread.h" |
Steve Anton | 10542f2 | 2019-01-11 17:11:00 | [diff] [blame] | 34 | #include "rtc_base/constructor_magic.h" |
| 35 | #include "rtc_base/network_route.h" |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 36 | #include "rtc_base/race_checker.h" |
Sebastian Jansson | e625605 | 2018-05-04 12:08:15 | [diff] [blame] | 37 | #include "rtc_base/task_queue.h" |
Sebastian Jansson | ecb6897 | 2019-01-18 09:30:54 | [diff] [blame] | 38 | #include "rtc_base/task_utils/repeating_task.h" |
nisse | cae45d0 | 2017-04-24 12:53:20 | [diff] [blame] | 39 | |
nisse | b8f9a32 | 2017-03-27 12:36:15 | [diff] [blame] | 40 | namespace webrtc { |
nisse | cae45d0 | 2017-04-24 12:53:20 | [diff] [blame] | 41 | class Clock; |
Benjamin Wright | 192eeec | 2018-10-18 00:27:25 | [diff] [blame] | 42 | class FrameEncryptorInterface; |
nisse | cae45d0 | 2017-04-24 12:53:20 | [diff] [blame] | 43 | class RtcEventLog; |
nisse | b8f9a32 | 2017-03-27 12:36:15 | [diff] [blame] | 44 | |
nisse | cae45d0 | 2017-04-24 12:53:20 | [diff] [blame] | 45 | // 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 Jansson | 317a522 | 2018-03-16 14:36:37 | [diff] [blame] | 48 | class RtpTransportControllerSend final |
| 49 | : public RtpTransportControllerSendInterface, |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 50 | public RtcpBandwidthObserver, |
Sebastian Jansson | e1795f4 | 2019-07-24 09:38:03 | [diff] [blame] | 51 | public TransportFeedbackObserver, |
| 52 | public NetworkStateEstimateObserver { |
nisse | b8f9a32 | 2017-03-27 12:36:15 | [diff] [blame] | 53 | public: |
Sebastian Jansson | dfce03a | 2018-05-18 16:05:10 | [diff] [blame] | 54 | RtpTransportControllerSend( |
| 55 | Clock* clock, |
| 56 | RtcEventLog* event_log, |
Ying Wang | 0810a7c | 2019-04-10 11:48:24 | [diff] [blame] | 57 | NetworkStatePredictorFactoryInterface* predictor_factory, |
Sebastian Jansson | dfce03a | 2018-05-18 16:05:10 | [diff] [blame] | 58 | NetworkControllerFactoryInterface* controller_factory, |
Sebastian Jansson | ed50e6c | 2019-03-01 13:45:21 | [diff] [blame] | 59 | const BitrateConstraints& bitrate_config, |
| 60 | std::unique_ptr<ProcessThread> process_thread, |
Erik Språng | 662678d | 2019-11-15 16:18:52 | [diff] [blame] | 61 | TaskQueueFactory* task_queue_factory, |
| 62 | const WebRtcKeyValueConfig* trials); |
Sebastian Jansson | 97f61ea | 2018-02-21 12:01:55 | [diff] [blame] | 63 | ~RtpTransportControllerSend() override; |
Sebastian Jansson | 19704ec | 2018-03-12 14:59:12 | [diff] [blame] | 64 | |
Stefan Holmer | 9416ef8 | 2018-07-19 08:34:38 | [diff] [blame] | 65 | RtpVideoSenderInterface* CreateRtpVideoSender( |
Stefan Holmer | dbdb3a0 | 2018-07-17 14:03:46 | [diff] [blame] | 66 | 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 Ou | 5571812 | 2018-11-09 21:17:39 | [diff] [blame] | 70 | int rtcp_report_interval_ms, |
Stefan Holmer | dbdb3a0 | 2018-07-17 14:03:46 | [diff] [blame] | 71 | Transport* send_transport, |
| 72 | const RtpSenderObservers& observers, |
Stefan Holmer | 64be7fa | 2018-10-04 13:21:55 | [diff] [blame] | 73 | RtcEventLog* event_log, |
Benjamin Wright | 192eeec | 2018-10-18 00:27:25 | [diff] [blame] | 74 | std::unique_ptr<FecController> fec_controller, |
Marina Ciocea | e77912b | 2020-02-27 15:16:55 | [diff] [blame] | 75 | const RtpSenderFrameEncryptionConfig& frame_encryption_config, |
| 76 | rtc::scoped_refptr<FrameTransformerInterface> frame_transformer) override; |
Stefan Holmer | 9416ef8 | 2018-07-19 08:34:38 | [diff] [blame] | 77 | void DestroyRtpVideoSender( |
| 78 | RtpVideoSenderInterface* rtp_video_sender) override; |
Stefan Holmer | dbdb3a0 | 2018-07-17 14:03:46 | [diff] [blame] | 79 | |
nisse | cae45d0 | 2017-04-24 12:53:20 | [diff] [blame] | 80 | // Implements RtpTransportControllerSendInterface |
Sebastian Jansson | e625605 | 2018-05-04 12:08:15 | [diff] [blame] | 81 | rtc::TaskQueue* GetWorkerQueue() override; |
nisse | 76e62b0 | 2017-05-31 09:24:52 | [diff] [blame] | 82 | PacketRouter* packet_router() override; |
Sebastian Jansson | 4c1ffb8 | 2018-02-15 15:51:58 | [diff] [blame] | 83 | |
Sebastian Jansson | e1795f4 | 2019-07-24 09:38:03 | [diff] [blame] | 84 | NetworkStateEstimateObserver* network_state_estimate_observer() override; |
nisse | 76e62b0 | 2017-05-31 09:24:52 | [diff] [blame] | 85 | TransportFeedbackObserver* transport_feedback_observer() override; |
Erik Språng | aa59eca | 2019-07-24 12:52:55 | [diff] [blame] | 86 | RtpPacketSender* packet_sender() override; |
sprang | db2a9fc | 2017-08-09 13:42:32 | [diff] [blame] | 87 | |
Sebastian Jansson | 93b1ea2 | 2019-09-18 16:31:52 | [diff] [blame] | 88 | void SetAllocatedSendBitrateLimits(BitrateAllocationLimits limits) override; |
Stefan Holmer | 5c8942a | 2017-08-22 14:16:44 | [diff] [blame] | 89 | |
Sebastian Jansson | 4c1ffb8 | 2018-02-15 15:51:58 | [diff] [blame] | 90 | void SetPacingFactor(float pacing_factor) override; |
| 91 | void SetQueueTimeLimit(int limit_ms) override; |
Sebastian Jansson | f298855 | 2019-10-29 16:18:51 | [diff] [blame] | 92 | StreamFeedbackProvider* GetStreamFeedbackProvider() override; |
Sebastian Jansson | 19704ec | 2018-03-12 14:59:12 | [diff] [blame] | 93 | void RegisterTargetTransferRateObserver( |
| 94 | TargetTransferRateObserver* observer) override; |
Sebastian Jansson | 97f61ea | 2018-02-21 12:01:55 | [diff] [blame] | 95 | void OnNetworkRouteChanged(const std::string& transport_name, |
| 96 | const rtc::NetworkRoute& network_route) override; |
Sebastian Jansson | e4be6da | 2018-02-15 15:51:41 | [diff] [blame] | 97 | void OnNetworkAvailability(bool network_available) override; |
Sebastian Jansson | e4be6da | 2018-02-15 15:51:41 | [diff] [blame] | 98 | RtcpBandwidthObserver* GetBandwidthObserver() override; |
Sebastian Jansson | e4be6da | 2018-02-15 15:51:41 | [diff] [blame] | 99 | int64_t GetPacerQueuingDelayMs() const override; |
Erik Språng | 425d6aa | 2019-07-29 14:38:27 | [diff] [blame] | 100 | absl::optional<Timestamp> GetFirstPacketTime() const override; |
Sebastian Jansson | e4be6da | 2018-02-15 15:51:41 | [diff] [blame] | 101 | void EnablePeriodicAlrProbing(bool enable) override; |
| 102 | void OnSentPacket(const rtc::SentPacket& sent_packet) override; |
Sebastian Jansson | 607a6f1 | 2019-06-13 15:48:53 | [diff] [blame] | 103 | void OnReceivedPacket(const ReceivedPacket& packet_msg) override; |
nisse | cae45d0 | 2017-04-24 12:53:20 | [diff] [blame] | 104 | |
Sebastian Jansson | 97f61ea | 2018-02-21 12:01:55 | [diff] [blame] | 105 | void SetSdpBitrateParameters(const BitrateConstraints& constraints) override; |
Yves Gerey | 665174f | 2018-06-19 13:03:05 | [diff] [blame] | 106 | void SetClientBitratePreferences(const BitrateSettings& preferences) override; |
Sebastian Jansson | 97f61ea | 2018-02-21 12:01:55 | [diff] [blame] | 107 | |
Stefan Holmer | 64be7fa | 2018-10-04 13:21:55 | [diff] [blame] | 108 | void OnTransportOverheadChanged( |
Christoffer Rodbro | b0ca519 | 2020-03-26 08:22:24 | [diff] [blame] | 109 | size_t transport_overhead_bytes_per_packet) override; |
Stefan Holmer | 64be7fa | 2018-10-04 13:21:55 | [diff] [blame] | 110 | |
Erik Språng | aa59eca | 2019-07-24 12:52:55 | [diff] [blame] | 111 | void AccountForAudioPacketsInPacedSender(bool account_for_audio) override; |
Sebastian Jansson | c3eb9fd | 2020-01-29 16:42:52 | [diff] [blame] | 112 | void IncludeOverheadInPacedSender() override; |
Erik Språng | 7703f23 | 2020-09-14 09:03:13 | [diff] [blame] | 113 | void EnsureStarted() override; |
Erik Språng | aa59eca | 2019-07-24 12:52:55 | [diff] [blame] | 114 | |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 115 | // 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ång | 30a276b | 2019-04-23 10:00:11 | [diff] [blame] | 122 | void OnAddPacket(const RtpPacketSendInfo& packet_info) override; |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 123 | void OnTransportFeedback(const rtcp::TransportFeedback& feedback) override; |
| 124 | |
Sebastian Jansson | e1795f4 | 2019-07-24 09:38:03 | [diff] [blame] | 125 | // Implements NetworkStateEstimateObserver interface |
| 126 | void OnRemoteNetworkEstimate(NetworkStateEstimate estimate) override; |
| 127 | |
nisse | cae45d0 | 2017-04-24 12:53:20 | [diff] [blame] | 128 | private: |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 129 | 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 Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 135 | |
Christoffer Rodbro | 6404cdd | 2020-03-26 19:37:21 | [diff] [blame] | 136 | absl::optional<BitrateConstraints> ApplyOrLiftRelayCap(bool is_relayed); |
| 137 | bool IsRelevantRouteChange(const rtc::NetworkRoute& old_route, |
| 138 | const rtc::NetworkRoute& new_route) const; |
Christoffer Rodbro | b0ca519 | 2020-03-26 08:22:24 | [diff] [blame] | 139 | void UpdateBitrateConstraints(const BitrateConstraints& updated); |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 140 | void UpdateStreamsConfig() RTC_RUN_ON(task_queue_); |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 141 | void OnReceivedRtcpReceiverReportBlocks(const ReportBlockList& report_blocks, |
| 142 | int64_t now_ms) |
| 143 | RTC_RUN_ON(task_queue_); |
Sebastian Jansson | 1618095 | 2018-12-12 15:49:10 | [diff] [blame] | 144 | void PostUpdates(NetworkControlUpdate update) RTC_RUN_ON(task_queue_); |
| 145 | void UpdateControlState() RTC_RUN_ON(task_queue_); |
Erik Språng | 425d6aa | 2019-07-29 14:38:27 | [diff] [blame] | 146 | RtpPacketPacer* pacer(); |
| 147 | const RtpPacketPacer* pacer() const; |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 148 | |
Sebastian Jansson | aa01f27 | 2019-01-30 10:28:59 | [diff] [blame] | 149 | Clock* const clock_; |
Sebastian Jansson | 166b45d | 2019-05-13 09:57:42 | [diff] [blame] | 150 | RtcEventLog* const event_log_; |
nisse | cae45d0 | 2017-04-24 12:53:20 | [diff] [blame] | 151 | PacketRouter packet_router_; |
Stefan Holmer | 9416ef8 | 2018-07-19 08:34:38 | [diff] [blame] | 152 | std::vector<std::unique_ptr<RtpVideoSenderInterface>> video_rtp_senders_; |
Sebastian Jansson | 97f61ea | 2018-02-21 12:01:55 | [diff] [blame] | 153 | RtpBitrateConfigurator bitrate_configurator_; |
Sebastian Jansson | 91bb667 | 2018-02-21 12:02:51 | [diff] [blame] | 154 | std::map<std::string, rtc::NetworkRoute> network_routes_; |
Erik Språng | 7703f23 | 2020-09-14 09:03:13 | [diff] [blame] | 155 | bool process_thread_started_; |
Sebastian Jansson | c33c0fc | 2018-02-22 10:10:18 | [diff] [blame] | 156 | const std::unique_ptr<ProcessThread> process_thread_; |
Erik Språng | 4314a49 | 2019-11-26 16:48:49 | [diff] [blame] | 157 | const bool use_task_queue_pacer_; |
| 158 | std::unique_ptr<PacedSender> process_thread_pacer_; |
| 159 | std::unique_ptr<TaskQueuePacedSender> task_queue_pacer_; |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 160 | |
| 161 | TargetTransferRateObserver* observer_ RTC_GUARDED_BY(task_queue_); |
JT Teh | ea992f8 | 2020-01-15 18:24:20 | [diff] [blame] | 162 | TransportFeedbackDemuxer feedback_demuxer_; |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 163 | |
Sebastian Jansson | 658f181 | 2020-01-16 09:59:28 | [diff] [blame] | 164 | TransportFeedbackAdapter transport_feedback_adapter_ |
| 165 | RTC_GUARDED_BY(task_queue_); |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 166 | |
| 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 Rodbro | c610e26 | 2019-01-08 09:49:19 | [diff] [blame] | 189 | const bool add_pacing_to_cwin_; |
Christoffer Rodbro | 6404cdd | 2020-03-26 19:37:21 | [diff] [blame] | 190 | FieldTrialParameter<DataRate> relay_bandwidth_cap_; |
Sebastian Jansson | 658f181 | 2020-01-16 09:59:28 | [diff] [blame] | 191 | |
| 192 | size_t transport_overhead_bytes_per_packet_ RTC_GUARDED_BY(task_queue_); |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 193 | bool network_available_ RTC_GUARDED_BY(task_queue_); |
Sebastian Jansson | ecb6897 | 2019-01-18 09:30:54 | [diff] [blame] | 194 | RepeatingTaskHandle pacer_queue_update_task_ RTC_GUARDED_BY(task_queue_); |
| 195 | RepeatingTaskHandle controller_task_ RTC_GUARDED_BY(task_queue_); |
Sebastian Jansson | 87609be | 2018-12-05 16:35:35 | [diff] [blame] | 196 | |
Sebastian Jansson | 658f181 | 2020-01-16 09:59:28 | [diff] [blame] | 197 | // Protected by internal locks. |
Stefan Holmer | dbdb3a0 | 2018-07-17 14:03:46 | [diff] [blame] | 198 | RateLimiter retransmission_rate_limiter_; |
| 199 | |
Sebastian Jansson | e625605 | 2018-05-04 12:08:15 | [diff] [blame] | 200 | // 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_; |
nisse | cae45d0 | 2017-04-24 12:53:20 | [diff] [blame] | 204 | RTC_DISALLOW_COPY_AND_ASSIGN(RtpTransportControllerSend); |
nisse | b8f9a32 | 2017-03-27 12:36:15 | [diff] [blame] | 205 | }; |
| 206 | |
| 207 | } // namespace webrtc |
| 208 | |
Mirko Bonadei | 92ea95e | 2017-09-15 04:47:31 | [diff] [blame] | 209 | #endif // CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_ |