blob: 43dc1a00769a1eae0dc881ba1ef6519a11d0f646 [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"
Sebastian Jansson97f61ea2018-02-21 13:01:55 +010022#include "call/rtp_bitrate_configurator.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020023#include "call/rtp_transport_controller_send_interface.h"
Stefan Holmer9416ef82018-07-19 10:34:38 +020024#include "call/rtp_video_sender.h"
Sebastian Jansson87609be2018-12-05 17:35:35 +010025#include "modules/congestion_controller/rtp/control_handler.h"
26#include "modules/congestion_controller/rtp/transport_feedback_adapter.h"
Niels Möllerfd6c0912017-10-31 10:19:10 +010027#include "modules/pacing/packet_router.h"
Sebastian Janssonc33c0fc2018-02-22 11:10:18 +010028#include "modules/utility/include/process_thread.h"
Steve Anton10542f22019-01-11 09:11:00 -080029#include "rtc_base/constructor_magic.h"
30#include "rtc_base/network_route.h"
Sebastian Jansson87609be2018-12-05 17:35:35 +010031#include "rtc_base/race_checker.h"
Sebastian Janssone6256052018-05-04 14:08:15 +020032#include "rtc_base/task_queue.h"
Sebastian Janssonecb68972019-01-18 10:30:54 +010033#include "rtc_base/task_utils/repeating_task.h"
nissecae45d02017-04-24 05:53:20 -070034
nisseb8f9a322017-03-27 05:36:15 -070035namespace webrtc {
nissecae45d02017-04-24 05:53:20 -070036class Clock;
Benjamin Wright192eeec2018-10-17 17:27:25 -070037class FrameEncryptorInterface;
nissecae45d02017-04-24 05:53:20 -070038class RtcEventLog;
nisseb8f9a322017-03-27 05:36:15 -070039
nissecae45d02017-04-24 05:53:20 -070040// 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 Jansson317a5222018-03-16 15:36:37 +010043class RtpTransportControllerSend final
44 : public RtpTransportControllerSendInterface,
Sebastian Jansson87609be2018-12-05 17:35:35 +010045 public RtcpBandwidthObserver,
Sebastian Jansson87609be2018-12-05 17:35:35 +010046 public TransportFeedbackObserver {
nisseb8f9a322017-03-27 05:36:15 -070047 public:
Sebastian Janssondfce03a2018-05-18 18:05:10 +020048 RtpTransportControllerSend(
49 Clock* clock,
50 RtcEventLog* event_log,
Ying Wang0810a7c2019-04-10 13:48:24 +020051 NetworkStatePredictorFactoryInterface* predictor_factory,
Sebastian Janssondfce03a2018-05-18 18:05:10 +020052 NetworkControllerFactoryInterface* controller_factory,
Sebastian Janssoned50e6c2019-03-01 14:45:21 +010053 const BitrateConstraints& bitrate_config,
54 std::unique_ptr<ProcessThread> process_thread,
55 TaskQueueFactory* task_queue_factory);
Sebastian Jansson97f61ea2018-02-21 13:01:55 +010056 ~RtpTransportControllerSend() override;
Sebastian Jansson19704ec2018-03-12 15:59:12 +010057
Stefan Holmer9416ef82018-07-19 10:34:38 +020058 RtpVideoSenderInterface* CreateRtpVideoSender(
Stefan Holmerdbdb3a02018-07-17 16:03:46 +020059 std::map<uint32_t, RtpState> suspended_ssrcs,
60 const std::map<uint32_t, RtpPayloadState>&
61 states, // move states into RtpTransportControllerSend
62 const RtpConfig& rtp_config,
Jiawei Ou55718122018-11-09 13:17:39 -080063 int rtcp_report_interval_ms,
Stefan Holmerdbdb3a02018-07-17 16:03:46 +020064 Transport* send_transport,
65 const RtpSenderObservers& observers,
Stefan Holmer64be7fa2018-10-04 15:21:55 +020066 RtcEventLog* event_log,
Benjamin Wright192eeec2018-10-17 17:27:25 -070067 std::unique_ptr<FecController> fec_controller,
68 const RtpSenderFrameEncryptionConfig& frame_encryption_config) override;
Stefan Holmer9416ef82018-07-19 10:34:38 +020069 void DestroyRtpVideoSender(
70 RtpVideoSenderInterface* rtp_video_sender) override;
Stefan Holmerdbdb3a02018-07-17 16:03:46 +020071
nissecae45d02017-04-24 05:53:20 -070072 // Implements RtpTransportControllerSendInterface
Sebastian Janssone6256052018-05-04 14:08:15 +020073 rtc::TaskQueue* GetWorkerQueue() override;
nisse76e62b02017-05-31 02:24:52 -070074 PacketRouter* packet_router() override;
Sebastian Jansson4c1ffb82018-02-15 16:51:58 +010075
nisse76e62b02017-05-31 02:24:52 -070076 TransportFeedbackObserver* transport_feedback_observer() override;
77 RtpPacketSender* packet_sender() override;
sprangdb2a9fc2017-08-09 06:42:32 -070078
Stefan Holmer5c8942a2017-08-22 16:16:44 +020079 void SetAllocatedSendBitrateLimits(int min_send_bitrate_bps,
philipel832b1c82018-02-28 17:04:18 +010080 int max_padding_bitrate_bps,
philipeldb4fa4b2018-03-06 18:29:22 +010081 int max_total_bitrate_bps) override;
Stefan Holmer5c8942a2017-08-22 16:16:44 +020082
Sebastian Jansson4c1ffb82018-02-15 16:51:58 +010083 void SetPacingFactor(float pacing_factor) override;
84 void SetQueueTimeLimit(int limit_ms) override;
Sebastian Janssone4be6da2018-02-15 16:51:41 +010085 void RegisterPacketFeedbackObserver(
86 PacketFeedbackObserver* observer) override;
87 void DeRegisterPacketFeedbackObserver(
88 PacketFeedbackObserver* observer) override;
Sebastian Jansson19704ec2018-03-12 15:59:12 +010089 void RegisterTargetTransferRateObserver(
90 TargetTransferRateObserver* observer) override;
Sebastian Jansson97f61ea2018-02-21 13:01:55 +010091 void OnNetworkRouteChanged(const std::string& transport_name,
92 const rtc::NetworkRoute& network_route) override;
Sebastian Janssone4be6da2018-02-15 16:51:41 +010093 void OnNetworkAvailability(bool network_available) override;
Sebastian Janssone4be6da2018-02-15 16:51:41 +010094 RtcpBandwidthObserver* GetBandwidthObserver() override;
Sebastian Janssone4be6da2018-02-15 16:51:41 +010095 int64_t GetPacerQueuingDelayMs() const override;
96 int64_t GetFirstPacketTimeMs() const override;
Sebastian Janssone4be6da2018-02-15 16:51:41 +010097 void EnablePeriodicAlrProbing(bool enable) override;
98 void OnSentPacket(const rtc::SentPacket& sent_packet) override;
nissecae45d02017-04-24 05:53:20 -070099
Sebastian Jansson97f61ea2018-02-21 13:01:55 +0100100 void SetSdpBitrateParameters(const BitrateConstraints& constraints) override;
Yves Gerey665174f2018-06-19 15:03:05 +0200101 void SetClientBitratePreferences(const BitrateSettings& preferences) override;
Sebastian Jansson97f61ea2018-02-21 13:01:55 +0100102
Stefan Holmer64be7fa2018-10-04 15:21:55 +0200103 void OnTransportOverheadChanged(
104 size_t transport_overhead_per_packet) override;
105
Sebastian Jansson87609be2018-12-05 17:35:35 +0100106 // Implements RtcpBandwidthObserver interface
107 void OnReceivedEstimatedBitrate(uint32_t bitrate) override;
108 void OnReceivedRtcpReceiverReport(const ReportBlockList& report_blocks,
109 int64_t rtt,
110 int64_t now_ms) override;
111
112 // Implements TransportFeedbackObserver interface
113 void AddPacket(uint32_t ssrc,
114 uint16_t sequence_number,
115 size_t length,
116 const PacedPacketInfo& pacing_info) override;
117 void OnTransportFeedback(const rtcp::TransportFeedback& feedback) override;
118
nissecae45d02017-04-24 05:53:20 -0700119 private:
Sebastian Jansson87609be2018-12-05 17:35:35 +0100120 void MaybeCreateControllers() RTC_RUN_ON(task_queue_);
121 void UpdateInitialConstraints(TargetRateConstraints new_contraints)
122 RTC_RUN_ON(task_queue_);
123
124 void StartProcessPeriodicTasks() RTC_RUN_ON(task_queue_);
125 void UpdateControllerWithTimeInterval() RTC_RUN_ON(task_queue_);
Sebastian Jansson87609be2018-12-05 17:35:35 +0100126
127 void UpdateStreamsConfig() RTC_RUN_ON(task_queue_);
Sebastian Jansson87609be2018-12-05 17:35:35 +0100128 void OnReceivedRtcpReceiverReportBlocks(const ReportBlockList& report_blocks,
129 int64_t now_ms)
130 RTC_RUN_ON(task_queue_);
Sebastian Jansson16180952018-12-12 16:49:10 +0100131 void PostUpdates(NetworkControlUpdate update) RTC_RUN_ON(task_queue_);
132 void UpdateControlState() RTC_RUN_ON(task_queue_);
Sebastian Jansson87609be2018-12-05 17:35:35 +0100133
Sebastian Janssonaa01f272019-01-30 11:28:59 +0100134 Clock* const clock_;
nissecae45d02017-04-24 05:53:20 -0700135 PacketRouter packet_router_;
Stefan Holmer9416ef82018-07-19 10:34:38 +0200136 std::vector<std::unique_ptr<RtpVideoSenderInterface>> video_rtp_senders_;
Stefan Holmer5c8942a2017-08-22 16:16:44 +0200137 PacedSender pacer_;
Sebastian Jansson97f61ea2018-02-21 13:01:55 +0100138 RtpBitrateConfigurator bitrate_configurator_;
Sebastian Jansson91bb6672018-02-21 13:02:51 +0100139 std::map<std::string, rtc::NetworkRoute> network_routes_;
Sebastian Janssonc33c0fc2018-02-22 11:10:18 +0100140 const std::unique_ptr<ProcessThread> process_thread_;
Sebastian Jansson87609be2018-12-05 17:35:35 +0100141
142 TargetTransferRateObserver* observer_ RTC_GUARDED_BY(task_queue_);
143
144 // TODO(srte): Move all access to feedback adapter to task queue.
145 TransportFeedbackAdapter transport_feedback_adapter_;
146
147 NetworkControllerFactoryInterface* const controller_factory_override_
148 RTC_PT_GUARDED_BY(task_queue_);
149 const std::unique_ptr<NetworkControllerFactoryInterface>
150 controller_factory_fallback_ RTC_PT_GUARDED_BY(task_queue_);
151
152 std::unique_ptr<CongestionControlHandler> control_handler_
153 RTC_GUARDED_BY(task_queue_) RTC_PT_GUARDED_BY(task_queue_);
154
155 std::unique_ptr<NetworkControllerInterface> controller_
156 RTC_GUARDED_BY(task_queue_) RTC_PT_GUARDED_BY(task_queue_);
157
158 TimeDelta process_interval_ RTC_GUARDED_BY(task_queue_);
159
160 std::map<uint32_t, RTCPReportBlock> last_report_blocks_
161 RTC_GUARDED_BY(task_queue_);
162 Timestamp last_report_block_time_ RTC_GUARDED_BY(task_queue_);
163
164 NetworkControllerConfig initial_config_ RTC_GUARDED_BY(task_queue_);
165 StreamsConfig streams_config_ RTC_GUARDED_BY(task_queue_);
166
167 const bool reset_feedback_on_route_change_;
168 const bool send_side_bwe_with_overhead_;
Christoffer Rodbroc610e262019-01-08 10:49:19 +0100169 const bool add_pacing_to_cwin_;
Sebastian Jansson87609be2018-12-05 17:35:35 +0100170 // Transport overhead is written by OnNetworkRouteChanged and read by
171 // AddPacket.
172 // TODO(srte): Remove atomic when feedback adapter runs on task queue.
173 std::atomic<size_t> transport_overhead_bytes_per_packet_;
174 bool network_available_ RTC_GUARDED_BY(task_queue_);
Sebastian Janssonecb68972019-01-18 10:30:54 +0100175 RepeatingTaskHandle pacer_queue_update_task_ RTC_GUARDED_BY(task_queue_);
176 RepeatingTaskHandle controller_task_ RTC_GUARDED_BY(task_queue_);
Sebastian Jansson87609be2018-12-05 17:35:35 +0100177 // Protects access to last_packet_feedback_vector_ in feedback adapter.
178 // TODO(srte): Remove this checker when feedback adapter runs on task queue.
179 rtc::RaceChecker worker_race_;
180
Stefan Holmerdbdb3a02018-07-17 16:03:46 +0200181 RateLimiter retransmission_rate_limiter_;
182
Sebastian Janssone6256052018-05-04 14:08:15 +0200183 // TODO(perkj): |task_queue_| is supposed to replace |process_thread_|.
184 // |task_queue_| is defined last to ensure all pending tasks are cancelled
185 // and deleted before any other members.
186 rtc::TaskQueue task_queue_;
nissecae45d02017-04-24 05:53:20 -0700187 RTC_DISALLOW_COPY_AND_ASSIGN(RtpTransportControllerSend);
nisseb8f9a322017-03-27 05:36:15 -0700188};
189
190} // namespace webrtc
191
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200192#endif // CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_