|  | /* | 
|  | *  Copyright (c) 2019 The WebRTC project authors. All Rights Reserved. | 
|  | * | 
|  | *  Use of this source code is governed by a BSD-style license | 
|  | *  that can be found in the LICENSE file in the root of the source | 
|  | *  tree. An additional intellectual property rights grant can be found | 
|  | *  in the file PATENTS.  All contributing project authors may | 
|  | *  be found in the AUTHORS file in the root of the source tree. | 
|  | */ | 
|  |  | 
|  | #ifndef MODULES_RTP_RTCP_SOURCE_RTP_SENDER_EGRESS_H_ | 
|  | #define MODULES_RTP_RTCP_SOURCE_RTP_SENDER_EGRESS_H_ | 
|  |  | 
|  | #include <map> | 
|  | #include <memory> | 
|  | #include <utility> | 
|  | #include <vector> | 
|  |  | 
|  | #include "absl/types/optional.h" | 
|  | #include "api/call/transport.h" | 
|  | #include "api/rtc_event_log/rtc_event_log.h" | 
|  | #include "api/sequence_checker.h" | 
|  | #include "api/task_queue/pending_task_safety_flag.h" | 
|  | #include "api/task_queue/task_queue_base.h" | 
|  | #include "api/units/data_rate.h" | 
|  | #include "api/units/time_delta.h" | 
|  | #include "api/units/timestamp.h" | 
|  | #include "modules/remote_bitrate_estimator/test/bwe_test_logging.h" | 
|  | #include "modules/rtp_rtcp/include/rtp_rtcp_defines.h" | 
|  | #include "modules/rtp_rtcp/source/packet_sequencer.h" | 
|  | #include "modules/rtp_rtcp/source/rtp_packet_history.h" | 
|  | #include "modules/rtp_rtcp/source/rtp_packet_to_send.h" | 
|  | #include "modules/rtp_rtcp/source/rtp_rtcp_interface.h" | 
|  | #include "modules/rtp_rtcp/source/rtp_sequence_number_map.h" | 
|  | #include "rtc_base/rate_statistics.h" | 
|  | #include "rtc_base/synchronization/mutex.h" | 
|  | #include "rtc_base/system/no_unique_address.h" | 
|  | #include "rtc_base/task_utils/repeating_task.h" | 
|  | #include "rtc_base/thread_annotations.h" | 
|  |  | 
|  | namespace webrtc { | 
|  |  | 
|  | class RtpSenderEgress { | 
|  | public: | 
|  | // Helper class that redirects packets directly to the send part of this class | 
|  | // without passing through an actual paced sender. | 
|  | class NonPacedPacketSender : public RtpPacketSender { | 
|  | public: | 
|  | NonPacedPacketSender(RtpSenderEgress* sender, PacketSequencer* sequencer); | 
|  | virtual ~NonPacedPacketSender(); | 
|  |  | 
|  | void EnqueuePackets( | 
|  | std::vector<std::unique_ptr<RtpPacketToSend>> packets) override; | 
|  | // Since we don't pace packets, there's no pending packets to remove. | 
|  | void RemovePacketsForSsrc(uint32_t ssrc) override {} | 
|  |  | 
|  | private: | 
|  | void PrepareForSend(RtpPacketToSend* packet); | 
|  | uint16_t transport_sequence_number_; | 
|  | RtpSenderEgress* const sender_; | 
|  | PacketSequencer* sequencer_; | 
|  | }; | 
|  |  | 
|  | RtpSenderEgress(const RtpRtcpInterface::Configuration& config, | 
|  | RtpPacketHistory* packet_history); | 
|  | ~RtpSenderEgress(); | 
|  |  | 
|  | void SendPacket(RtpPacketToSend* packet, const PacedPacketInfo& pacing_info) | 
|  | RTC_LOCKS_EXCLUDED(lock_); | 
|  | uint32_t Ssrc() const { return ssrc_; } | 
|  | absl::optional<uint32_t> RtxSsrc() const { return rtx_ssrc_; } | 
|  | absl::optional<uint32_t> FlexFecSsrc() const { return flexfec_ssrc_; } | 
|  |  | 
|  | RtpSendRates GetSendRates() const RTC_LOCKS_EXCLUDED(lock_); | 
|  | void GetDataCounters(StreamDataCounters* rtp_stats, | 
|  | StreamDataCounters* rtx_stats) const | 
|  | RTC_LOCKS_EXCLUDED(lock_); | 
|  |  | 
|  | void ForceIncludeSendPacketsInAllocation(bool part_of_allocation) | 
|  | RTC_LOCKS_EXCLUDED(lock_); | 
|  | bool MediaHasBeenSent() const RTC_LOCKS_EXCLUDED(lock_); | 
|  | void SetMediaHasBeenSent(bool media_sent) RTC_LOCKS_EXCLUDED(lock_); | 
|  | void SetTimestampOffset(uint32_t timestamp) RTC_LOCKS_EXCLUDED(lock_); | 
|  |  | 
|  | // For each sequence number in `sequence_number`, recall the last RTP packet | 
|  | // which bore it - its timestamp and whether it was the first and/or last | 
|  | // packet in that frame. If all of the given sequence numbers could be | 
|  | // recalled, return a vector with all of them (in corresponding order). | 
|  | // If any could not be recalled, return an empty vector. | 
|  | std::vector<RtpSequenceNumberMap::Info> GetSentRtpPacketInfos( | 
|  | rtc::ArrayView<const uint16_t> sequence_numbers) const | 
|  | RTC_LOCKS_EXCLUDED(lock_); | 
|  |  | 
|  | void SetFecProtectionParameters(const FecProtectionParams& delta_params, | 
|  | const FecProtectionParams& key_params); | 
|  | std::vector<std::unique_ptr<RtpPacketToSend>> FetchFecPackets(); | 
|  |  | 
|  | // Clears pending status for these sequence numbers in the packet history. | 
|  | void OnAbortedRetransmissions( | 
|  | rtc::ArrayView<const uint16_t> sequence_numbers); | 
|  |  | 
|  | private: | 
|  | RtpSendRates GetSendRatesLocked(Timestamp now) const | 
|  | RTC_EXCLUSIVE_LOCKS_REQUIRED(lock_); | 
|  | bool HasCorrectSsrc(const RtpPacketToSend& packet) const; | 
|  | void AddPacketToTransportFeedback(uint16_t packet_id, | 
|  | const RtpPacketToSend& packet, | 
|  | const PacedPacketInfo& pacing_info); | 
|  | void UpdateDelayStatistics(Timestamp capture_time, | 
|  | Timestamp now, | 
|  | uint32_t ssrc); | 
|  | void RecomputeMaxSendDelay() RTC_EXCLUSIVE_LOCKS_REQUIRED(lock_); | 
|  | void UpdateOnSendPacket(int packet_id, Timestamp capture_time, uint32_t ssrc); | 
|  | // Sends packet on to `transport_`, leaving the RTP module. | 
|  | bool SendPacketToNetwork(const RtpPacketToSend& packet, | 
|  | const PacketOptions& options, | 
|  | const PacedPacketInfo& pacing_info); | 
|  |  | 
|  | void UpdateRtpStats(Timestamp now, | 
|  | uint32_t packet_ssrc, | 
|  | RtpPacketMediaType packet_type, | 
|  | RtpPacketCounter counter, | 
|  | size_t packet_size); | 
|  | #if BWE_TEST_LOGGING_COMPILE_TIME_ENABLE | 
|  | void BweTestLoggingPlot(Timestamp now, uint32_t packet_ssrc); | 
|  | #endif | 
|  |  | 
|  | // Called on a timer, once a second, on the worker_queue_. | 
|  | void PeriodicUpdate(); | 
|  |  | 
|  | TaskQueueBase* const worker_queue_; | 
|  | RTC_NO_UNIQUE_ADDRESS SequenceChecker pacer_checker_; | 
|  | const uint32_t ssrc_; | 
|  | const absl::optional<uint32_t> rtx_ssrc_; | 
|  | const absl::optional<uint32_t> flexfec_ssrc_; | 
|  | const bool populate_network2_timestamp_; | 
|  | Clock* const clock_; | 
|  | RtpPacketHistory* const packet_history_; | 
|  | Transport* const transport_; | 
|  | RtcEventLog* const event_log_; | 
|  | #if BWE_TEST_LOGGING_COMPILE_TIME_ENABLE | 
|  | const bool is_audio_; | 
|  | #endif | 
|  | const bool need_rtp_packet_infos_; | 
|  | VideoFecGenerator* const fec_generator_ RTC_GUARDED_BY(pacer_checker_); | 
|  | absl::optional<uint16_t> last_sent_seq_ RTC_GUARDED_BY(pacer_checker_); | 
|  | absl::optional<uint16_t> last_sent_rtx_seq_ RTC_GUARDED_BY(pacer_checker_); | 
|  |  | 
|  | TransportFeedbackObserver* const transport_feedback_observer_; | 
|  | SendSideDelayObserver* const send_side_delay_observer_; | 
|  | SendPacketObserver* const send_packet_observer_; | 
|  | StreamDataCountersCallback* const rtp_stats_callback_; | 
|  | BitrateStatisticsObserver* const bitrate_callback_; | 
|  |  | 
|  | mutable Mutex lock_; | 
|  | bool media_has_been_sent_ RTC_GUARDED_BY(pacer_checker_); | 
|  | bool force_part_of_allocation_ RTC_GUARDED_BY(lock_); | 
|  | uint32_t timestamp_offset_ RTC_GUARDED_BY(worker_queue_); | 
|  |  | 
|  | // Maps capture time to send-side delay. Send-side delay is the difference | 
|  | // between transmission time and capture time. | 
|  | std::map<Timestamp, TimeDelta> send_delays_ RTC_GUARDED_BY(lock_); | 
|  | std::map<Timestamp, TimeDelta>::const_iterator max_delay_it_ | 
|  | RTC_GUARDED_BY(lock_); | 
|  | // The sum of delays over a kSendSideDelayWindowMs sliding window. | 
|  | TimeDelta sum_delays_ RTC_GUARDED_BY(lock_); | 
|  | StreamDataCounters rtp_stats_ RTC_GUARDED_BY(lock_); | 
|  | StreamDataCounters rtx_rtp_stats_ RTC_GUARDED_BY(lock_); | 
|  | // One element per value in RtpPacketMediaType, with index matching value. | 
|  | std::vector<RateStatistics> send_rates_ RTC_GUARDED_BY(lock_); | 
|  | absl::optional<std::pair<FecProtectionParams, FecProtectionParams>> | 
|  | pending_fec_params_ RTC_GUARDED_BY(lock_); | 
|  |  | 
|  | // Maps sent packets' sequence numbers to a tuple consisting of: | 
|  | // 1. The timestamp, without the randomizing offset mandated by the RFC. | 
|  | // 2. Whether the packet was the first in its frame. | 
|  | // 3. Whether the packet was the last in its frame. | 
|  | const std::unique_ptr<RtpSequenceNumberMap> rtp_sequence_number_map_ | 
|  | RTC_GUARDED_BY(worker_queue_); | 
|  | RepeatingTaskHandle update_task_ RTC_GUARDED_BY(worker_queue_); | 
|  | ScopedTaskSafety task_safety_; | 
|  | }; | 
|  |  | 
|  | }  // namespace webrtc | 
|  |  | 
|  | #endif  // MODULES_RTP_RTCP_SOURCE_RTP_SENDER_EGRESS_H_ |