nisse | b8f9a32 | 2017-03-27 05:36:15 -0700 | [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 06:47:31 +0200 | [diff] [blame] | 11 | #ifndef CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_ |
| 12 | #define CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_ |
nisse | b8f9a32 | 2017-03-27 05:36:15 -0700 | [diff] [blame] | 13 | |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 14 | #include <atomic> |
Sebastian Jansson | 91bb667 | 2018-02-21 13:02:51 +0100 | [diff] [blame] | 15 | #include <map> |
Sebastian Jansson | c33c0fc | 2018-02-22 11:10:18 +0100 | [diff] [blame] | 16 | #include <memory> |
Sebastian Jansson | 97f61ea | 2018-02-21 13:01:55 +0100 | [diff] [blame] | 17 | #include <string> |
Stefan Holmer | dbdb3a0 | 2018-07-17 16:03:46 +0200 | [diff] [blame] | 18 | #include <vector> |
Sebastian Jansson | 97f61ea | 2018-02-21 13:01:55 +0100 | [diff] [blame] | 19 | |
Ying Wang | 0810a7c | 2019-04-10 13:48:24 +0200 | [diff] [blame] | 20 | #include "api/network_state_predictor.h" |
Sebastian Jansson | dfce03a | 2018-05-18 18:05:10 +0200 | [diff] [blame] | 21 | #include "api/transport/network_control.h" |
Sebastian Jansson | 97f61ea | 2018-02-21 13:01:55 +0100 | [diff] [blame] | 22 | #include "call/rtp_bitrate_configurator.h" |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 23 | #include "call/rtp_transport_controller_send_interface.h" |
Stefan Holmer | 9416ef8 | 2018-07-19 10:34:38 +0200 | [diff] [blame] | 24 | #include "call/rtp_video_sender.h" |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 25 | #include "modules/congestion_controller/rtp/control_handler.h" |
| 26 | #include "modules/congestion_controller/rtp/transport_feedback_adapter.h" |
Niels Möller | fd6c091 | 2017-10-31 10:19:10 +0100 | [diff] [blame] | 27 | #include "modules/pacing/packet_router.h" |
Sebastian Jansson | c33c0fc | 2018-02-22 11:10:18 +0100 | [diff] [blame] | 28 | #include "modules/utility/include/process_thread.h" |
Steve Anton | 10542f2 | 2019-01-11 09:11:00 -0800 | [diff] [blame] | 29 | #include "rtc_base/constructor_magic.h" |
| 30 | #include "rtc_base/network_route.h" |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 31 | #include "rtc_base/race_checker.h" |
Sebastian Jansson | e625605 | 2018-05-04 14:08:15 +0200 | [diff] [blame] | 32 | #include "rtc_base/task_queue.h" |
Sebastian Jansson | ecb6897 | 2019-01-18 10:30:54 +0100 | [diff] [blame] | 33 | #include "rtc_base/task_utils/repeating_task.h" |
nisse | cae45d0 | 2017-04-24 05:53:20 -0700 | [diff] [blame] | 34 | |
nisse | b8f9a32 | 2017-03-27 05:36:15 -0700 | [diff] [blame] | 35 | namespace webrtc { |
nisse | cae45d0 | 2017-04-24 05:53:20 -0700 | [diff] [blame] | 36 | class Clock; |
Benjamin Wright | 192eeec | 2018-10-17 17:27:25 -0700 | [diff] [blame] | 37 | class FrameEncryptorInterface; |
nisse | cae45d0 | 2017-04-24 05:53:20 -0700 | [diff] [blame] | 38 | class RtcEventLog; |
nisse | b8f9a32 | 2017-03-27 05:36:15 -0700 | [diff] [blame] | 39 | |
nisse | cae45d0 | 2017-04-24 05:53:20 -0700 | [diff] [blame] | 40 | // TODO(nisse): When we get the underlying transports here, we should |
| 41 | // have one object implementing RtpTransportControllerSendInterface |
| 42 | // per transport, sharing the same congestion controller. |
Sebastian Jansson | 317a522 | 2018-03-16 15:36:37 +0100 | [diff] [blame] | 43 | class RtpTransportControllerSend final |
| 44 | : public RtpTransportControllerSendInterface, |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 45 | public RtcpBandwidthObserver, |
Sebastian Jansson | e1795f4 | 2019-07-24 11:38:03 +0200 | [diff] [blame] | 46 | public TransportFeedbackObserver, |
| 47 | public NetworkStateEstimateObserver { |
nisse | b8f9a32 | 2017-03-27 05:36:15 -0700 | [diff] [blame] | 48 | public: |
Sebastian Jansson | dfce03a | 2018-05-18 18:05:10 +0200 | [diff] [blame] | 49 | RtpTransportControllerSend( |
| 50 | Clock* clock, |
| 51 | RtcEventLog* event_log, |
Ying Wang | 0810a7c | 2019-04-10 13:48:24 +0200 | [diff] [blame] | 52 | NetworkStatePredictorFactoryInterface* predictor_factory, |
Sebastian Jansson | dfce03a | 2018-05-18 18:05:10 +0200 | [diff] [blame] | 53 | NetworkControllerFactoryInterface* controller_factory, |
Sebastian Jansson | ed50e6c | 2019-03-01 14:45:21 +0100 | [diff] [blame] | 54 | const BitrateConstraints& bitrate_config, |
| 55 | std::unique_ptr<ProcessThread> process_thread, |
| 56 | TaskQueueFactory* task_queue_factory); |
Sebastian Jansson | 97f61ea | 2018-02-21 13:01:55 +0100 | [diff] [blame] | 57 | ~RtpTransportControllerSend() override; |
Sebastian Jansson | 19704ec | 2018-03-12 15:59:12 +0100 | [diff] [blame] | 58 | |
Stefan Holmer | 9416ef8 | 2018-07-19 10:34:38 +0200 | [diff] [blame] | 59 | RtpVideoSenderInterface* CreateRtpVideoSender( |
Stefan Holmer | dbdb3a0 | 2018-07-17 16:03:46 +0200 | [diff] [blame] | 60 | std::map<uint32_t, RtpState> suspended_ssrcs, |
| 61 | const std::map<uint32_t, RtpPayloadState>& |
| 62 | states, // move states into RtpTransportControllerSend |
| 63 | const RtpConfig& rtp_config, |
Jiawei Ou | 5571812 | 2018-11-09 13:17:39 -0800 | [diff] [blame] | 64 | int rtcp_report_interval_ms, |
Stefan Holmer | dbdb3a0 | 2018-07-17 16:03:46 +0200 | [diff] [blame] | 65 | Transport* send_transport, |
| 66 | const RtpSenderObservers& observers, |
Stefan Holmer | 64be7fa | 2018-10-04 15:21:55 +0200 | [diff] [blame] | 67 | RtcEventLog* event_log, |
Benjamin Wright | 192eeec | 2018-10-17 17:27:25 -0700 | [diff] [blame] | 68 | std::unique_ptr<FecController> fec_controller, |
| 69 | const RtpSenderFrameEncryptionConfig& frame_encryption_config) override; |
Stefan Holmer | 9416ef8 | 2018-07-19 10:34:38 +0200 | [diff] [blame] | 70 | void DestroyRtpVideoSender( |
| 71 | RtpVideoSenderInterface* rtp_video_sender) override; |
Stefan Holmer | dbdb3a0 | 2018-07-17 16:03:46 +0200 | [diff] [blame] | 72 | |
nisse | cae45d0 | 2017-04-24 05:53:20 -0700 | [diff] [blame] | 73 | // Implements RtpTransportControllerSendInterface |
Sebastian Jansson | e625605 | 2018-05-04 14:08:15 +0200 | [diff] [blame] | 74 | rtc::TaskQueue* GetWorkerQueue() override; |
nisse | 76e62b0 | 2017-05-31 02:24:52 -0700 | [diff] [blame] | 75 | PacketRouter* packet_router() override; |
Sebastian Jansson | 4c1ffb8 | 2018-02-15 16:51:58 +0100 | [diff] [blame] | 76 | |
Sebastian Jansson | e1795f4 | 2019-07-24 11:38:03 +0200 | [diff] [blame] | 77 | NetworkStateEstimateObserver* network_state_estimate_observer() override; |
nisse | 76e62b0 | 2017-05-31 02:24:52 -0700 | [diff] [blame] | 78 | TransportFeedbackObserver* transport_feedback_observer() override; |
Erik Språng | aa59eca | 2019-07-24 14:52:55 +0200 | [diff] [blame^] | 79 | RtpPacketSender* packet_sender() override; |
sprang | db2a9fc | 2017-08-09 06:42:32 -0700 | [diff] [blame] | 80 | |
Stefan Holmer | 5c8942a | 2017-08-22 16:16:44 +0200 | [diff] [blame] | 81 | void SetAllocatedSendBitrateLimits(int min_send_bitrate_bps, |
philipel | 832b1c8 | 2018-02-28 17:04:18 +0100 | [diff] [blame] | 82 | int max_padding_bitrate_bps, |
philipel | db4fa4b | 2018-03-06 18:29:22 +0100 | [diff] [blame] | 83 | int max_total_bitrate_bps) override; |
Stefan Holmer | 5c8942a | 2017-08-22 16:16:44 +0200 | [diff] [blame] | 84 | |
Sebastian Jansson | 4c1ffb8 | 2018-02-15 16:51:58 +0100 | [diff] [blame] | 85 | void SetPacingFactor(float pacing_factor) override; |
| 86 | void SetQueueTimeLimit(int limit_ms) override; |
Sebastian Jansson | e4be6da | 2018-02-15 16:51:41 +0100 | [diff] [blame] | 87 | void RegisterPacketFeedbackObserver( |
| 88 | PacketFeedbackObserver* observer) override; |
| 89 | void DeRegisterPacketFeedbackObserver( |
| 90 | PacketFeedbackObserver* observer) override; |
Sebastian Jansson | 19704ec | 2018-03-12 15:59:12 +0100 | [diff] [blame] | 91 | void RegisterTargetTransferRateObserver( |
| 92 | TargetTransferRateObserver* observer) override; |
Sebastian Jansson | 97f61ea | 2018-02-21 13:01:55 +0100 | [diff] [blame] | 93 | void OnNetworkRouteChanged(const std::string& transport_name, |
| 94 | const rtc::NetworkRoute& network_route) override; |
Sebastian Jansson | e4be6da | 2018-02-15 16:51:41 +0100 | [diff] [blame] | 95 | void OnNetworkAvailability(bool network_available) override; |
Sebastian Jansson | e4be6da | 2018-02-15 16:51:41 +0100 | [diff] [blame] | 96 | RtcpBandwidthObserver* GetBandwidthObserver() override; |
Sebastian Jansson | e4be6da | 2018-02-15 16:51:41 +0100 | [diff] [blame] | 97 | int64_t GetPacerQueuingDelayMs() const override; |
| 98 | int64_t GetFirstPacketTimeMs() const override; |
Sebastian Jansson | e4be6da | 2018-02-15 16:51:41 +0100 | [diff] [blame] | 99 | void EnablePeriodicAlrProbing(bool enable) override; |
| 100 | void OnSentPacket(const rtc::SentPacket& sent_packet) override; |
Sebastian Jansson | 607a6f1 | 2019-06-13 17:48:53 +0200 | [diff] [blame] | 101 | void OnReceivedPacket(const ReceivedPacket& packet_msg) override; |
nisse | cae45d0 | 2017-04-24 05:53:20 -0700 | [diff] [blame] | 102 | |
Sebastian Jansson | 97f61ea | 2018-02-21 13:01:55 +0100 | [diff] [blame] | 103 | void SetSdpBitrateParameters(const BitrateConstraints& constraints) override; |
Yves Gerey | 665174f | 2018-06-19 15:03:05 +0200 | [diff] [blame] | 104 | void SetClientBitratePreferences(const BitrateSettings& preferences) override; |
Sebastian Jansson | 97f61ea | 2018-02-21 13:01:55 +0100 | [diff] [blame] | 105 | |
Stefan Holmer | 64be7fa | 2018-10-04 15:21:55 +0200 | [diff] [blame] | 106 | void OnTransportOverheadChanged( |
| 107 | size_t transport_overhead_per_packet) override; |
| 108 | |
Erik Språng | aa59eca | 2019-07-24 14:52:55 +0200 | [diff] [blame^] | 109 | void AccountForAudioPacketsInPacedSender(bool account_for_audio) override; |
| 110 | |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 111 | // Implements RtcpBandwidthObserver interface |
| 112 | void OnReceivedEstimatedBitrate(uint32_t bitrate) override; |
| 113 | void OnReceivedRtcpReceiverReport(const ReportBlockList& report_blocks, |
| 114 | int64_t rtt, |
| 115 | int64_t now_ms) override; |
| 116 | |
| 117 | // Implements TransportFeedbackObserver interface |
Erik Språng | 30a276b | 2019-04-23 12:00:11 +0200 | [diff] [blame] | 118 | void OnAddPacket(const RtpPacketSendInfo& packet_info) override; |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 119 | void OnTransportFeedback(const rtcp::TransportFeedback& feedback) override; |
| 120 | |
Sebastian Jansson | e1795f4 | 2019-07-24 11:38:03 +0200 | [diff] [blame] | 121 | // Implements NetworkStateEstimateObserver interface |
| 122 | void OnRemoteNetworkEstimate(NetworkStateEstimate estimate) override; |
| 123 | |
nisse | cae45d0 | 2017-04-24 05:53:20 -0700 | [diff] [blame] | 124 | private: |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 125 | void MaybeCreateControllers() RTC_RUN_ON(task_queue_); |
| 126 | void UpdateInitialConstraints(TargetRateConstraints new_contraints) |
| 127 | RTC_RUN_ON(task_queue_); |
| 128 | |
| 129 | void StartProcessPeriodicTasks() RTC_RUN_ON(task_queue_); |
| 130 | void UpdateControllerWithTimeInterval() RTC_RUN_ON(task_queue_); |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 131 | |
| 132 | void UpdateStreamsConfig() RTC_RUN_ON(task_queue_); |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 133 | void OnReceivedRtcpReceiverReportBlocks(const ReportBlockList& report_blocks, |
| 134 | int64_t now_ms) |
| 135 | RTC_RUN_ON(task_queue_); |
Sebastian Jansson | 1618095 | 2018-12-12 16:49:10 +0100 | [diff] [blame] | 136 | void PostUpdates(NetworkControlUpdate update) RTC_RUN_ON(task_queue_); |
| 137 | void UpdateControlState() RTC_RUN_ON(task_queue_); |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 138 | |
Sebastian Jansson | aa01f27 | 2019-01-30 11:28:59 +0100 | [diff] [blame] | 139 | Clock* const clock_; |
Sebastian Jansson | 166b45d | 2019-05-13 11:57:42 +0200 | [diff] [blame] | 140 | RtcEventLog* const event_log_; |
Sebastian Jansson | df88cc0 | 2019-04-15 15:42:25 +0200 | [diff] [blame] | 141 | const FieldTrialBasedConfig trial_based_config_; |
nisse | cae45d0 | 2017-04-24 05:53:20 -0700 | [diff] [blame] | 142 | PacketRouter packet_router_; |
Stefan Holmer | 9416ef8 | 2018-07-19 10:34:38 +0200 | [diff] [blame] | 143 | std::vector<std::unique_ptr<RtpVideoSenderInterface>> video_rtp_senders_; |
Stefan Holmer | 5c8942a | 2017-08-22 16:16:44 +0200 | [diff] [blame] | 144 | PacedSender pacer_; |
Sebastian Jansson | 97f61ea | 2018-02-21 13:01:55 +0100 | [diff] [blame] | 145 | RtpBitrateConfigurator bitrate_configurator_; |
Sebastian Jansson | 91bb667 | 2018-02-21 13:02:51 +0100 | [diff] [blame] | 146 | std::map<std::string, rtc::NetworkRoute> network_routes_; |
Sebastian Jansson | c33c0fc | 2018-02-22 11:10:18 +0100 | [diff] [blame] | 147 | const std::unique_ptr<ProcessThread> process_thread_; |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 148 | |
| 149 | TargetTransferRateObserver* observer_ RTC_GUARDED_BY(task_queue_); |
| 150 | |
| 151 | // TODO(srte): Move all access to feedback adapter to task queue. |
| 152 | TransportFeedbackAdapter transport_feedback_adapter_; |
| 153 | |
| 154 | NetworkControllerFactoryInterface* const controller_factory_override_ |
| 155 | RTC_PT_GUARDED_BY(task_queue_); |
| 156 | const std::unique_ptr<NetworkControllerFactoryInterface> |
| 157 | controller_factory_fallback_ RTC_PT_GUARDED_BY(task_queue_); |
| 158 | |
| 159 | std::unique_ptr<CongestionControlHandler> control_handler_ |
| 160 | RTC_GUARDED_BY(task_queue_) RTC_PT_GUARDED_BY(task_queue_); |
| 161 | |
| 162 | std::unique_ptr<NetworkControllerInterface> controller_ |
| 163 | RTC_GUARDED_BY(task_queue_) RTC_PT_GUARDED_BY(task_queue_); |
| 164 | |
| 165 | TimeDelta process_interval_ RTC_GUARDED_BY(task_queue_); |
| 166 | |
| 167 | std::map<uint32_t, RTCPReportBlock> last_report_blocks_ |
| 168 | RTC_GUARDED_BY(task_queue_); |
| 169 | Timestamp last_report_block_time_ RTC_GUARDED_BY(task_queue_); |
| 170 | |
| 171 | NetworkControllerConfig initial_config_ RTC_GUARDED_BY(task_queue_); |
| 172 | StreamsConfig streams_config_ RTC_GUARDED_BY(task_queue_); |
| 173 | |
| 174 | const bool reset_feedback_on_route_change_; |
| 175 | const bool send_side_bwe_with_overhead_; |
Christoffer Rodbro | c610e26 | 2019-01-08 10:49:19 +0100 | [diff] [blame] | 176 | const bool add_pacing_to_cwin_; |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 177 | // Transport overhead is written by OnNetworkRouteChanged and read by |
| 178 | // AddPacket. |
| 179 | // TODO(srte): Remove atomic when feedback adapter runs on task queue. |
| 180 | std::atomic<size_t> transport_overhead_bytes_per_packet_; |
| 181 | bool network_available_ RTC_GUARDED_BY(task_queue_); |
Sebastian Jansson | ecb6897 | 2019-01-18 10:30:54 +0100 | [diff] [blame] | 182 | RepeatingTaskHandle pacer_queue_update_task_ RTC_GUARDED_BY(task_queue_); |
| 183 | RepeatingTaskHandle controller_task_ RTC_GUARDED_BY(task_queue_); |
Sebastian Jansson | 87609be | 2018-12-05 17:35:35 +0100 | [diff] [blame] | 184 | // Protects access to last_packet_feedback_vector_ in feedback adapter. |
| 185 | // TODO(srte): Remove this checker when feedback adapter runs on task queue. |
| 186 | rtc::RaceChecker worker_race_; |
| 187 | |
Stefan Holmer | dbdb3a0 | 2018-07-17 16:03:46 +0200 | [diff] [blame] | 188 | RateLimiter retransmission_rate_limiter_; |
| 189 | |
Sebastian Jansson | e625605 | 2018-05-04 14:08:15 +0200 | [diff] [blame] | 190 | // TODO(perkj): |task_queue_| is supposed to replace |process_thread_|. |
| 191 | // |task_queue_| is defined last to ensure all pending tasks are cancelled |
| 192 | // and deleted before any other members. |
| 193 | rtc::TaskQueue task_queue_; |
nisse | cae45d0 | 2017-04-24 05:53:20 -0700 | [diff] [blame] | 194 | RTC_DISALLOW_COPY_AND_ASSIGN(RtpTransportControllerSend); |
nisse | b8f9a32 | 2017-03-27 05:36:15 -0700 | [diff] [blame] | 195 | }; |
| 196 | |
| 197 | } // namespace webrtc |
| 198 | |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 199 | #endif // CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_ |