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