wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2013 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 | |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 11 | #ifndef MODULES_RTP_RTCP_SOURCE_RECEIVE_STATISTICS_IMPL_H_ |
| 12 | #define MODULES_RTP_RTCP_SOURCE_RECEIVE_STATISTICS_IMPL_H_ |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 13 | |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 14 | #include "modules/rtp_rtcp/include/receive_statistics.h" |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 15 | |
Taylor Brandstetter | 8491693 | 2018-06-25 15:50:26 -0700 | [diff] [blame^] | 16 | #include <math.h> |
| 17 | |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 18 | #include <algorithm> |
danilchap | b8b6fbb | 2015-12-10 05:05:27 -0800 | [diff] [blame] | 19 | #include <map> |
danilchap | 0bc8423 | 2017-08-11 08:12:54 -0700 | [diff] [blame] | 20 | #include <vector> |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 21 | |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 22 | #include "rtc_base/criticalsection.h" |
| 23 | #include "rtc_base/rate_statistics.h" |
| 24 | #include "system_wrappers/include/ntp_time.h" |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 25 | |
| 26 | namespace webrtc { |
| 27 | |
stefan@webrtc.org | 286fe0b | 2013-08-21 20:58:21 +0000 | [diff] [blame] | 28 | class StreamStatisticianImpl : public StreamStatistician { |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 29 | public: |
danilchap | ec86be0 | 2017-08-14 05:51:02 -0700 | [diff] [blame] | 30 | StreamStatisticianImpl(uint32_t ssrc, |
| 31 | Clock* clock, |
sprang@webrtc.org | 0e93257 | 2014-01-23 10:00:39 +0000 | [diff] [blame] | 32 | RtcpStatisticsCallback* rtcp_callback, |
| 33 | StreamDataCountersCallback* rtp_callback); |
Danil Chapovalov | 2a5ce2b | 2018-02-07 09:38:31 +0100 | [diff] [blame] | 34 | ~StreamStatisticianImpl() override; |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 35 | |
Taylor Brandstetter | 8491693 | 2018-06-25 15:50:26 -0700 | [diff] [blame^] | 36 | bool GetStatistics(RtcpStatistics* statistics, |
| 37 | bool update_fraction_lost) override; |
Danil Chapovalov | c5267d2 | 2017-09-18 13:57:19 +0200 | [diff] [blame] | 38 | bool GetActiveStatisticsAndReset(RtcpStatistics* statistics); |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 39 | void GetDataCounters(size_t* bytes_received, |
| 40 | uint32_t* packets_received) const override; |
| 41 | void GetReceiveStreamDataCounters( |
| 42 | StreamDataCounters* data_counters) const override; |
| 43 | uint32_t BitrateReceived() const override; |
Niels Möller | eda0087 | 2018-05-23 13:54:51 +0200 | [diff] [blame] | 44 | bool IsRetransmitOfOldPacket(const RTPHeader& header) const override; |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 45 | bool IsPacketInOrder(uint16_t sequence_number) const override; |
stefan@webrtc.org | 286fe0b | 2013-08-21 20:58:21 +0000 | [diff] [blame] | 46 | |
sprang@webrtc.org | 0e93257 | 2014-01-23 10:00:39 +0000 | [diff] [blame] | 47 | void IncomingPacket(const RTPHeader& rtp_header, |
asapersson@webrtc.org | 97d0489 | 2014-12-09 09:47:53 +0000 | [diff] [blame] | 48 | size_t packet_length, |
stefan@webrtc.org | 7bb8f02 | 2013-09-06 13:40:11 +0000 | [diff] [blame] | 49 | bool retransmitted); |
asapersson@webrtc.org | 273fbbb | 2015-01-27 12:17:29 +0000 | [diff] [blame] | 50 | void FecPacketReceived(const RTPHeader& header, size_t packet_length); |
stefan@webrtc.org | 7bb8f02 | 2013-09-06 13:40:11 +0000 | [diff] [blame] | 51 | void SetMaxReorderingThreshold(int max_reordering_threshold); |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 52 | |
| 53 | private: |
Taylor Brandstetter | 8491693 | 2018-06-25 15:50:26 -0700 | [diff] [blame^] | 54 | bool InOrderPacketInternal(uint16_t sequence_number) const |
| 55 | RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_lock_); |
| 56 | RtcpStatistics CalculateRtcpStatistics(bool update_fraction_lost) |
danilchap | 56359be | 2017-09-07 07:53:45 -0700 | [diff] [blame] | 57 | RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_lock_); |
danilchap | 1227e8b | 2015-12-21 11:06:50 -0800 | [diff] [blame] | 58 | void UpdateJitter(const RTPHeader& header, NtpTime receive_time); |
danilchap | ec86be0 | 2017-08-14 05:51:02 -0700 | [diff] [blame] | 59 | StreamDataCounters UpdateCounters(const RTPHeader& rtp_header, |
| 60 | size_t packet_length, |
Taylor Brandstetter | 8491693 | 2018-06-25 15:50:26 -0700 | [diff] [blame^] | 61 | bool retransmitted) |
| 62 | RTC_EXCLUSIVE_LOCKS_REQUIRED(stream_lock_); |
stefan@webrtc.org | 7bb8f02 | 2013-09-06 13:40:11 +0000 | [diff] [blame] | 63 | |
danilchap | ec86be0 | 2017-08-14 05:51:02 -0700 | [diff] [blame] | 64 | const uint32_t ssrc_; |
sprang | cd349d9 | 2016-07-13 09:11:28 -0700 | [diff] [blame] | 65 | Clock* const clock_; |
danilchap | 7c9426c | 2016-04-14 03:05:31 -0700 | [diff] [blame] | 66 | rtc::CriticalSection stream_lock_; |
sprang | cd349d9 | 2016-07-13 09:11:28 -0700 | [diff] [blame] | 67 | RateStatistics incoming_bitrate_; |
stefan@webrtc.org | 7bb8f02 | 2013-09-06 13:40:11 +0000 | [diff] [blame] | 68 | int max_reordering_threshold_; // In number of packets or sequence numbers. |
stefan@webrtc.org | 286fe0b | 2013-08-21 20:58:21 +0000 | [diff] [blame] | 69 | |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 70 | // Stats on received RTP packets. |
| 71 | uint32_t jitter_q4_; |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 72 | |
stefan@webrtc.org | 7bb8f02 | 2013-09-06 13:40:11 +0000 | [diff] [blame] | 73 | int64_t last_receive_time_ms_; |
danilchap | 1227e8b | 2015-12-21 11:06:50 -0800 | [diff] [blame] | 74 | NtpTime last_receive_time_ntp_; |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 75 | uint32_t last_received_timestamp_; |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 76 | uint16_t received_seq_first_; |
| 77 | uint16_t received_seq_max_; |
| 78 | uint16_t received_seq_wraps_; |
| 79 | |
| 80 | // Current counter values. |
pkasting@chromium.org | 4591fbd | 2014-11-20 22:28:14 +0000 | [diff] [blame] | 81 | size_t received_packet_overhead_; |
Taylor Brandstetter | 8491693 | 2018-06-25 15:50:26 -0700 | [diff] [blame^] | 82 | StreamDataCounters receive_counters_ RTC_GUARDED_BY(stream_lock_); |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 83 | |
Taylor Brandstetter | 8491693 | 2018-06-25 15:50:26 -0700 | [diff] [blame^] | 84 | // Used to calculate fraction_lost between reports. |
| 85 | uint32_t last_report_received_packets_ = 0; |
| 86 | uint32_t last_report_extended_seq_max_ = 0; |
| 87 | uint8_t last_fraction_lost_ = 0; |
sprang@webrtc.org | 54ae4ff | 2013-12-19 13:26:02 +0000 | [diff] [blame] | 88 | |
danilchap | ec86be0 | 2017-08-14 05:51:02 -0700 | [diff] [blame] | 89 | // stream_lock_ shouldn't be held when calling callbacks. |
sprang@webrtc.org | 54ae4ff | 2013-12-19 13:26:02 +0000 | [diff] [blame] | 90 | RtcpStatisticsCallback* const rtcp_callback_; |
sprang@webrtc.org | 0e93257 | 2014-01-23 10:00:39 +0000 | [diff] [blame] | 91 | StreamDataCountersCallback* const rtp_callback_; |
stefan@webrtc.org | 286fe0b | 2013-08-21 20:58:21 +0000 | [diff] [blame] | 92 | }; |
| 93 | |
sprang@webrtc.org | 54ae4ff | 2013-12-19 13:26:02 +0000 | [diff] [blame] | 94 | class ReceiveStatisticsImpl : public ReceiveStatistics, |
sprang@webrtc.org | 0e93257 | 2014-01-23 10:00:39 +0000 | [diff] [blame] | 95 | public RtcpStatisticsCallback, |
| 96 | public StreamDataCountersCallback { |
stefan@webrtc.org | 286fe0b | 2013-08-21 20:58:21 +0000 | [diff] [blame] | 97 | public: |
| 98 | explicit ReceiveStatisticsImpl(Clock* clock); |
| 99 | |
Danil Chapovalov | 2a5ce2b | 2018-02-07 09:38:31 +0100 | [diff] [blame] | 100 | ~ReceiveStatisticsImpl() override; |
stefan@webrtc.org | 286fe0b | 2013-08-21 20:58:21 +0000 | [diff] [blame] | 101 | |
danilchap | 0bc8423 | 2017-08-11 08:12:54 -0700 | [diff] [blame] | 102 | // Implement ReceiveStatisticsProvider. |
| 103 | std::vector<rtcp::ReportBlock> RtcpReportBlocks(size_t max_blocks) override; |
| 104 | |
stefan@webrtc.org | 286fe0b | 2013-08-21 20:58:21 +0000 | [diff] [blame] | 105 | // Implement ReceiveStatistics. |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 106 | void IncomingPacket(const RTPHeader& header, |
| 107 | size_t packet_length, |
| 108 | bool retransmitted) override; |
| 109 | void FecPacketReceived(const RTPHeader& header, |
| 110 | size_t packet_length) override; |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 111 | StreamStatistician* GetStatistician(uint32_t ssrc) const override; |
| 112 | void SetMaxReorderingThreshold(int max_reordering_threshold) override; |
stefan@webrtc.org | 286fe0b | 2013-08-21 20:58:21 +0000 | [diff] [blame] | 113 | |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 114 | void RegisterRtcpStatisticsCallback( |
| 115 | RtcpStatisticsCallback* callback) override; |
sprang@webrtc.org | 54ae4ff | 2013-12-19 13:26:02 +0000 | [diff] [blame] | 116 | |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 117 | void RegisterRtpStatisticsCallback( |
| 118 | StreamDataCountersCallback* callback) override; |
sprang@webrtc.org | 54ae4ff | 2013-12-19 13:26:02 +0000 | [diff] [blame] | 119 | |
stefan@webrtc.org | 286fe0b | 2013-08-21 20:58:21 +0000 | [diff] [blame] | 120 | private: |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 121 | void StatisticsUpdated(const RtcpStatistics& statistics, |
| 122 | uint32_t ssrc) override; |
| 123 | void CNameChanged(const char* cname, uint32_t ssrc) override; |
| 124 | void DataCountersUpdated(const StreamDataCounters& counters, |
| 125 | uint32_t ssrc) override; |
sprang@webrtc.org | 0e93257 | 2014-01-23 10:00:39 +0000 | [diff] [blame] | 126 | |
sprang | cd349d9 | 2016-07-13 09:11:28 -0700 | [diff] [blame] | 127 | Clock* const clock_; |
danilchap | 7c9426c | 2016-04-14 03:05:31 -0700 | [diff] [blame] | 128 | rtc::CriticalSection receive_statistics_lock_; |
Danil Chapovalov | d1996b7 | 2018-01-16 11:07:18 +0100 | [diff] [blame] | 129 | uint32_t last_returned_ssrc_; |
Danil Chapovalov | c5267d2 | 2017-09-18 13:57:19 +0200 | [diff] [blame] | 130 | std::map<uint32_t, StreamStatisticianImpl*> statisticians_; |
sprang@webrtc.org | 54ae4ff | 2013-12-19 13:26:02 +0000 | [diff] [blame] | 131 | |
| 132 | RtcpStatisticsCallback* rtcp_stats_callback_; |
sprang@webrtc.org | 0e93257 | 2014-01-23 10:00:39 +0000 | [diff] [blame] | 133 | StreamDataCountersCallback* rtp_stats_callback_; |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 134 | }; |
| 135 | } // namespace webrtc |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 136 | #endif // MODULES_RTP_RTCP_SOURCE_RECEIVE_STATISTICS_IMPL_H_ |