/* * 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 API_RTP_PACKET_INFO_H_ #define API_RTP_PACKET_INFO_H_ #include #include #include #include "absl/types/optional.h" #include "api/rtp_headers.h" #include "api/units/timestamp.h" #include "rtc_base/system/rtc_export.h" namespace webrtc { // // Structure to hold information about a received `RtpPacket`. It is primarily // used to carry per-packet information from when a packet is received until // the information is passed to `SourceTracker`. // class RTC_EXPORT RtpPacketInfo { public: RtpPacketInfo(); RtpPacketInfo(uint32_t ssrc, std::vector csrcs, uint32_t rtp_timestamp, absl::optional audio_level, absl::optional absolute_capture_time, Timestamp receive_time); RtpPacketInfo(const RTPHeader& rtp_header, Timestamp receive_time); // TODO(bugs.webrtc.org/12722): Deprecated, remove once downstream projects // are updated. RtpPacketInfo(uint32_t ssrc, std::vector csrcs, uint32_t rtp_timestamp, absl::optional audio_level, absl::optional absolute_capture_time, int64_t receive_time_ms); RtpPacketInfo(const RTPHeader& rtp_header, int64_t receive_time_ms); RtpPacketInfo(const RtpPacketInfo& other) = default; RtpPacketInfo(RtpPacketInfo&& other) = default; RtpPacketInfo& operator=(const RtpPacketInfo& other) = default; RtpPacketInfo& operator=(RtpPacketInfo&& other) = default; uint32_t ssrc() const { return ssrc_; } void set_ssrc(uint32_t value) { ssrc_ = value; } const std::vector& csrcs() const { return csrcs_; } void set_csrcs(std::vector value) { csrcs_ = std::move(value); } uint32_t rtp_timestamp() const { return rtp_timestamp_; } void set_rtp_timestamp(uint32_t value) { rtp_timestamp_ = value; } absl::optional audio_level() const { return audio_level_; } void set_audio_level(absl::optional value) { audio_level_ = value; } const absl::optional& absolute_capture_time() const { return absolute_capture_time_; } void set_absolute_capture_time( const absl::optional& value) { absolute_capture_time_ = value; } const absl::optional& local_capture_clock_offset() const { return local_capture_clock_offset_; } void set_local_capture_clock_offset(const absl::optional& value) { local_capture_clock_offset_ = value; } Timestamp receive_time() const { return receive_time_; } void set_receive_time(Timestamp value) { receive_time_ = value; } // TODO(bugs.webrtc.org/12722): Deprecated, remove once downstream projects // are updated. int64_t receive_time_ms() const { return receive_time_.ms(); } private: // Fields from the RTP header: // https://tools.ietf.org/html/rfc3550#section-5.1 uint32_t ssrc_; std::vector csrcs_; uint32_t rtp_timestamp_; // Fields from the Audio Level header extension: // https://tools.ietf.org/html/rfc6464#section-3 absl::optional audio_level_; // Fields from the Absolute Capture Time header extension: // http://www.webrtc.org/experiments/rtp-hdrext/abs-capture-time // To not be confused with `local_capture_clock_offset_`, the // `estimated_capture_clock_offset` in `absolute_capture_time_` should // represent the clock offset between a remote sender and the capturer, and // thus equals to the corresponding values in the received RTP packets, // subjected to possible interpolations. absl::optional absolute_capture_time_; // Clock offset against capturer's clock. Should be derived from the estimated // capture clock offset defined in the Absolute Capture Time header extension. absl::optional local_capture_clock_offset_; // Local `webrtc::Clock`-based timestamp of when the packet was received. Timestamp receive_time_; }; bool operator==(const RtpPacketInfo& lhs, const RtpPacketInfo& rhs); inline bool operator!=(const RtpPacketInfo& lhs, const RtpPacketInfo& rhs) { return !(lhs == rhs); } } // namespace webrtc #endif // API_RTP_PACKET_INFO_H_