blob: 8df12a36cf72d813aa8f163a26a9967906f289b8 [file] [log] [blame]
Chen Xingd2a66862019-06-03 12:53:421/*
2 * Copyright (c) 2019 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 API_RTP_PACKET_INFO_H_
12#define API_RTP_PACKET_INFO_H_
13
14#include <cstdint>
15#include <utility>
16#include <vector>
17
18#include "absl/types/optional.h"
19#include "api/rtp_headers.h"
Alessio Bazzica56b96ffe2022-09-20 09:16:1620#include "api/units/time_delta.h"
Johannes Kronf7de74c2021-04-30 11:10:5621#include "api/units/timestamp.h"
Johannes Kron0809e7e2020-01-21 10:54:2122#include "rtc_base/system/rtc_export.h"
Chen Xingd2a66862019-06-03 12:53:4223
24namespace webrtc {
25
Chen Xing12d64de2019-06-13 18:36:1226//
Artem Titov0e61fdd2021-07-25 19:50:1427// Structure to hold information about a received `RtpPacket`. It is primarily
Chen Xing12d64de2019-06-13 18:36:1228// used to carry per-packet information from when a packet is received until
Artem Titov0e61fdd2021-07-25 19:50:1429// the information is passed to `SourceTracker`.
Chen Xing12d64de2019-06-13 18:36:1230//
Johannes Kron0809e7e2020-01-21 10:54:2131class RTC_EXPORT RtpPacketInfo {
Chen Xingd2a66862019-06-03 12:53:4232 public:
33 RtpPacketInfo();
34
35 RtpPacketInfo(uint32_t ssrc,
36 std::vector<uint32_t> csrcs,
Chen Xingd2a66862019-06-03 12:53:4237 uint32_t rtp_timestamp,
Alessio Bazzicaa1d03562022-09-19 16:05:2938 Timestamp receive_time);
39
Johannes Kronf7de74c2021-04-30 11:10:5640 RtpPacketInfo(const RTPHeader& rtp_header, Timestamp receive_time);
41
Chen Xingd2a66862019-06-03 12:53:4242 RtpPacketInfo(const RtpPacketInfo& other) = default;
43 RtpPacketInfo(RtpPacketInfo&& other) = default;
44 RtpPacketInfo& operator=(const RtpPacketInfo& other) = default;
45 RtpPacketInfo& operator=(RtpPacketInfo&& other) = default;
46
47 uint32_t ssrc() const { return ssrc_; }
48 void set_ssrc(uint32_t value) { ssrc_ = value; }
49
50 const std::vector<uint32_t>& csrcs() const { return csrcs_; }
51 void set_csrcs(std::vector<uint32_t> value) { csrcs_ = std::move(value); }
52
Chen Xingd2a66862019-06-03 12:53:4253 uint32_t rtp_timestamp() const { return rtp_timestamp_; }
54 void set_rtp_timestamp(uint32_t value) { rtp_timestamp_ = value; }
55
Johannes Kronf7de74c2021-04-30 11:10:5656 Timestamp receive_time() const { return receive_time_; }
57 void set_receive_time(Timestamp value) { receive_time_ = value; }
Chen Xingd2a66862019-06-03 12:53:4258
Alessio Bazzicaa1d03562022-09-19 16:05:2959 absl::optional<uint8_t> audio_level() const { return audio_level_; }
60 RtpPacketInfo& set_audio_level(absl::optional<uint8_t> value) {
61 audio_level_ = value;
62 return *this;
63 }
64
65 const absl::optional<AbsoluteCaptureTime>& absolute_capture_time() const {
66 return absolute_capture_time_;
67 }
68 RtpPacketInfo& set_absolute_capture_time(
69 const absl::optional<AbsoluteCaptureTime>& value) {
70 absolute_capture_time_ = value;
71 return *this;
72 }
73
Alessio Bazzica56b96ffe2022-09-20 09:16:1674 const absl::optional<TimeDelta>& local_capture_clock_offset() const {
Alessio Bazzicaa1d03562022-09-19 16:05:2975 return local_capture_clock_offset_;
76 }
77 RtpPacketInfo& set_local_capture_clock_offset(
Alessio Bazzica56b96ffe2022-09-20 09:16:1678 absl::optional<TimeDelta> value) {
Alessio Bazzicaa1d03562022-09-19 16:05:2979 local_capture_clock_offset_ = value;
80 return *this;
81 }
82
Chen Xingd2a66862019-06-03 12:53:4283 private:
84 // Fields from the RTP header:
85 // https://tools.ietf.org/html/rfc3550#section-5.1
86 uint32_t ssrc_;
87 std::vector<uint32_t> csrcs_;
Chen Xingd2a66862019-06-03 12:53:4288 uint32_t rtp_timestamp_;
89
Alessio Bazzicaa1d03562022-09-19 16:05:2990 // Local `webrtc::Clock`-based timestamp of when the packet was received.
91 Timestamp receive_time_;
92
Chen Xingd2a66862019-06-03 12:53:4293 // Fields from the Audio Level header extension:
94 // https://tools.ietf.org/html/rfc6464#section-3
95 absl::optional<uint8_t> audio_level_;
96
Chen Xinge08648d2019-08-05 14:29:1397 // Fields from the Absolute Capture Time header extension:
98 // http://www.webrtc.org/experiments/rtp-hdrext/abs-capture-time
99 absl::optional<AbsoluteCaptureTime> absolute_capture_time_;
100
Alessio Bazzica56b96ffe2022-09-20 09:16:16101 // Clock offset between the local clock and the capturer's clock.
102 // Do not confuse with `AbsoluteCaptureTime::estimated_capture_clock_offset`
103 // which instead represents the clock offset between a remote sender and the
104 // capturer. The following holds:
105 // Capture's NTP Clock = Local NTP Clock + Local-Capture Clock Offset
106 absl::optional<TimeDelta> local_capture_clock_offset_;
Chen Xingd2a66862019-06-03 12:53:42107};
108
109bool operator==(const RtpPacketInfo& lhs, const RtpPacketInfo& rhs);
110
111inline bool operator!=(const RtpPacketInfo& lhs, const RtpPacketInfo& rhs) {
112 return !(lhs == rhs);
113}
114
115} // namespace webrtc
116
117#endif // API_RTP_PACKET_INFO_H_