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