Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2012 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 | |
| 11 | #ifndef MODULES_RTP_RTCP_SOURCE_RTP_RTCP_IMPL2_H_ |
| 12 | #define MODULES_RTP_RTCP_SOURCE_RTP_RTCP_IMPL2_H_ |
| 13 | |
| 14 | #include <stddef.h> |
| 15 | #include <stdint.h> |
| 16 | |
| 17 | #include <memory> |
| 18 | #include <set> |
| 19 | #include <string> |
| 20 | #include <vector> |
| 21 | |
| 22 | #include "absl/types/optional.h" |
| 23 | #include "api/rtp_headers.h" |
Artem Titov | d15a575 | 2021-02-10 14:31:24 +0100 | [diff] [blame] | 24 | #include "api/sequence_checker.h" |
Tomas Gunnarsson | 473bbd8 | 2020-06-27 17:44:55 +0200 | [diff] [blame] | 25 | #include "api/task_queue/task_queue_base.h" |
Markus Handell | 885d538 | 2021-06-21 18:57:36 +0200 | [diff] [blame] | 26 | #include "api/units/time_delta.h" |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 27 | #include "api/video/video_bitrate_allocation.h" |
| 28 | #include "modules/include/module_fec_types.h" |
| 29 | #include "modules/remote_bitrate_estimator/include/remote_bitrate_estimator.h" |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 30 | #include "modules/rtp_rtcp/include/rtp_rtcp_defines.h" // RTCPPacketType |
Erik Språng | bfcfe03 | 2021-08-04 14:45:32 +0200 | [diff] [blame] | 31 | #include "modules/rtp_rtcp/source/packet_sequencer.h" |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 32 | #include "modules/rtp_rtcp/source/rtcp_packet/tmmb_item.h" |
| 33 | #include "modules/rtp_rtcp/source/rtcp_receiver.h" |
| 34 | #include "modules/rtp_rtcp/source/rtcp_sender.h" |
| 35 | #include "modules/rtp_rtcp/source/rtp_packet_history.h" |
| 36 | #include "modules/rtp_rtcp/source/rtp_packet_to_send.h" |
| 37 | #include "modules/rtp_rtcp/source/rtp_sender.h" |
| 38 | #include "modules/rtp_rtcp/source/rtp_sender_egress.h" |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 39 | #include "rtc_base/gtest_prod_util.h" |
Markus Handell | f7303e6 | 2020-07-09 01:34:42 +0200 | [diff] [blame] | 40 | #include "rtc_base/synchronization/mutex.h" |
Mirko Bonadei | 20e4c80 | 2020-11-23 11:07:42 +0100 | [diff] [blame] | 41 | #include "rtc_base/system/no_unique_address.h" |
Tomas Gunnarsson | ba0ba71 | 2020-07-01 08:53:21 +0200 | [diff] [blame] | 42 | #include "rtc_base/task_utils/pending_task_safety_flag.h" |
| 43 | #include "rtc_base/task_utils/repeating_task.h" |
Markus Handell | 885d538 | 2021-06-21 18:57:36 +0200 | [diff] [blame] | 44 | #include "rtc_base/task_utils/to_queued_task.h" |
| 45 | #include "rtc_base/thread_annotations.h" |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 46 | |
| 47 | namespace webrtc { |
| 48 | |
| 49 | class Clock; |
| 50 | struct PacedPacketInfo; |
| 51 | struct RTPVideoHeader; |
| 52 | |
Tomas Gunnarsson | f25761d | 2020-06-03 22:55:33 +0200 | [diff] [blame] | 53 | class ModuleRtpRtcpImpl2 final : public RtpRtcpInterface, |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 54 | public RTCPReceiver::ModuleRtpRtcp { |
| 55 | public: |
Tomas Gunnarsson | f25761d | 2020-06-03 22:55:33 +0200 | [diff] [blame] | 56 | explicit ModuleRtpRtcpImpl2( |
| 57 | const RtpRtcpInterface::Configuration& configuration); |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 58 | ~ModuleRtpRtcpImpl2() override; |
| 59 | |
Niels Moller | 2accc7d | 2021-01-12 15:54:16 +0000 | [diff] [blame] | 60 | // This method is provided to easy with migrating away from the |
| 61 | // RtpRtcp::Create factory method. Since this is an internal implementation |
| 62 | // detail though, creating an instance of ModuleRtpRtcpImpl2 directly should |
| 63 | // be fine. |
| 64 | static std::unique_ptr<ModuleRtpRtcpImpl2> Create( |
| 65 | const Configuration& configuration); |
| 66 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 67 | // Receiver part. |
| 68 | |
| 69 | // Called when we receive an RTCP packet. |
| 70 | void IncomingRtcpPacket(const uint8_t* incoming_packet, |
| 71 | size_t incoming_packet_length) override; |
| 72 | |
| 73 | void SetRemoteSSRC(uint32_t ssrc) override; |
| 74 | |
Tommi | 08be9ba | 2021-06-15 23:01:57 +0200 | [diff] [blame] | 75 | void SetLocalSsrc(uint32_t local_ssrc) override; |
| 76 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 77 | // Sender part. |
| 78 | void RegisterSendPayloadFrequency(int payload_type, |
| 79 | int payload_frequency) override; |
| 80 | |
| 81 | int32_t DeRegisterSendPayload(int8_t payload_type) override; |
| 82 | |
| 83 | void SetExtmapAllowMixed(bool extmap_allow_mixed) override; |
| 84 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 85 | void RegisterRtpHeaderExtension(absl::string_view uri, int id) override; |
| 86 | int32_t DeregisterSendRtpHeaderExtension(RTPExtensionType type) override; |
| 87 | void DeregisterSendRtpHeaderExtension(absl::string_view uri) override; |
| 88 | |
| 89 | bool SupportsPadding() const override; |
| 90 | bool SupportsRtxPayloadPadding() const override; |
| 91 | |
| 92 | // Get start timestamp. |
| 93 | uint32_t StartTimestamp() const override; |
| 94 | |
| 95 | // Configure start timestamp, default is a random number. |
| 96 | void SetStartTimestamp(uint32_t timestamp) override; |
| 97 | |
| 98 | uint16_t SequenceNumber() const override; |
| 99 | |
| 100 | // Set SequenceNumber, default is a random number. |
| 101 | void SetSequenceNumber(uint16_t seq) override; |
| 102 | |
| 103 | void SetRtpState(const RtpState& rtp_state) override; |
| 104 | void SetRtxState(const RtpState& rtp_state) override; |
| 105 | RtpState GetRtpState() const override; |
| 106 | RtpState GetRtxState() const override; |
| 107 | |
Ivo Creusen | 8c40d51 | 2021-07-13 12:53:22 +0000 | [diff] [blame] | 108 | void SetNonSenderRttMeasurement(bool enabled) override; |
| 109 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 110 | uint32_t SSRC() const override { return rtcp_sender_.SSRC(); } |
| 111 | |
Tommi | 08be9ba | 2021-06-15 23:01:57 +0200 | [diff] [blame] | 112 | // Semantically identical to `SSRC()` but must be called on the packet |
| 113 | // delivery thread/tq and returns the ssrc that maps to |
| 114 | // RtpRtcpInterface::Configuration::local_media_ssrc. |
| 115 | uint32_t local_media_ssrc() const; |
| 116 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 117 | void SetRid(const std::string& rid) override; |
| 118 | |
| 119 | void SetMid(const std::string& mid) override; |
| 120 | |
| 121 | void SetCsrcs(const std::vector<uint32_t>& csrcs) override; |
| 122 | |
| 123 | RTCPSender::FeedbackState GetFeedbackState(); |
| 124 | |
| 125 | void SetRtxSendStatus(int mode) override; |
| 126 | int RtxSendStatus() const override; |
| 127 | absl::optional<uint32_t> RtxSsrc() const override; |
| 128 | |
| 129 | void SetRtxSendPayloadType(int payload_type, |
| 130 | int associated_payload_type) override; |
| 131 | |
| 132 | absl::optional<uint32_t> FlexfecSsrc() const override; |
| 133 | |
| 134 | // Sends kRtcpByeCode when going from true to false. |
| 135 | int32_t SetSendingStatus(bool sending) override; |
| 136 | |
| 137 | bool Sending() const override; |
| 138 | |
| 139 | // Drops or relays media packets. |
| 140 | void SetSendingMediaStatus(bool sending) override; |
| 141 | |
| 142 | bool SendingMedia() const override; |
| 143 | |
| 144 | bool IsAudioConfigured() const override; |
| 145 | |
| 146 | void SetAsPartOfAllocation(bool part_of_allocation) override; |
| 147 | |
| 148 | bool OnSendingRtpFrame(uint32_t timestamp, |
| 149 | int64_t capture_time_ms, |
| 150 | int payload_type, |
| 151 | bool force_sender_report) override; |
| 152 | |
| 153 | bool TrySendPacket(RtpPacketToSend* packet, |
| 154 | const PacedPacketInfo& pacing_info) override; |
| 155 | |
Erik Språng | 1d50cb6 | 2020-07-02 17:41:32 +0200 | [diff] [blame] | 156 | void SetFecProtectionParams(const FecProtectionParams& delta_params, |
| 157 | const FecProtectionParams& key_params) override; |
| 158 | |
| 159 | std::vector<std::unique_ptr<RtpPacketToSend>> FetchFecPackets() override; |
| 160 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 161 | void OnPacketsAcknowledged( |
| 162 | rtc::ArrayView<const uint16_t> sequence_numbers) override; |
| 163 | |
| 164 | std::vector<std::unique_ptr<RtpPacketToSend>> GeneratePadding( |
| 165 | size_t target_size_bytes) override; |
| 166 | |
| 167 | std::vector<RtpSequenceNumberMap::Info> GetSentRtpPacketInfos( |
| 168 | rtc::ArrayView<const uint16_t> sequence_numbers) const override; |
| 169 | |
| 170 | size_t ExpectedPerPacketOverhead() const override; |
| 171 | |
Erik Språng | b6bbdeb | 2021-08-13 16:12:41 +0200 | [diff] [blame] | 172 | void OnPacketSendingThreadSwitched() override; |
| 173 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 174 | // RTCP part. |
| 175 | |
| 176 | // Get RTCP status. |
| 177 | RtcpMode RTCP() const override; |
| 178 | |
| 179 | // Configure RTCP status i.e on/off. |
| 180 | void SetRTCPStatus(RtcpMode method) override; |
| 181 | |
| 182 | // Set RTCP CName. |
| 183 | int32_t SetCNAME(const char* c_name) override; |
| 184 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 185 | // Get remote NTP. |
| 186 | int32_t RemoteNTP(uint32_t* received_ntp_secs, |
| 187 | uint32_t* received_ntp_frac, |
| 188 | uint32_t* rtcp_arrival_time_secs, |
| 189 | uint32_t* rtcp_arrival_time_frac, |
| 190 | uint32_t* rtcp_timestamp) const override; |
| 191 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 192 | // Get RoundTripTime. |
| 193 | int32_t RTT(uint32_t remote_ssrc, |
| 194 | int64_t* rtt, |
| 195 | int64_t* avg_rtt, |
| 196 | int64_t* min_rtt, |
| 197 | int64_t* max_rtt) const override; |
| 198 | |
| 199 | int64_t ExpectedRetransmissionTimeMs() const override; |
| 200 | |
| 201 | // Force a send of an RTCP packet. |
Markus Handell | 885d538 | 2021-06-21 18:57:36 +0200 | [diff] [blame] | 202 | // Normal SR and RR are triggered via the task queue that's current when this |
| 203 | // object is created. |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 204 | int32_t SendRTCP(RTCPPacketType rtcpPacketType) override; |
| 205 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 206 | void GetSendStreamDataCounters( |
| 207 | StreamDataCounters* rtp_counters, |
| 208 | StreamDataCounters* rtx_counters) const override; |
| 209 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 210 | // A snapshot of the most recent Report Block with additional data of |
| 211 | // interest to statistics. Used to implement RTCRemoteInboundRtpStreamStats. |
| 212 | // Within this list, the ReportBlockData::RTCPReportBlock::source_ssrc(), |
| 213 | // which is the SSRC of the corresponding outbound RTP stream, is unique. |
| 214 | std::vector<ReportBlockData> GetLatestReportBlockData() const override; |
Alessio Bazzica | bc1c93d | 2021-03-12 17:45:26 +0100 | [diff] [blame] | 215 | absl::optional<SenderReportStats> GetSenderReportStats() const override; |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 216 | |
| 217 | // (REMB) Receiver Estimated Max Bitrate. |
| 218 | void SetRemb(int64_t bitrate_bps, std::vector<uint32_t> ssrcs) override; |
| 219 | void UnsetRemb() override; |
| 220 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 221 | void SetTmmbn(std::vector<rtcp::TmmbItem> bounding_set) override; |
| 222 | |
| 223 | size_t MaxRtpPacketSize() const override; |
| 224 | |
| 225 | void SetMaxRtpPacketSize(size_t max_packet_size) override; |
| 226 | |
| 227 | // (NACK) Negative acknowledgment part. |
| 228 | |
| 229 | // Send a Negative acknowledgment packet. |
| 230 | // TODO(philipel): Deprecate SendNACK and use SendNack instead. |
| 231 | int32_t SendNACK(const uint16_t* nack_list, uint16_t size) override; |
| 232 | |
| 233 | void SendNack(const std::vector<uint16_t>& sequence_numbers) override; |
| 234 | |
| 235 | // Store the sent packets, needed to answer to a negative acknowledgment |
| 236 | // requests. |
| 237 | void SetStorePacketsStatus(bool enable, uint16_t number_to_store) override; |
| 238 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 239 | void SendCombinedRtcpPacket( |
| 240 | std::vector<std::unique_ptr<rtcp::RtcpPacket>> rtcp_packets) override; |
| 241 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 242 | // Video part. |
| 243 | int32_t SendLossNotification(uint16_t last_decoded_seq_num, |
| 244 | uint16_t last_received_seq_num, |
| 245 | bool decodability_flag, |
| 246 | bool buffering_allowed) override; |
| 247 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 248 | RtpSendRates GetSendRates() const override; |
| 249 | |
| 250 | void OnReceivedNack( |
| 251 | const std::vector<uint16_t>& nack_sequence_numbers) override; |
| 252 | void OnReceivedRtcpReportBlocks( |
| 253 | const ReportBlockList& report_blocks) override; |
| 254 | void OnRequestSendReport() override; |
| 255 | |
| 256 | void SetVideoBitrateAllocation( |
| 257 | const VideoBitrateAllocation& bitrate) override; |
| 258 | |
| 259 | RTPSender* RtpSender() override; |
| 260 | const RTPSender* RtpSender() const override; |
| 261 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 262 | private: |
| 263 | FRIEND_TEST_ALL_PREFIXES(RtpRtcpImpl2Test, Rtt); |
| 264 | FRIEND_TEST_ALL_PREFIXES(RtpRtcpImpl2Test, RttForReceiverOnly); |
| 265 | |
Erik Språng | 54abf98 | 2021-08-13 17:25:44 +0200 | [diff] [blame^] | 266 | struct RtpSenderContext { |
Tomas Gunnarsson | f25761d | 2020-06-03 22:55:33 +0200 | [diff] [blame] | 267 | explicit RtpSenderContext(const RtpRtcpInterface::Configuration& config); |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 268 | // Storage of packets, for retransmissions and padding, if applicable. |
| 269 | RtpPacketHistory packet_history; |
Erik Språng | b6bbdeb | 2021-08-13 16:12:41 +0200 | [diff] [blame] | 270 | SequenceChecker sequencing_checker; |
Erik Språng | bfcfe03 | 2021-08-04 14:45:32 +0200 | [diff] [blame] | 271 | // Handles sequence number assignment and padding timestamp generation. |
Erik Språng | b6bbdeb | 2021-08-13 16:12:41 +0200 | [diff] [blame] | 272 | PacketSequencer sequencer RTC_GUARDED_BY(sequencing_checker); |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 273 | // Handles final time timestamping/stats/etc and handover to Transport. |
| 274 | RtpSenderEgress packet_sender; |
| 275 | // If no paced sender configured, this class will be used to pass packets |
Artem Titov | 913cfa7 | 2021-07-28 23:57:33 +0200 | [diff] [blame] | 276 | // from `packet_generator_` to `packet_sender_`. |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 277 | RtpSenderEgress::NonPacedPacketSender non_paced_sender; |
| 278 | // Handles creation of RTP packets to be sent. |
| 279 | RTPSender packet_generator; |
| 280 | }; |
| 281 | |
| 282 | void set_rtt_ms(int64_t rtt_ms); |
| 283 | int64_t rtt_ms() const; |
| 284 | |
| 285 | bool TimeToSendFullNackList(int64_t now) const; |
| 286 | |
Tomas Gunnarsson | ba0ba71 | 2020-07-01 08:53:21 +0200 | [diff] [blame] | 287 | // Called on a timer, once a second, on the worker_queue_, to update the RTT, |
| 288 | // check if we need to send RTCP report, send TMMBR updates and fire events. |
| 289 | void PeriodicUpdate(); |
| 290 | |
Niels Möller | af6ea0c | 2020-11-20 12:21:21 +0100 | [diff] [blame] | 291 | // Returns true if the module is configured to store packets. |
| 292 | bool StorePackets() const; |
| 293 | |
Markus Handell | 885d538 | 2021-06-21 18:57:36 +0200 | [diff] [blame] | 294 | // Used from RtcpSenderMediator to maybe send rtcp. |
| 295 | void MaybeSendRtcp() RTC_RUN_ON(worker_queue_); |
| 296 | |
Artem Titov | 913cfa7 | 2021-07-28 23:57:33 +0200 | [diff] [blame] | 297 | // Called when `rtcp_sender_` informs of the next RTCP instant. The method may |
Markus Handell | 885d538 | 2021-06-21 18:57:36 +0200 | [diff] [blame] | 298 | // be called on various sequences, and is called under a RTCPSenderLock. |
| 299 | void ScheduleRtcpSendEvaluation(TimeDelta duration); |
| 300 | |
| 301 | // Helper method combating too early delayed calls from task queues. |
| 302 | // TODO(bugs.webrtc.org/12889): Consider removing this function when the issue |
| 303 | // is resolved. |
| 304 | void MaybeSendRtcpAtOrAfterTimestamp(Timestamp execution_time) |
| 305 | RTC_RUN_ON(worker_queue_); |
| 306 | |
Artem Titov | 913cfa7 | 2021-07-28 23:57:33 +0200 | [diff] [blame] | 307 | // Schedules a call to MaybeSendRtcpAtOrAfterTimestamp delayed by `duration`. |
Markus Handell | 885d538 | 2021-06-21 18:57:36 +0200 | [diff] [blame] | 308 | void ScheduleMaybeSendRtcpAtOrAfterTimestamp(Timestamp execution_time, |
| 309 | TimeDelta duration); |
| 310 | |
Tomas Gunnarsson | 473bbd8 | 2020-06-27 17:44:55 +0200 | [diff] [blame] | 311 | TaskQueueBase* const worker_queue_; |
Erik Språng | b6bbdeb | 2021-08-13 16:12:41 +0200 | [diff] [blame] | 312 | RTC_NO_UNIQUE_ADDRESS SequenceChecker rtcp_thread_checker_; |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 313 | |
| 314 | std::unique_ptr<RtpSenderContext> rtp_sender_; |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 315 | RTCPSender rtcp_sender_; |
| 316 | RTCPReceiver rtcp_receiver_; |
| 317 | |
| 318 | Clock* const clock_; |
| 319 | |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 320 | uint16_t packet_overhead_; |
| 321 | |
| 322 | // Send side |
| 323 | int64_t nack_last_time_sent_full_ms_; |
| 324 | uint16_t nack_last_seq_number_sent_; |
| 325 | |
| 326 | RemoteBitrateEstimator* const remote_bitrate_; |
| 327 | |
| 328 | RtcpRttStats* const rtt_stats_; |
Tomas Gunnarsson | ba0ba71 | 2020-07-01 08:53:21 +0200 | [diff] [blame] | 329 | RepeatingTaskHandle rtt_update_task_ RTC_GUARDED_BY(worker_queue_); |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 330 | |
| 331 | // The processed RTT from RtcpRttStats. |
Markus Handell | f7303e6 | 2020-07-09 01:34:42 +0200 | [diff] [blame] | 332 | mutable Mutex mutex_rtt_; |
Niels Möller | cd98213 | 2020-11-26 16:19:56 +0100 | [diff] [blame] | 333 | int64_t rtt_ms_ RTC_GUARDED_BY(mutex_rtt_); |
Markus Handell | 885d538 | 2021-06-21 18:57:36 +0200 | [diff] [blame] | 334 | |
| 335 | RTC_NO_UNIQUE_ADDRESS ScopedTaskSafety task_safety_; |
Tommi | 3a5742c | 2020-05-20 09:32:51 +0200 | [diff] [blame] | 336 | }; |
| 337 | |
| 338 | } // namespace webrtc |
| 339 | |
| 340 | #endif // MODULES_RTP_RTCP_SOURCE_RTP_RTCP_IMPL2_H_ |