mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-14 14:20:45 +01:00

Bug: None Change-Id: I1bcfbd9c16b329f3aa3f95d8ed61b82131e0da1d Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/316922 Commit-Queue: Erik Språng <sprang@webrtc.org> Reviewed-by: Erik Språng <sprang@webrtc.org> Auto-Submit: Danil Chapovalov <danilchap@webrtc.org> Cr-Commit-Position: refs/heads/main@{#40591}
214 lines
7.9 KiB
C++
214 lines
7.9 KiB
C++
/*
|
|
* Copyright (c) 2012 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_H_
|
|
#define MODULES_RTP_RTCP_SOURCE_RTP_SENDER_H_
|
|
|
|
#include <map>
|
|
#include <memory>
|
|
#include <string>
|
|
#include <utility>
|
|
#include <vector>
|
|
|
|
#include "absl/strings/string_view.h"
|
|
#include "absl/types/optional.h"
|
|
#include "api/array_view.h"
|
|
#include "api/call/transport.h"
|
|
#include "api/field_trials_view.h"
|
|
#include "modules/rtp_rtcp/include/flexfec_sender.h"
|
|
#include "modules/rtp_rtcp/include/rtp_header_extension_map.h"
|
|
#include "modules/rtp_rtcp/include/rtp_packet_sender.h"
|
|
#include "modules/rtp_rtcp/include/rtp_rtcp_defines.h"
|
|
#include "modules/rtp_rtcp/source/rtp_packet_history.h"
|
|
#include "modules/rtp_rtcp/source/rtp_rtcp_config.h"
|
|
#include "modules/rtp_rtcp/source/rtp_rtcp_interface.h"
|
|
#include "rtc_base/random.h"
|
|
#include "rtc_base/synchronization/mutex.h"
|
|
#include "rtc_base/thread_annotations.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class FrameEncryptorInterface;
|
|
class RateLimiter;
|
|
class RtcEventLog;
|
|
class RtpPacketToSend;
|
|
|
|
// Maximum amount of padding in RFC 3550 is 255 bytes.
|
|
constexpr size_t kMaxPaddingLength = 255;
|
|
|
|
class RTPSender {
|
|
public:
|
|
RTPSender(const RtpRtcpInterface::Configuration& config,
|
|
RtpPacketHistory* packet_history,
|
|
RtpPacketSender* packet_sender);
|
|
RTPSender(const RTPSender&) = delete;
|
|
RTPSender& operator=(const RTPSender&) = delete;
|
|
|
|
~RTPSender();
|
|
|
|
void SetSendingMediaStatus(bool enabled) RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
bool SendingMedia() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
bool IsAudioConfigured() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
uint32_t TimestampOffset() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
void SetTimestampOffset(uint32_t timestamp) RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
void SetMid(absl::string_view mid) RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
uint16_t SequenceNumber() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
void SetSequenceNumber(uint16_t seq) RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
void SetMaxRtpPacketSize(size_t max_packet_size)
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
void SetExtmapAllowMixed(bool extmap_allow_mixed)
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
// RTP header extension
|
|
bool RegisterRtpHeaderExtension(absl::string_view uri, int id)
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
bool IsRtpHeaderExtensionRegistered(RTPExtensionType type) const
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
void DeregisterRtpHeaderExtension(absl::string_view uri)
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
bool SupportsPadding() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
bool SupportsRtxPayloadPadding() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
std::vector<std::unique_ptr<RtpPacketToSend>> GeneratePadding(
|
|
size_t target_size_bytes,
|
|
bool media_has_been_sent,
|
|
bool can_send_padding_on_media_ssrc) RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
// NACK.
|
|
void OnReceivedNack(const std::vector<uint16_t>& nack_sequence_numbers,
|
|
int64_t avg_rtt) RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
int32_t ReSendPacket(uint16_t packet_id) RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
// ACK.
|
|
void OnReceivedAckOnSsrc(int64_t extended_highest_sequence_number)
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
void OnReceivedAckOnRtxSsrc(int64_t extended_highest_sequence_number)
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
// RTX.
|
|
void SetRtxStatus(int mode) RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
int RtxStatus() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
absl::optional<uint32_t> RtxSsrc() const RTC_LOCKS_EXCLUDED(send_mutex_) {
|
|
return rtx_ssrc_;
|
|
}
|
|
// Returns expected size difference between an RTX packet and media packet
|
|
// that RTX packet is created from. Returns 0 if RTX is disabled.
|
|
size_t RtxPacketOverhead() const;
|
|
|
|
void SetRtxPayloadType(int payload_type, int associated_payload_type)
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
// Size info for header extensions used by FEC packets.
|
|
static rtc::ArrayView<const RtpExtensionSize> FecExtensionSizes()
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
// Size info for header extensions used by video packets.
|
|
static rtc::ArrayView<const RtpExtensionSize> VideoExtensionSizes()
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
// Size info for header extensions used by audio packets.
|
|
static rtc::ArrayView<const RtpExtensionSize> AudioExtensionSizes()
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
// Create empty packet, fills ssrc, csrcs and reserve place for header
|
|
// extensions RtpSender updates before sending.
|
|
std::unique_ptr<RtpPacketToSend> AllocatePacket(
|
|
rtc::ArrayView<const uint32_t> csrcs = {})
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
// Maximum header overhead per fec/padding packet.
|
|
size_t FecOrPaddingPacketMaxRtpHeaderLength() const
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
// Expected header overhead per media packet.
|
|
size_t ExpectedPerPacketOverhead() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
// Including RTP headers.
|
|
size_t MaxRtpPacketSize() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
uint32_t SSRC() const RTC_LOCKS_EXCLUDED(send_mutex_) { return ssrc_; }
|
|
|
|
absl::optional<uint32_t> FlexfecSsrc() const RTC_LOCKS_EXCLUDED(send_mutex_) {
|
|
return flexfec_ssrc_;
|
|
}
|
|
|
|
// Pass a set of packets to RtpPacketSender instance, for paced or immediate
|
|
// sending to the network.
|
|
void EnqueuePackets(std::vector<std::unique_ptr<RtpPacketToSend>> packets)
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
void SetRtpState(const RtpState& rtp_state) RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
RtpState GetRtpState() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
void SetRtxRtpState(const RtpState& rtp_state)
|
|
RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
RtpState GetRtxRtpState() const RTC_LOCKS_EXCLUDED(send_mutex_);
|
|
|
|
private:
|
|
std::unique_ptr<RtpPacketToSend> BuildRtxPacket(
|
|
const RtpPacketToSend& packet);
|
|
|
|
bool IsFecPacket(const RtpPacketToSend& packet) const;
|
|
|
|
void UpdateHeaderSizes() RTC_EXCLUSIVE_LOCKS_REQUIRED(send_mutex_);
|
|
|
|
void UpdateLastPacketState(const RtpPacketToSend& packet)
|
|
RTC_EXCLUSIVE_LOCKS_REQUIRED(send_mutex_);
|
|
|
|
Clock* const clock_;
|
|
Random random_ RTC_GUARDED_BY(send_mutex_);
|
|
|
|
const bool audio_configured_;
|
|
|
|
const uint32_t ssrc_;
|
|
const absl::optional<uint32_t> rtx_ssrc_;
|
|
const absl::optional<uint32_t> flexfec_ssrc_;
|
|
|
|
RtpPacketHistory* const packet_history_;
|
|
RtpPacketSender* const paced_sender_;
|
|
|
|
mutable Mutex send_mutex_;
|
|
|
|
bool sending_media_ RTC_GUARDED_BY(send_mutex_);
|
|
size_t max_packet_size_;
|
|
|
|
RtpHeaderExtensionMap rtp_header_extension_map_ RTC_GUARDED_BY(send_mutex_);
|
|
size_t max_media_packet_header_ RTC_GUARDED_BY(send_mutex_);
|
|
size_t max_padding_fec_packet_header_ RTC_GUARDED_BY(send_mutex_);
|
|
|
|
// RTP variables
|
|
uint32_t timestamp_offset_ RTC_GUARDED_BY(send_mutex_);
|
|
// RID value to send in the RID or RepairedRID header extension.
|
|
const std::string rid_;
|
|
// MID value to send in the MID header extension.
|
|
std::string mid_ RTC_GUARDED_BY(send_mutex_);
|
|
// Should we send MID/RID even when ACKed? (see below).
|
|
const bool always_send_mid_and_rid_;
|
|
// Track if any ACK has been received on the SSRC and RTX SSRC to indicate
|
|
// when to stop sending the MID and RID header extensions.
|
|
bool ssrc_has_acked_ RTC_GUARDED_BY(send_mutex_);
|
|
bool rtx_ssrc_has_acked_ RTC_GUARDED_BY(send_mutex_);
|
|
// Maximum number of csrcs this sender is used with.
|
|
size_t max_num_csrcs_ RTC_GUARDED_BY(send_mutex_) = 0;
|
|
int rtx_ RTC_GUARDED_BY(send_mutex_);
|
|
// Mapping rtx_payload_type_map_[associated] = rtx.
|
|
std::map<int8_t, int8_t> rtx_payload_type_map_ RTC_GUARDED_BY(send_mutex_);
|
|
bool supports_bwe_extension_ RTC_GUARDED_BY(send_mutex_);
|
|
|
|
RateLimiter* const retransmission_rate_limiter_;
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // MODULES_RTP_RTCP_SOURCE_RTP_SENDER_H_
|