blob: ef41476903a0277b2122adde0acefae17a6f177b [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
Danil Chapovalov443f2662020-03-11 12:24:40 +010020#include "api/array_view.h"
Henrik Boströmf2047872019-05-16 13:32:20 +020021#include "modules/rtp_rtcp/include/report_block_data.h"
Niels Möller53382cb2018-11-27 14:05:08 +010022#include "modules/rtp_rtcp/include/rtcp_statistics.h"
Mirko Bonadei3b676722019-07-12 17:35:05 +000023#include "modules/rtp_rtcp/include/rtp_rtcp.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020024#include "modules/rtp_rtcp/include/rtp_rtcp_defines.h"
25#include "modules/rtp_rtcp/source/rtcp_nack_stats.h"
26#include "modules/rtp_rtcp/source/rtcp_packet/dlrr.h"
Steve Anton10542f22019-01-11 09:11:00 -080027#include "rtc_base/critical_section.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020028#include "rtc_base/thread_annotations.h"
29#include "system_wrappers/include/ntp_time.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000030
31namespace webrtc {
spranga790d832016-12-02 07:29:44 -080032class VideoBitrateAllocationObserver;
danilchap59cb2bd2016-08-29 11:08:47 -070033namespace rtcp {
danilchap1b1863a2016-09-20 01:39:54 -070034class CommonHeader;
danilchap1b1863a2016-09-20 01:39:54 -070035class ReportBlock;
36class Rrtr;
spranga790d832016-12-02 07:29:44 -080037class TargetBitrate;
danilchap59cb2bd2016-08-29 11:08:47 -070038class TmmbItem;
39} // namespace rtcp
pwestin@webrtc.org741da942011-09-20 13:52:04 +000040
Danil Chapovalov443f2662020-03-11 12:24:40 +010041class RTCPReceiver final {
danilchapda161d72016-08-19 07:29:46 -070042 public:
danilchap59cb2bd2016-08-29 11:08:47 -070043 class ModuleRtpRtcp {
44 public:
45 virtual void SetTmmbn(std::vector<rtcp::TmmbItem> bounding_set) = 0;
46 virtual void OnRequestSendReport() = 0;
47 virtual void OnReceivedNack(
48 const std::vector<uint16_t>& nack_sequence_numbers) = 0;
49 virtual void OnReceivedRtcpReportBlocks(
50 const ReportBlockList& report_blocks) = 0;
51
52 protected:
53 virtual ~ModuleRtpRtcp() = default;
54 };
55
Mirko Bonadei3b676722019-07-12 17:35:05 +000056 RTCPReceiver(const RtpRtcp::Configuration& config, ModuleRtpRtcp* owner);
Danil Chapovalov443f2662020-03-11 12:24:40 +010057 ~RTCPReceiver();
niklase@google.com470e71d2011-07-07 08:21:25 +000058
Danil Chapovalov443f2662020-03-11 12:24:40 +010059 void IncomingPacket(const uint8_t* packet, size_t packet_size) {
60 IncomingPacket(rtc::MakeArrayView(packet, packet_size));
61 }
62 void IncomingPacket(rtc::ArrayView<const uint8_t> packet);
danilchap59cb2bd2016-08-29 11:08:47 -070063
Danil Chapovalov760c4b42017-09-27 13:25:24 +020064 int64_t LastReceivedReportBlockMs() const;
niklase@google.com470e71d2011-07-07 08:21:25 +000065
danilchapda161d72016-08-19 07:29:46 -070066 void SetRemoteSSRC(uint32_t ssrc);
67 uint32_t RemoteSSRC() const;
niklase@google.com470e71d2011-07-07 08:21:25 +000068
danilchap8bab7962016-12-20 02:46:46 -080069 // Get received cname.
70 int32_t CNAME(uint32_t remote_ssrc, char cname[RTCP_CNAME_SIZE]) const;
niklase@google.com470e71d2011-07-07 08:21:25 +000071
danilchap8bab7962016-12-20 02:46:46 -080072 // Get received NTP.
73 bool NTP(uint32_t* received_ntp_secs,
74 uint32_t* received_ntp_frac,
75 uint32_t* rtcp_arrival_time_secs,
76 uint32_t* rtcp_arrival_time_frac,
danilchapda161d72016-08-19 07:29:46 -070077 uint32_t* rtcp_timestamp) const;
niklase@google.com470e71d2011-07-07 08:21:25 +000078
Mirta Dvornicicb1f063d2018-04-16 11:16:21 +020079 std::vector<rtcp::ReceiveTimeInfo> ConsumeReceivedXrReferenceTimeInfo();
asapersson@webrtc.org8469f7b2013-10-02 13:15:34 +000080
danilchap28b03eb2016-10-05 06:59:44 -070081 // Get rtt.
82 int32_t RTT(uint32_t remote_ssrc,
83 int64_t* last_rtt_ms,
84 int64_t* avg_rtt_ms,
85 int64_t* min_rtt_ms,
86 int64_t* max_rtt_ms) const;
niklase@google.com470e71d2011-07-07 08:21:25 +000087
danilchapda161d72016-08-19 07:29:46 -070088 void SetRtcpXrRrtrStatus(bool enable);
89 bool GetAndResetXrRrRtt(int64_t* rtt_ms);
asapersson@webrtc.org7d6bd222013-10-31 12:14:34 +000090
danilchap8bab7962016-12-20 02:46:46 -080091 // Get statistics.
danilchapda161d72016-08-19 07:29:46 -070092 int32_t StatisticsReceived(std::vector<RTCPReportBlock>* receiveBlocks) const;
Henrik Boströmf2047872019-05-16 13:32:20 +020093 // A snapshot of Report Blocks with additional data of interest to statistics.
94 // Within this list, the sender-source SSRC pair is unique and per-pair the
95 // ReportBlockData represents the latest Report Block that was received for
96 // that pair.
97 std::vector<ReportBlockData> GetLatestReportBlockData() const;
perkj@webrtc.orgce5990c2012-01-11 13:00:08 +000098
danilchapda161d72016-08-19 07:29:46 -070099 // Returns true if we haven't received an RTCP RR for several RTCP
100 // intervals, but only triggers true once.
Jiawei Ou8b5d9d82018-11-15 16:44:37 -0800101 bool RtcpRrTimeout();
mflodman@webrtc.org2f225ca2013-01-09 13:54:43 +0000102
danilchapda161d72016-08-19 07:29:46 -0700103 // Returns true if we haven't received an RTCP RR telling the receive side
104 // has not received RTP packets for too long, i.e. extended highest sequence
105 // number hasn't increased for several RTCP intervals. The function only
106 // returns true once until a new RR is received.
Jiawei Ou8b5d9d82018-11-15 16:44:37 -0800107 bool RtcpRrSequenceNumberTimeout();
mflodman@webrtc.org2f225ca2013-01-09 13:54:43 +0000108
danilchap7851bda2016-09-29 15:28:07 -0700109 std::vector<rtcp::TmmbItem> TmmbrReceived();
danilchap9bf610e2017-02-20 06:03:01 -0800110 // Return true if new bandwidth should be set.
111 bool UpdateTmmbrTimers();
danilchapda161d72016-08-19 07:29:46 -0700112 std::vector<rtcp::TmmbItem> BoundingSet(bool* tmmbr_owner);
danilchap9bf610e2017-02-20 06:03:01 -0800113 // Set new bandwidth and notify remote clients about it.
114 void NotifyTmmbrUpdated();
niklase@google.com470e71d2011-07-07 08:21:25 +0000115
danilchapdd128922016-09-13 12:23:29 -0700116 private:
danilchap92ea6012016-09-23 10:36:03 -0700117 struct PacketInformation;
danilchap9bf610e2017-02-20 06:03:01 -0800118 struct TmmbrInformation;
Mirta Dvornicicb1f063d2018-04-16 11:16:21 +0200119 struct RrtrInformation;
danilchapefa966b2017-02-17 06:23:15 -0800120 struct LastFirStatus;
danilchap28b03eb2016-10-05 06:59:44 -0700121 // RTCP report blocks mapped by remote SSRC.
Henrik Boströmf2047872019-05-16 13:32:20 +0200122 using ReportBlockDataMap = std::map<uint32_t, ReportBlockData>;
danilchap28b03eb2016-10-05 06:59:44 -0700123 // RTCP report blocks map mapped by source SSRC.
Henrik Boströmf2047872019-05-16 13:32:20 +0200124 using ReportBlockMap = std::map<uint32_t, ReportBlockDataMap>;
danilchapdd128922016-09-13 12:23:29 -0700125
Danil Chapovalov443f2662020-03-11 12:24:40 +0100126 bool ParseCompoundPacket(rtc::ArrayView<const uint8_t> packet,
danilchap92ea6012016-09-23 10:36:03 -0700127 PacketInformation* packet_information);
danilchapdd128922016-09-13 12:23:29 -0700128
danilchap8bab7962016-12-20 02:46:46 -0800129 void TriggerCallbacksFromRtcpPacket(
danilchap92ea6012016-09-23 10:36:03 -0700130 const PacketInformation& packet_information);
danilchapdd128922016-09-13 12:23:29 -0700131
danilchapec067e92017-02-21 05:38:19 -0800132 TmmbrInformation* FindOrCreateTmmbrInfo(uint32_t remote_ssrc)
danilchap56359be2017-09-07 07:53:45 -0700133 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapec067e92017-02-21 05:38:19 -0800134 // Update TmmbrInformation (if present) is alive.
135 void UpdateTmmbrRemoteIsAlive(uint32_t remote_ssrc)
danilchap56359be2017-09-07 07:53:45 -0700136 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchap9bf610e2017-02-20 06:03:01 -0800137 TmmbrInformation* GetTmmbrInformation(uint32_t remote_ssrc)
danilchap56359be2017-09-07 07:53:45 -0700138 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000139
danilchap92ea6012016-09-23 10:36:03 -0700140 void HandleSenderReport(const rtcp::CommonHeader& rtcp_block,
141 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700142 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
Danil Chapovalov91511f12016-09-15 16:24:02 +0200143
danilchap92ea6012016-09-23 10:36:03 -0700144 void HandleReceiverReport(const rtcp::CommonHeader& rtcp_block,
145 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700146 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000147
danilchap1b1863a2016-09-20 01:39:54 -0700148 void HandleReportBlock(const rtcp::ReportBlock& report_block,
danilchap92ea6012016-09-23 10:36:03 -0700149 PacketInformation* packet_information,
danilchap8bab7962016-12-20 02:46:46 -0800150 uint32_t remote_ssrc)
danilchap56359be2017-09-07 07:53:45 -0700151 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000152
danilchap8bab7962016-12-20 02:46:46 -0800153 void HandleSdes(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700154 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700155 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000156
danilchap1b1863a2016-09-20 01:39:54 -0700157 void HandleXr(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700158 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700159 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000160
danilchap92ea6012016-09-23 10:36:03 -0700161 void HandleXrReceiveReferenceTime(uint32_t sender_ssrc,
162 const rtcp::Rrtr& rrtr)
danilchap56359be2017-09-07 07:53:45 -0700163 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000164
danilchap92ea6012016-09-23 10:36:03 -0700165 void HandleXrDlrrReportBlock(const rtcp::ReceiveTimeInfo& rti)
danilchap56359be2017-09-07 07:53:45 -0700166 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700167
sprangb32aaf92017-08-28 05:49:12 -0700168 void HandleXrTargetBitrate(uint32_t ssrc,
169 const rtcp::TargetBitrate& target_bitrate,
spranga790d832016-12-02 07:29:44 -0800170 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700171 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
spranga790d832016-12-02 07:29:44 -0800172
danilchap8bab7962016-12-20 02:46:46 -0800173 void HandleNack(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700174 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700175 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700176
Sebastian Janssone1795f42019-07-24 11:38:03 +0200177 void HandleApp(const rtcp::CommonHeader& rtcp_block,
178 PacketInformation* packet_information)
179 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
180
danilchap8bab7962016-12-20 02:46:46 -0800181 void HandleBye(const rtcp::CommonHeader& rtcp_block)
danilchap56359be2017-09-07 07:53:45 -0700182 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700183
danilchap8bab7962016-12-20 02:46:46 -0800184 void HandlePli(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700185 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700186 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700187
danilchap1b1863a2016-09-20 01:39:54 -0700188 void HandlePsfbApp(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700189 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700190 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700191
danilchap8bab7962016-12-20 02:46:46 -0800192 void HandleTmmbr(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700193 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700194 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000195
danilchap8bab7962016-12-20 02:46:46 -0800196 void HandleTmmbn(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700197 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700198 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000199
danilchap8bab7962016-12-20 02:46:46 -0800200 void HandleSrReq(const rtcp::CommonHeader& rtcp_block,
201 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700202 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000203
danilchap8bab7962016-12-20 02:46:46 -0800204 void HandleFir(const rtcp::CommonHeader& rtcp_block,
danilchap92ea6012016-09-23 10:36:03 -0700205 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700206 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
danilchapda161d72016-08-19 07:29:46 -0700207
danilchap92ea6012016-09-23 10:36:03 -0700208 void HandleTransportFeedback(const rtcp::CommonHeader& rtcp_block,
209 PacketInformation* packet_information)
danilchap56359be2017-09-07 07:53:45 -0700210 RTC_EXCLUSIVE_LOCKS_REQUIRED(rtcp_receiver_lock_);
Erik Språng6b8d3552015-09-24 15:06:57 +0200211
danilchap8bab7962016-12-20 02:46:46 -0800212 Clock* const clock_;
Peter Boströmfe7a80c2015-04-23 17:53:17 +0200213 const bool receiver_only_;
danilchap8bab7962016-12-20 02:46:46 -0800214 ModuleRtpRtcp* const rtp_rtcp_;
Erik Språng6841d252019-10-15 14:29:11 +0200215 const uint32_t main_ssrc_;
216 const std::set<uint32_t> registered_ssrcs_;
niklase@google.com470e71d2011-07-07 08:21:25 +0000217
spranga790d832016-12-02 07:29:44 -0800218 RtcpBandwidthObserver* const rtcp_bandwidth_observer_;
219 RtcpIntraFrameObserver* const rtcp_intra_frame_observer_;
Elad Alon0a8562e2019-04-09 11:55:13 +0200220 RtcpLossNotificationObserver* const rtcp_loss_notification_observer_;
Sebastian Janssone1795f42019-07-24 11:38:03 +0200221 NetworkStateEstimateObserver* const network_state_estimate_observer_;
spranga790d832016-12-02 07:29:44 -0800222 TransportFeedbackObserver* const transport_feedback_observer_;
223 VideoBitrateAllocationObserver* const bitrate_allocation_observer_;
Jiawei Ou8b5d9d82018-11-15 16:44:37 -0800224 const int report_interval_ms_;
niklase@google.com470e71d2011-07-07 08:21:25 +0000225
danilchap8bab7962016-12-20 02:46:46 -0800226 rtc::CriticalSection rtcp_receiver_lock_;
danilchap56359be2017-09-07 07:53:45 -0700227 uint32_t remote_ssrc_ RTC_GUARDED_BY(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000228
danilchap8bab7962016-12-20 02:46:46 -0800229 // Received sender report.
danilchap56359be2017-09-07 07:53:45 -0700230 NtpTime remote_sender_ntp_time_ RTC_GUARDED_BY(rtcp_receiver_lock_);
231 uint32_t remote_sender_rtp_time_ RTC_GUARDED_BY(rtcp_receiver_lock_);
danilchap0b4b7272016-10-06 09:24:45 -0700232 // When did we receive the last send report.
danilchap56359be2017-09-07 07:53:45 -0700233 NtpTime last_received_sr_ntp_ RTC_GUARDED_BY(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000234
Mirta Dvornicicb1f063d2018-04-16 11:16:21 +0200235 // Received RRTR information in ascending receive time order.
236 std::list<RrtrInformation> received_rrtrs_
237 RTC_GUARDED_BY(rtcp_receiver_lock_);
238 // Received RRTR information mapped by remote ssrc.
239 std::map<uint32_t, std::list<RrtrInformation>::iterator>
240 received_rrtrs_ssrc_it_ RTC_GUARDED_BY(rtcp_receiver_lock_);
241
asapersson@webrtc.org7d6bd222013-10-31 12:14:34 +0000242 // Estimated rtt, zero when there is no valid estimate.
danilchap56359be2017-09-07 07:53:45 -0700243 bool xr_rrtr_status_ RTC_GUARDED_BY(rtcp_receiver_lock_);
pkasting@chromium.org16825b12015-01-12 21:51:21 +0000244 int64_t xr_rr_rtt_ms_;
asapersson@webrtc.org8469f7b2013-10-02 13:15:34 +0000245
danilchap56359be2017-09-07 07:53:45 -0700246 int64_t oldest_tmmbr_info_ms_ RTC_GUARDED_BY(rtcp_receiver_lock_);
danilchap9bf610e2017-02-20 06:03:01 -0800247 // Mapped by remote ssrc.
248 std::map<uint32_t, TmmbrInformation> tmmbr_infos_
danilchap56359be2017-09-07 07:53:45 -0700249 RTC_GUARDED_BY(rtcp_receiver_lock_);
danilchap9bf610e2017-02-20 06:03:01 -0800250
danilchap56359be2017-09-07 07:53:45 -0700251 ReportBlockMap received_report_blocks_ RTC_GUARDED_BY(rtcp_receiver_lock_);
252 std::map<uint32_t, LastFirStatus> last_fir_
253 RTC_GUARDED_BY(rtcp_receiver_lock_);
danilchap95321242016-09-27 07:05:32 -0700254 std::map<uint32_t, std::string> received_cnames_
danilchap56359be2017-09-07 07:53:45 -0700255 RTC_GUARDED_BY(rtcp_receiver_lock_);
niklase@google.com470e71d2011-07-07 08:21:25 +0000256
Danil Chapovalov760c4b42017-09-27 13:25:24 +0200257 // The last time we received an RTCP Report block for this module.
258 int64_t last_received_rb_ms_ RTC_GUARDED_BY(rtcp_receiver_lock_);
mflodman@webrtc.org2f225ca2013-01-09 13:54:43 +0000259
asapersson@webrtc.orgcb791412014-12-18 14:30:32 +0000260 // The time we last received an RTCP RR telling we have successfully
mflodman@webrtc.org2f225ca2013-01-09 13:54:43 +0000261 // delivered RTP packet to the remote side.
danilchap8bab7962016-12-20 02:46:46 -0800262 int64_t last_increased_sequence_number_ms_;
stefan@webrtc.org8ca8a712013-04-23 16:48:32 +0000263
Danil Chapovalovbd74d5c2020-03-12 09:22:44 +0100264 RtcpStatisticsCallback* const stats_callback_;
265 RtcpCnameCallback* const cname_callback_;
Henrik Boströmf2047872019-05-16 13:32:20 +0200266 // TODO(hbos): Remove RtcpStatisticsCallback in favor of
267 // ReportBlockDataObserver; the ReportBlockData contains a superset of the
268 // RtcpStatistics data.
Danil Chapovalovbd74d5c2020-03-12 09:22:44 +0100269 ReportBlockDataObserver* const report_block_data_observer_;
asapersson@webrtc.org8098e072014-02-19 11:59:02 +0000270
pbos@webrtc.org1d0fa5d2015-02-19 12:47:00 +0000271 RtcpPacketTypeCounterObserver* const packet_type_counter_observer_;
asapersson@webrtc.org8098e072014-02-19 11:59:02 +0000272 RtcpPacketTypeCounter packet_type_counter_;
asapersson@webrtc.org2dd31342014-10-29 12:42:30 +0000273
danilchap84432382017-02-09 05:21:42 -0800274 RtcpNackStats nack_stats_;
Erik Språng6b8d3552015-09-24 15:06:57 +0200275
276 size_t num_skipped_packets_;
danilchap8bab7962016-12-20 02:46:46 -0800277 int64_t last_skipped_packets_warning_ms_;
niklase@google.com470e71d2011-07-07 08:21:25 +0000278};
pbos@webrtc.orgd900e8b2013-07-03 15:12:26 +0000279} // namespace webrtc
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200280#endif // MODULES_RTP_RTCP_SOURCE_RTCP_RECEIVER_H_