blob: f2df0ed2f53733798653acb764a9df5fe945aa47 [file] [log] [blame]
sprang@webrtc.orgccd42842014-01-07 09:54:34 +00001/*
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
11#include "webrtc/video/send_statistics_proxy.h"
12
13#include <map>
14
15#include "webrtc/system_wrappers/interface/critical_section_wrapper.h"
16
17namespace webrtc {
18
19SendStatisticsProxy::SendStatisticsProxy(
stefan@webrtc.org168f23f2014-07-11 13:44:02 +000020 const VideoSendStream::Config& config)
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000021 : config_(config),
pbos@webrtc.orgde1429e2014-04-28 13:00:21 +000022 crit_(CriticalSectionWrapper::CreateCriticalSection()) {
23}
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000024
25SendStatisticsProxy::~SendStatisticsProxy() {}
26
27void SendStatisticsProxy::OutgoingRate(const int video_channel,
28 const unsigned int framerate,
29 const unsigned int bitrate) {
pbos@webrtc.orgde1429e2014-04-28 13:00:21 +000030 CriticalSectionScoped lock(crit_.get());
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000031 stats_.encode_frame_rate = framerate;
stefan@webrtc.org0bae1fa2014-11-05 14:05:29 +000032 stats_.media_bitrate_bps = bitrate;
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000033}
34
henrik.lundin@webrtc.orgb10363f2014-03-13 13:31:21 +000035void SendStatisticsProxy::SuspendChange(int video_channel, bool is_suspended) {
pbos@webrtc.orgde1429e2014-04-28 13:00:21 +000036 CriticalSectionScoped lock(crit_.get());
henrik.lundin@webrtc.orgb10363f2014-03-13 13:31:21 +000037 stats_.suspended = is_suspended;
38}
39
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000040void SendStatisticsProxy::CapturedFrameRate(const int capture_id,
41 const unsigned char frame_rate) {
pbos@webrtc.orgde1429e2014-04-28 13:00:21 +000042 CriticalSectionScoped lock(crit_.get());
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000043 stats_.input_frame_rate = frame_rate;
44}
45
46VideoSendStream::Stats SendStatisticsProxy::GetStats() const {
stefan@webrtc.org168f23f2014-07-11 13:44:02 +000047 CriticalSectionScoped lock(crit_.get());
48 return stats_;
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000049}
50
stefan@webrtc.org0bae1fa2014-11-05 14:05:29 +000051SsrcStats* SendStatisticsProxy::GetStatsEntry(uint32_t ssrc) {
52 std::map<uint32_t, SsrcStats>::iterator it = stats_.substreams.find(ssrc);
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000053 if (it != stats_.substreams.end())
54 return &it->second;
55
56 if (std::find(config_.rtp.ssrcs.begin(), config_.rtp.ssrcs.end(), ssrc) ==
stefan@webrtc.org58e2d262014-08-14 15:10:49 +000057 config_.rtp.ssrcs.end() &&
58 std::find(config_.rtp.rtx.ssrcs.begin(),
59 config_.rtp.rtx.ssrcs.end(),
60 ssrc) == config_.rtp.rtx.ssrcs.end()) {
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000061 return NULL;
stefan@webrtc.org58e2d262014-08-14 15:10:49 +000062 }
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000063
64 return &stats_.substreams[ssrc]; // Insert new entry and return ptr.
65}
66
67void SendStatisticsProxy::StatisticsUpdated(const RtcpStatistics& statistics,
68 uint32_t ssrc) {
pbos@webrtc.orgde1429e2014-04-28 13:00:21 +000069 CriticalSectionScoped lock(crit_.get());
stefan@webrtc.org0bae1fa2014-11-05 14:05:29 +000070 SsrcStats* stats = GetStatsEntry(ssrc);
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000071 if (stats == NULL)
72 return;
73
74 stats->rtcp_stats = statistics;
75}
76
77void SendStatisticsProxy::DataCountersUpdated(
78 const StreamDataCounters& counters,
79 uint32_t ssrc) {
pbos@webrtc.orgde1429e2014-04-28 13:00:21 +000080 CriticalSectionScoped lock(crit_.get());
stefan@webrtc.org0bae1fa2014-11-05 14:05:29 +000081 SsrcStats* stats = GetStatsEntry(ssrc);
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000082 if (stats == NULL)
83 return;
84
85 stats->rtp_stats = counters;
86}
87
stefan@webrtc.org0bae1fa2014-11-05 14:05:29 +000088void SendStatisticsProxy::Notify(const BitrateStatistics& total_stats,
89 const BitrateStatistics& retransmit_stats,
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000090 uint32_t ssrc) {
pbos@webrtc.orgde1429e2014-04-28 13:00:21 +000091 CriticalSectionScoped lock(crit_.get());
stefan@webrtc.org0bae1fa2014-11-05 14:05:29 +000092 SsrcStats* stats = GetStatsEntry(ssrc);
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000093 if (stats == NULL)
94 return;
95
stefan@webrtc.org0bae1fa2014-11-05 14:05:29 +000096 stats->total_bitrate_bps = total_stats.bitrate_bps;
97 stats->retransmit_bitrate_bps = retransmit_stats.bitrate_bps;
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000098}
99
100void SendStatisticsProxy::FrameCountUpdated(FrameType frame_type,
101 uint32_t frame_count,
102 const unsigned int ssrc) {
pbos@webrtc.orgde1429e2014-04-28 13:00:21 +0000103 CriticalSectionScoped lock(crit_.get());
stefan@webrtc.org0bae1fa2014-11-05 14:05:29 +0000104 SsrcStats* stats = GetStatsEntry(ssrc);
sprang@webrtc.orgccd42842014-01-07 09:54:34 +0000105 if (stats == NULL)
106 return;
107
108 switch (frame_type) {
109 case kVideoFrameDelta:
110 stats->delta_frames = frame_count;
111 break;
112 case kVideoFrameKey:
113 stats->key_frames = frame_count;
114 break;
115 case kFrameEmpty:
116 case kAudioFrameSpeech:
117 case kAudioFrameCN:
118 break;
119 }
120}
121
stefan@webrtc.org168f23f2014-07-11 13:44:02 +0000122void SendStatisticsProxy::SendSideDelayUpdated(int avg_delay_ms,
123 int max_delay_ms,
124 uint32_t ssrc) {
125 CriticalSectionScoped lock(crit_.get());
stefan@webrtc.org0bae1fa2014-11-05 14:05:29 +0000126 SsrcStats* stats = GetStatsEntry(ssrc);
stefan@webrtc.org168f23f2014-07-11 13:44:02 +0000127 if (stats == NULL)
128 return;
129 stats->avg_delay_ms = avg_delay_ms;
130 stats->max_delay_ms = max_delay_ms;
131}
132
sprang@webrtc.orgccd42842014-01-07 09:54:34 +0000133} // namespace webrtc