blob: 5b92d55609274a2338dee4b6dd07da1c97616dcd [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
pwestin@webrtc.orgf6bb77a2012-01-24 17:16:59 +00002 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
niklase@google.com470e71d2011-07-07 08:21:25 +00003 *
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
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef MODULES_RTP_RTCP_SOURCE_RTCP_RECEIVER_H_
12#define MODULES_RTP_RTCP_SOURCE_RTCP_RECEIVER_H_
niklase@google.com470e71d2011-07-07 08:21:25 +000013
Mirta Dvornicicb1f063d2018-04-16 11:16:21 +020014#include <list>
pwestin@webrtc.org26f8d9c2012-01-19 15:53:09 +000015#include <map>
stefan@webrtc.org28a331e2013-09-17 07:49:56 +000016#include <set>
danilchap95321242016-09-27 07:05:32 -070017#include <string>
danilchapb8b6fbb2015-12-10 05:05:27 -080018#include <vector>
perkj@webrtc.orgce5990c2012-01-11 13:00:08 +000019
Henrik Boströmf2047872019-05-16 13:32:20 +020020#include "modules/rtp_rtcp/include/report_block_data.h"
Niels Möller53382cb2018-11-27 14:05:08 +010021#include "modules/rtp_rtcp/include/rtcp_statistics.h"
Mirko Bonadei3b676722019-07-12 17:35:05 +000022#include "modules/rtp_rtcp/include/rtp_rtcp.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020023#include "modules/rtp_rtcp/include/rtp_rtcp_defines.h"
24#include "modules/rtp_rtcp/source/rtcp_nack_stats.h"
25#include "modules/rtp_rtcp/source/rtcp_packet/dlrr.h"
Steve Anton10542f22019-01-11 09:11:00 -080026#include "rtc_base/critical_section.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020027#include "rtc_base/thread_annotations.h"
28#include "system_wrappers/include/ntp_time.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000029
30namespace webrtc {
spranga790d832016-12-02 07:29:44 -080031class VideoBitrateAllocationObserver;
danilchap59cb2bd2016-08-29 11:08:47 -070032namespace rtcp {
danilchap1b1863a2016-09-20 01:39:54 -070033class CommonHeader;
danilchap1b1863a2016-09-20 01:39:54 -070034class ReportBlock;
35class Rrtr;
spranga790d832016-12-02 07:29:44 -080036class TargetBitrate;
danilchap59cb2bd2016-08-29 11:08:47 -070037class TmmbItem;
38} // namespace rtcp
pwestin@webrtc.org741da942011-09-20 13:52:04 +000039
danilchapda161d72016-08-19 07:29:46 -070040class RTCPReceiver {
41 public:
danilchap59cb2bd2016-08-29 11:08:47 -070042 class ModuleRtpRtcp {
43 public:
44 virtual void SetTmmbn(std::vector<rtcp::TmmbItem> bounding_set) = 0;
45 virtual void OnRequestSendReport() = 0;
46 virtual void OnReceivedNack(
47 const std::vector<uint16_t>& nack_sequence_numbers) = 0;
48 virtual void OnReceivedRtcpReportBlocks(
49 const ReportBlockList& report_blocks) = 0;
50
51 protected:
52 virtual ~ModuleRtpRtcp() = default;
53 };
54
Mirko Bonadei3b676722019-07-12 17:35:05 +000055 RTCPReceiver(const RtpRtcp::Configuration& config, ModuleRtpRtcp* owner);
danilchapda161d72016-08-19 07:29:46 -070056 virtual ~RTCPReceiver();
niklase@google.com470e71d2011-07-07 08:21:25 +000057
nisse479d3d72017-09-13 07:53:37 -070058 void IncomingPacket(const uint8_t* packet, size_t packet_size);
danilchap59cb2bd2016-08-29 11:08:47 -070059
Danil Chapovalov760c4b42017-09-27 13:25:24 +020060 int64_t LastReceivedReportBlockMs() const;
niklase@google.com470e71d2011-07-07 08:21:25 +000061
danilchapda161d72016-08-19 07:29:46 -070062 void SetRemoteSSRC(uint32_t ssrc);
63 uint32_t RemoteSSRC() const;
niklase@google.com470e71d2011-07-07 08:21:25 +000064
danilchap8bab7962016-12-20 02:46:46 -080065 // Get received cname.
66 int32_t CNAME(uint32_t remote_ssrc, char cname[RTCP_CNAME_SIZE]) const;
niklase@google.com470e71d2011-07-07 08:21:25 +000067
danilchap8bab7962016-12-20 02:46:46 -080068 // Get received NTP.
69 bool NTP(uint32_t* received_ntp_secs,
70 uint32_t* received_ntp_frac,
71 uint32_t* rtcp_arrival_time_secs,
72 uint32_t* rtcp_arrival_time_frac,
danilchapda161d72016-08-19 07:29:46 -070073 uint32_t* rtcp_timestamp) const;
niklase@google.com470e71d2011-07-07 08:21:25 +000074
Mirta Dvornicicb1f063d2018-04-16 11:16:21 +020075 std::vector<rtcp::ReceiveTimeInfo> ConsumeReceivedXrReferenceTimeInfo();
asapersson@webrtc.org8469f7b2013-10-02 13:15:34 +000076
danilchap28b03eb2016-10-05 06:59:44 -070077 // Get rtt.
78 int32_t RTT(uint32_t remote_ssrc,
79 int64_t* last_rtt_ms,
80 int64_t* avg_rtt_ms,
81 int64_t* min_rtt_ms,
82 int64_t* max_rtt_ms) const;
niklase@google.com470e71d2011-07-07 08:21:25 +000083
danilchapda161d72016-08-19 07:29:46 -070084 void SetRtcpXrRrtrStatus(bool enable);
85 bool GetAndResetXrRrRtt(int64_t* rtt_ms);
asapersson@webrtc.org7d6bd222013-10-31 12:14:34 +000086
danilchap8bab7962016-12-20 02:46:46 -080087 // Get statistics.
danilchapda161d72016-08-19 07:29:46 -070088 int32_t StatisticsReceived(std::vector<RTCPReportBlock>* receiveBlocks) const;
Henrik Boströmf2047872019-05-16 13:32:20 +020089 // A snapshot of Report Blocks with additional data of interest to statistics.
90 // Within this list, the sender-source SSRC pair is unique and per-pair the
91 // ReportBlockData represents the latest Report Block that was received for
92 // that pair.
93 std::vector<ReportBlockData> GetLatestReportBlockData() const;
perkj@webrtc.orgce5990c2012-01-11 13:00:08 +000094
danilchapda161d72016-08-19 07:29:46 -070095 // Returns true if we haven't received an RTCP RR for several RTCP
96 // intervals, but only triggers true once.
Jiawei Ou8b5d9d82018-11-15 16:44:37 -080097 bool RtcpRrTimeout();
mflodman@webrtc.org2f225ca2013-01-09 13:54:43 +000098
danilchapda161d72016-08-19 07:29:46 -070099 // Returns true if we haven't received an RTCP RR telling the receive side
100 // has not received RTP packets for too long, i.e. extended highest sequence
101 // number hasn't increased for several RTCP intervals. The function only
102 // returns true once until a new RR is received.
Jiawei Ou8b5d9d82018-11-15 16:44:37 -0800103 bool RtcpRrSequenceNumberTimeout();
mflodman@webrtc.org2f225ca2013-01-09 13:54:43 +0000104
danilchap7851bda2016-09-29 15:28:07 -0700105 std::vector<rtcp::TmmbItem> TmmbrReceived();
danilchap9bf610e2017-02-20 06:03:01 -0800106 // Return true if new bandwidth should be set.
107 bool UpdateTmmbrTimers();
danilchapda161d72016-08-19 07:29:46 -0700108 std::vector<rtcp::TmmbItem> BoundingSet(bool* tmmbr_owner);
danilchap9bf610e2017-02-20 06:03:01 -0800109 // Set new bandwidth and notify remote clients about it.
110 void NotifyTmmbrUpdated();
niklase@google.com470e71d2011-07-07 08:21:25 +0000111
danilchapda161d72016-08-19 07:29:46 -0700112 void RegisterRtcpStatisticsCallback(RtcpStatisticsCallback* callback);
Niels Möller4d7c4052019-08-05 12:45:19 +0200113 void RegisterRtcpCnameCallback(RtcpCnameCallback* callback);
danilchapda161d72016-08-19 07:29:46 -0700114 RtcpStatisticsCallback* GetRtcpStatisticsCallback();
Henrik Boströmf2047872019-05-16 13:32:20 +0200115 void SetReportBlockDataObserver(ReportBlockDataObserver* observer);
sprang@webrtc.orga6ad6e52013-12-05 09:48:44 +0000116
danilchapdd128922016-09-13 12:23:29 -0700117 private:
danilchap92ea6012016-09-23 10:36:03 -0700118 struct PacketInformation;
danilchap9bf610e2017-02-20 06:03:01 -0800119 struct TmmbrInformation;
Mirta Dvornicicb1f063d2018-04-16 11:16:21 +0200120 struct RrtrInformation;
danilchapefa966b2017-02-17 06:23:15 -0800121 struct LastFirStatus;
danilchap28b03eb2016-10-05 06:59:44 -0700122 // RTCP report blocks mapped by remote SSRC.
Henrik Boströmf2047872019-05-16 13:32:20 +0200123 using ReportBlockDataMap = std::map<uint32_t, ReportBlockData>;
danilchap28b03eb2016-10-05 06:59:44 -0700124 // RTCP report blocks map mapped by source SSRC.
Henrik Boströmf2047872019-05-16 13:32:20 +0200125 using ReportBlockMap = std::map<uint32_t, ReportBlockDataMap>;
danilchapdd128922016-09-13 12:23:29 -0700126
danilchap1b1863a2016-09-20 01:39:54 -0700127 bool ParseCompoundPacket(const uint8_t* packet_begin,
128 const uint8_t* packet_end,
danilchap92ea6012016-09-23 10:36:03 -0700129 PacketInformation* packet_information);
danilchapdd128922016-09-13 12:23:29 -0700130
danilchap8bab7962016-12-20 02:46:46 -0800131 void TriggerCallbacksFromRtcpPacket(
danilchap92ea6012016-09-23 10:36:03 -0700132 const PacketInformation& packet_information);
danilchapdd128922016-09-13 12:23:29 -0700133
danilchapec067e92017-02-21 05:38:19 -0800134 TmmbrInformation* FindOrCreateTmmbrInfo(uint32_t remote_ssrc)
danilchap56359be2017-09-07 07:53:45 -0700135 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapec067e92017-02-21 05:38:19 -0800136 // Update TmmbrInformation (if present) is alive.
137 void UpdateTmmbrRemoteIsAlive(uint32_t remote_ssrc)
danilchap56359be2017-09-07 07:53:45 -0700138 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchap9bf610e2017-02-20 06:03:01 -0800139 TmmbrInformation* GetTmmbrInformation(uint32_t remote_ssrc)
danilchap56359be2017-09-07 07:53:45 -0700140 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000141
danilchap92ea6012016-09-23 10:36:03 -0700142 void HandleSenderReport(const rtcp::CommonHeader& rtcp_block,
143 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700144 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
Danil Chapovalov91511f12016-09-15 16:24:02 +0200145
danilchap92ea6012016-09-23 10:36:03 -0700146 void HandleReceiverReport(const rtcp::CommonHeader& rtcp_block,
147 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700148 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000149
danilchap1b1863a2016-09-20 01:39:54 -0700150 void HandleReportBlock(const rtcp::ReportBlock& report_block,
danilchap92ea6012016-09-23 10:36:03 -0700151 PacketInformation* packet_information,
danilchap8bab7962016-12-20 02:46:46 -0800152 uint32_t remote_ssrc)
danilchap56359be2017-09-07 07:53:45 -0700153 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000154
danilchap8bab7962016-12-20 02:46:46 -0800155 void HandleSdes(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700156 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700157 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000158
danilchap1b1863a2016-09-20 01:39:54 -0700159 void HandleXr(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700160 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700161 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000162
danilchap92ea6012016-09-23 10:36:03 -0700163 void HandleXrReceiveReferenceTime(uint32_t sender_ssrc,
164 const rtcp::Rrtr& rrtr)
danilchap56359be2017-09-07 07:53:45 -0700165 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000166
danilchap92ea6012016-09-23 10:36:03 -0700167 void HandleXrDlrrReportBlock(const rtcp::ReceiveTimeInfo& rti)
danilchap56359be2017-09-07 07:53:45 -0700168 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700169
sprangb32aaf92017-08-28 05:49:12 -0700170 void HandleXrTargetBitrate(uint32_t ssrc,
171 const rtcp::TargetBitrate& target_bitrate,
spranga790d832016-12-02 07:29:44 -0800172 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700173 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
spranga790d832016-12-02 07:29:44 -0800174
danilchap8bab7962016-12-20 02:46:46 -0800175 void HandleNack(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700176 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700177 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700178
Sebastian Janssone1795f42019-07-24 11:38:03 +0200179 void HandleApp(const rtcp::CommonHeader& rtcp_block,
180 PacketInformation* packet_information)
181 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
182
danilchap8bab7962016-12-20 02:46:46 -0800183 void HandleBye(const rtcp::CommonHeader& rtcp_block)
danilchap56359be2017-09-07 07:53:45 -0700184 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700185
danilchap8bab7962016-12-20 02:46:46 -0800186 void HandlePli(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700187 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700188 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700189
danilchap1b1863a2016-09-20 01:39:54 -0700190 void HandlePsfbApp(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700191 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700192 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700193
danilchap8bab7962016-12-20 02:46:46 -0800194 void HandleTmmbr(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700195 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700196 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000197
danilchap8bab7962016-12-20 02:46:46 -0800198 void HandleTmmbn(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700199 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700200 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000201
danilchap8bab7962016-12-20 02:46:46 -0800202 void HandleSrReq(const rtcp::CommonHeader& rtcp_block,
203 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700204 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000205
danilchap8bab7962016-12-20 02:46:46 -0800206 void HandleFir(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700207 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700208 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700209
danilchap92ea6012016-09-23 10:36:03 -0700210 void HandleTransportFeedback(const rtcp::CommonHeader& rtcp_block,
211 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700212 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
Erik Språng6b8d3552015-09-24 15:06:57 +0200213
danilchap8bab7962016-12-20 02:46:46 -0800214 Clock* const clock_;
Peter Boströmfe7a80c2015-04-23 17:53:17 +0200215 const bool receiver_only_;
danilchap8bab7962016-12-20 02:46:46 -0800216 ModuleRtpRtcp* const rtp_rtcp_;
Erik Språng6841d252019-10-15 14:29:11 +0200217 const uint32_t main_ssrc_;
218 const std::set<uint32_t> registered_ssrcs_;
niklase@google.com470e71d2011-07-07 08:21:25 +0000219
spranga790d832016-12-02 07:29:44 -0800220 rtc::CriticalSection feedbacks_lock_;
221 RtcpBandwidthObserver* const rtcp_bandwidth_observer_;
222 RtcpIntraFrameObserver* const rtcp_intra_frame_observer_;
Elad Alon0a8562e2019-04-09 11:55:13 +0200223 RtcpLossNotificationObserver* const rtcp_loss_notification_observer_;
Sebastian Janssone1795f42019-07-24 11:38:03 +0200224 NetworkStateEstimateObserver* const network_state_estimate_observer_;
spranga790d832016-12-02 07:29:44 -0800225 TransportFeedbackObserver* const transport_feedback_observer_;
226 VideoBitrateAllocationObserver* const bitrate_allocation_observer_;
Jiawei Ou8b5d9d82018-11-15 16:44:37 -0800227 const int report_interval_ms_;
niklase@google.com470e71d2011-07-07 08:21:25 +0000228
danilchap8bab7962016-12-20 02:46:46 -0800229 rtc::CriticalSection rtcp_receiver_lock_;
danilchap56359be2017-09-07 07:53:45 -0700230 uint32_t remote_ssrc_ RTC_GUARDED_BY(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000231
danilchap8bab7962016-12-20 02:46:46 -0800232 // Received sender report.
danilchap56359be2017-09-07 07:53:45 -0700233 NtpTime remote_sender_ntp_time_ RTC_GUARDED_BY(rtcp_receiver_lock_);
234 uint32_t remote_sender_rtp_time_ RTC_GUARDED_BY(rtcp_receiver_lock_);
danilchap0b4b7272016-10-06 09:24:45 -0700235 // When did we receive the last send report.
danilchap56359be2017-09-07 07:53:45 -0700236 NtpTime last_received_sr_ntp_ RTC_GUARDED_BY(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000237
Mirta Dvornicicb1f063d2018-04-16 11:16:21 +0200238 // Received RRTR information in ascending receive time order.
239 std::list<RrtrInformation> received_rrtrs_
240 RTC_GUARDED_BY(rtcp_receiver_lock_);
241 // Received RRTR information mapped by remote ssrc.
242 std::map<uint32_t, std::list<RrtrInformation>::iterator>
243 received_rrtrs_ssrc_it_ RTC_GUARDED_BY(rtcp_receiver_lock_);
244
asapersson@webrtc.org7d6bd222013-10-31 12:14:34 +0000245 // Estimated rtt, zero when there is no valid estimate.
danilchap56359be2017-09-07 07:53:45 -0700246 bool xr_rrtr_status_ RTC_GUARDED_BY(rtcp_receiver_lock_);
pkasting@chromium.org16825b12015-01-12 21:51:21 +0000247 int64_t xr_rr_rtt_ms_;
asapersson@webrtc.org8469f7b2013-10-02 13:15:34 +0000248
danilchap56359be2017-09-07 07:53:45 -0700249 int64_t oldest_tmmbr_info_ms_ RTC_GUARDED_BY(rtcp_receiver_lock_);
danilchap9bf610e2017-02-20 06:03:01 -0800250 // Mapped by remote ssrc.
251 std::map<uint32_t, TmmbrInformation> tmmbr_infos_
danilchap56359be2017-09-07 07:53:45 -0700252 RTC_GUARDED_BY(rtcp_receiver_lock_);
danilchap9bf610e2017-02-20 06:03:01 -0800253
danilchap56359be2017-09-07 07:53:45 -0700254 ReportBlockMap received_report_blocks_ RTC_GUARDED_BY(rtcp_receiver_lock_);
255 std::map<uint32_t, LastFirStatus> last_fir_
256 RTC_GUARDED_BY(rtcp_receiver_lock_);
danilchap95321242016-09-27 07:05:32 -0700257 std::map<uint32_t, std::string> received_cnames_
danilchap56359be2017-09-07 07:53:45 -0700258 RTC_GUARDED_BY(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000259
Danil Chapovalov760c4b42017-09-27 13:25:24 +0200260 // The last time we received an RTCP Report block for this module.
261 int64_t last_received_rb_ms_ RTC_GUARDED_BY(rtcp_receiver_lock_);
mflodman@webrtc.org2f225ca2013-01-09 13:54:43 +0000262
asapersson@webrtc.orgcb791412014-12-18 14:30:32 +0000263 // The time we last received an RTCP RR telling we have successfully
mflodman@webrtc.org2f225ca2013-01-09 13:54:43 +0000264 // delivered RTP packet to the remote side.
danilchap8bab7962016-12-20 02:46:46 -0800265 int64_t last_increased_sequence_number_ms_;
stefan@webrtc.org8ca8a712013-04-23 16:48:32 +0000266
danilchap56359be2017-09-07 07:53:45 -0700267 RtcpStatisticsCallback* stats_callback_ RTC_GUARDED_BY(feedbacks_lock_);
Niels Möller4d7c4052019-08-05 12:45:19 +0200268 RtcpCnameCallback* cname_callback_ RTC_GUARDED_BY(feedbacks_lock_);
Henrik Boströmf2047872019-05-16 13:32:20 +0200269 // TODO(hbos): Remove RtcpStatisticsCallback in favor of
270 // ReportBlockDataObserver; the ReportBlockData contains a superset of the
271 // RtcpStatistics data.
272 ReportBlockDataObserver* report_block_data_observer_
273 RTC_GUARDED_BY(feedbacks_lock_);
asapersson@webrtc.org8098e072014-02-19 11:59:02 +0000274
pbos@webrtc.org1d0fa5d2015-02-19 12:47:00 +0000275 RtcpPacketTypeCounterObserver* const packet_type_counter_observer_;
asapersson@webrtc.org8098e072014-02-19 11:59:02 +0000276 RtcpPacketTypeCounter packet_type_counter_;
asapersson@webrtc.org2dd31342014-10-29 12:42:30 +0000277
danilchap84432382017-02-09 05:21:42 -0800278 RtcpNackStats nack_stats_;
Erik Språng6b8d3552015-09-24 15:06:57 +0200279
280 size_t num_skipped_packets_;
danilchap8bab7962016-12-20 02:46:46 -0800281 int64_t last_skipped_packets_warning_ms_;
niklase@google.com470e71d2011-07-07 08:21:25 +0000282};
pbos@webrtc.orgd900e8b2013-07-03 15:12:26 +0000283} // namespace webrtc
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200284#endif // MODULES_RTP_RTCP_SOURCE_RTCP_RECEIVER_H_