Remove the last getters from VideoReceiveStream stats.
R=stefan@webrtc.org BUG=1667 Review URL: https://webrtc-codereview.appspot.com/32899004 git-svn-id: http://webrtc.googlecode.com/svn/trunk@7965 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
		| @@ -582,8 +582,6 @@ public: | |||||||
|         EncodedImageCallback* observer) = 0; |         EncodedImageCallback* observer) = 0; | ||||||
|     virtual void RegisterPostEncodeImageCallback( |     virtual void RegisterPostEncodeImageCallback( | ||||||
|         EncodedImageCallback* post_encode_callback) = 0; |         EncodedImageCallback* post_encode_callback) = 0; | ||||||
|     virtual void RegisterReceiveFrameCountObserver( |  | ||||||
|         FrameCountObserver* frame_count_observer) = 0; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace webrtc | }  // namespace webrtc | ||||||
|   | |||||||
| @@ -109,8 +109,9 @@ class VCMSendStatisticsCallback { | |||||||
| // Callback class used for informing the user of the incoming bit rate and frame rate. | // Callback class used for informing the user of the incoming bit rate and frame rate. | ||||||
| class VCMReceiveStatisticsCallback { | class VCMReceiveStatisticsCallback { | ||||||
|  public: |  public: | ||||||
|   virtual int32_t OnReceiveStatisticsUpdate(const uint32_t bitRate, |   virtual void OnReceiveRatesUpdated(uint32_t bitRate, uint32_t frameRate) = 0; | ||||||
|                                             const uint32_t frameRate) = 0; |   virtual void OnDiscardedPacketsUpdated(int discarded_packets) = 0; | ||||||
|  |   virtual void OnFrameCountsUpdated(const FrameCounts& frame_counts) = 0; | ||||||
|  |  | ||||||
|  protected: |  protected: | ||||||
|   virtual ~VCMReceiveStatisticsCallback() { |   virtual ~VCMReceiveStatisticsCallback() { | ||||||
|   | |||||||
| @@ -124,7 +124,7 @@ VCMJitterBuffer::VCMJitterBuffer(Clock* clock, EventFactory* event_factory) | |||||||
|       incomplete_frames_(), |       incomplete_frames_(), | ||||||
|       last_decoded_state_(), |       last_decoded_state_(), | ||||||
|       first_packet_since_reset_(true), |       first_packet_since_reset_(true), | ||||||
|       frame_count_observer_(NULL), |       stats_callback_(NULL), | ||||||
|       incoming_frame_rate_(0), |       incoming_frame_rate_(0), | ||||||
|       incoming_frame_count_(0), |       incoming_frame_count_(0), | ||||||
|       time_last_incoming_frame_count_(0), |       time_last_incoming_frame_count_(0), | ||||||
| @@ -570,6 +570,8 @@ VCMFrameBufferEnum VCMJitterBuffer::InsertPacket(const VCMPacket& packet, | |||||||
|     if (packet.sizeBytes > 0) { |     if (packet.sizeBytes > 0) { | ||||||
|       num_discarded_packets_++; |       num_discarded_packets_++; | ||||||
|       num_consecutive_old_packets_++; |       num_consecutive_old_packets_++; | ||||||
|  |       if (stats_callback_ != NULL) | ||||||
|  |         stats_callback_->OnDiscardedPacketsUpdated(num_discarded_packets_); | ||||||
|     } |     } | ||||||
|     // Update last decoded sequence number if the packet arrived late and |     // Update last decoded sequence number if the packet arrived late and | ||||||
|     // belongs to a frame with a timestamp equal to the last decoded |     // belongs to a frame with a timestamp equal to the last decoded | ||||||
| @@ -1040,10 +1042,10 @@ void VCMJitterBuffer::RenderBufferSize(uint32_t* timestamp_start, | |||||||
|   *timestamp_end = decodable_frames_.Back()->TimeStamp(); |   *timestamp_end = decodable_frames_.Back()->TimeStamp(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void VCMJitterBuffer::RegisterFrameCountObserver( | void VCMJitterBuffer::RegisterStatsCallback( | ||||||
|     FrameCountObserver* frame_count_observer) { |     VCMReceiveStatisticsCallback* callback) { | ||||||
|   CriticalSectionScoped cs(crit_sect_); |   CriticalSectionScoped cs(crit_sect_); | ||||||
|   frame_count_observer_ = frame_count_observer; |   stats_callback_ = callback; | ||||||
| } | } | ||||||
|  |  | ||||||
| VCMFrameBuffer* VCMJitterBuffer::GetEmptyFrame() { | VCMFrameBuffer* VCMJitterBuffer::GetEmptyFrame() { | ||||||
| @@ -1118,8 +1120,8 @@ void VCMJitterBuffer::CountFrame(const VCMFrameBuffer& frame) { | |||||||
|     } else { |     } else { | ||||||
|       ++receive_statistics_.delta_frames; |       ++receive_statistics_.delta_frames; | ||||||
|     } |     } | ||||||
|     if (frame_count_observer_ != NULL) |     if (stats_callback_ != NULL) | ||||||
|       frame_count_observer_->FrameCountUpdated(receive_statistics_, 0); |       stats_callback_->OnFrameCountsUpdated(receive_statistics_); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -184,7 +184,7 @@ class VCMJitterBuffer { | |||||||
|   // corresponding to the start and end of the continuous complete buffer. |   // corresponding to the start and end of the continuous complete buffer. | ||||||
|   void RenderBufferSize(uint32_t* timestamp_start, uint32_t* timestamp_end); |   void RenderBufferSize(uint32_t* timestamp_start, uint32_t* timestamp_end); | ||||||
|  |  | ||||||
|   void RegisterFrameCountObserver(FrameCountObserver* observer); |   void RegisterStatsCallback(VCMReceiveStatisticsCallback* callback); | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   class SequenceNumberLessThan { |   class SequenceNumberLessThan { | ||||||
| @@ -303,8 +303,8 @@ class VCMJitterBuffer { | |||||||
|   bool first_packet_since_reset_; |   bool first_packet_since_reset_; | ||||||
|  |  | ||||||
|   // Statistics. |   // Statistics. | ||||||
|  |   VCMReceiveStatisticsCallback* stats_callback_ GUARDED_BY(crit_sect_); | ||||||
|   // Frame counts for each type (key, delta, ...) |   // Frame counts for each type (key, delta, ...) | ||||||
|   FrameCountObserver* frame_count_observer_ GUARDED_BY(crit_sect_); |  | ||||||
|   FrameCounts receive_statistics_; |   FrameCounts receive_statistics_; | ||||||
|   // Latest calculated frame rates of incoming stream. |   // Latest calculated frame rates of incoming stream. | ||||||
|   unsigned int incoming_frame_rate_; |   unsigned int incoming_frame_rate_; | ||||||
|   | |||||||
| @@ -270,9 +270,9 @@ int VCMReceiver::RenderBufferSizeMs() { | |||||||
|   return render_end - render_start; |   return render_end - render_start; | ||||||
| } | } | ||||||
|  |  | ||||||
| void VCMReceiver::RegisterFrameCountObserver( | void VCMReceiver::RegisterStatsCallback( | ||||||
|     FrameCountObserver* frame_count_observer) { |     VCMReceiveStatisticsCallback* callback) { | ||||||
|   jitter_buffer_.RegisterFrameCountObserver(frame_count_observer); |   jitter_buffer_.RegisterStatsCallback(callback); | ||||||
| } | } | ||||||
|  |  | ||||||
| }  // namespace webrtc | }  // namespace webrtc | ||||||
|   | |||||||
| @@ -79,7 +79,7 @@ class VCMReceiver { | |||||||
|   // the time this function is called. |   // the time this function is called. | ||||||
|   int RenderBufferSizeMs(); |   int RenderBufferSizeMs(); | ||||||
|  |  | ||||||
|   void RegisterFrameCountObserver(FrameCountObserver* frame_count_observer); |   void RegisterStatsCallback(VCMReceiveStatisticsCallback* callback); | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   static int32_t GenerateReceiverId(); |   static int32_t GenerateReceiverId(); | ||||||
|   | |||||||
| @@ -278,11 +278,6 @@ class VideoCodingModuleImpl : public VideoCodingModule { | |||||||
|     return receiver_->RegisterRenderBufferSizeCallback(callback); |     return receiver_->RegisterRenderBufferSizeCallback(callback); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   virtual void RegisterReceiveFrameCountObserver( |  | ||||||
|       FrameCountObserver* frame_count_observer) OVERRIDE { |  | ||||||
|     receiver_->RegisterFrameCountObserver(frame_count_observer); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   virtual int32_t Decode(uint16_t maxWaitTimeMs) OVERRIDE { |   virtual int32_t Decode(uint16_t maxWaitTimeMs) OVERRIDE { | ||||||
|     return receiver_->Decode(maxWaitTimeMs); |     return receiver_->Decode(maxWaitTimeMs); | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -182,7 +182,6 @@ class VideoReceiver { | |||||||
|   int32_t Process(); |   int32_t Process(); | ||||||
|  |  | ||||||
|   void RegisterPreDecodeImageCallback(EncodedImageCallback* observer); |   void RegisterPreDecodeImageCallback(EncodedImageCallback* observer); | ||||||
|   void RegisterFrameCountObserver(FrameCountObserver* frame_count_observer); |  | ||||||
|  |  | ||||||
|  protected: |  protected: | ||||||
|   int32_t Decode(const webrtc::VCMEncodedFrame& frame) |   int32_t Decode(const webrtc::VCMEncodedFrame& frame) | ||||||
|   | |||||||
| @@ -74,7 +74,7 @@ int32_t VideoReceiver::Process() { | |||||||
|       uint32_t bitRate; |       uint32_t bitRate; | ||||||
|       uint32_t frameRate; |       uint32_t frameRate; | ||||||
|       _receiver.ReceiveStatistics(&bitRate, &frameRate); |       _receiver.ReceiveStatistics(&bitRate, &frameRate); | ||||||
|       _receiveStatsCallback->OnReceiveStatisticsUpdate(bitRate, frameRate); |       _receiveStatsCallback->OnReceiveRatesUpdated(bitRate, frameRate); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (_decoderTimingCallback != NULL) { |     if (_decoderTimingCallback != NULL) { | ||||||
| @@ -284,6 +284,7 @@ int32_t VideoReceiver::RegisterReceiveCallback( | |||||||
| int32_t VideoReceiver::RegisterReceiveStatisticsCallback( | int32_t VideoReceiver::RegisterReceiveStatisticsCallback( | ||||||
|     VCMReceiveStatisticsCallback* receiveStats) { |     VCMReceiveStatisticsCallback* receiveStats) { | ||||||
|   CriticalSectionScoped cs(process_crit_sect_.get()); |   CriticalSectionScoped cs(process_crit_sect_.get()); | ||||||
|  |   _receiver.RegisterStatsCallback(receiveStats); | ||||||
|   _receiveStatsCallback = receiveStats; |   _receiveStatsCallback = receiveStats; | ||||||
|   return VCM_OK; |   return VCM_OK; | ||||||
| } | } | ||||||
| @@ -666,10 +667,6 @@ void VideoReceiver::RegisterPreDecodeImageCallback( | |||||||
|   CriticalSectionScoped cs(_receiveCritSect); |   CriticalSectionScoped cs(_receiveCritSect); | ||||||
|   pre_decode_image_callback_ = observer; |   pre_decode_image_callback_ = observer; | ||||||
| } | } | ||||||
| void VideoReceiver::RegisterFrameCountObserver( |  | ||||||
|     FrameCountObserver* frame_count_observer) { |  | ||||||
|   _receiver.RegisterFrameCountObserver(frame_count_observer); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| }  // namespace vcm | }  // namespace vcm | ||||||
| }  // namespace webrtc | }  // namespace webrtc | ||||||
|   | |||||||
| @@ -15,13 +15,8 @@ | |||||||
|  |  | ||||||
| namespace webrtc { | namespace webrtc { | ||||||
|  |  | ||||||
| ReceiveStatisticsProxy::ReceiveStatisticsProxy(uint32_t ssrc, | ReceiveStatisticsProxy::ReceiveStatisticsProxy(uint32_t ssrc, Clock* clock) | ||||||
|                                                Clock* clock, |     : clock_(clock), | ||||||
|                                                ViECodec* codec, |  | ||||||
|                                                int channel) |  | ||||||
|     : channel_(channel), |  | ||||||
|       clock_(clock), |  | ||||||
|       codec_(codec), |  | ||||||
|       crit_(CriticalSectionWrapper::CreateCriticalSection()), |       crit_(CriticalSectionWrapper::CreateCriticalSection()), | ||||||
|       // 1000ms window, scale 1000 for ms to s. |       // 1000ms window, scale 1000 for ms to s. | ||||||
|       decode_fps_estimator_(1000, 1000), |       decode_fps_estimator_(1000, 1000), | ||||||
| @@ -32,14 +27,8 @@ ReceiveStatisticsProxy::ReceiveStatisticsProxy(uint32_t ssrc, | |||||||
| ReceiveStatisticsProxy::~ReceiveStatisticsProxy() {} | ReceiveStatisticsProxy::~ReceiveStatisticsProxy() {} | ||||||
|  |  | ||||||
| VideoReceiveStream::Stats ReceiveStatisticsProxy::GetStats() const { | VideoReceiveStream::Stats ReceiveStatisticsProxy::GetStats() const { | ||||||
|   VideoReceiveStream::Stats stats; |   CriticalSectionScoped lock(crit_.get()); | ||||||
|   { |   return stats_; | ||||||
|     CriticalSectionScoped lock(crit_.get()); |  | ||||||
|     stats = stats_; |  | ||||||
|   } |  | ||||||
|   stats.discarded_packets = codec_->GetNumDiscardedPackets(channel_); |  | ||||||
|  |  | ||||||
|   return stats; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void ReceiveStatisticsProxy::IncomingRate(const int video_channel, | void ReceiveStatisticsProxy::IncomingRate(const int video_channel, | ||||||
| @@ -98,10 +87,19 @@ void ReceiveStatisticsProxy::OnRenderedFrame() { | |||||||
|   stats_.render_frame_rate = renders_fps_estimator_.Rate(now); |   stats_.render_frame_rate = renders_fps_estimator_.Rate(now); | ||||||
| } | } | ||||||
|  |  | ||||||
| void ReceiveStatisticsProxy::FrameCountUpdated(const FrameCounts& frame_counts, | void ReceiveStatisticsProxy::OnReceiveRatesUpdated(uint32_t bitRate, | ||||||
|                                                uint32_t ssrc) { |                                                    uint32_t frameRate) { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void ReceiveStatisticsProxy::OnFrameCountsUpdated( | ||||||
|  |     const FrameCounts& frame_counts) { | ||||||
|   CriticalSectionScoped lock(crit_.get()); |   CriticalSectionScoped lock(crit_.get()); | ||||||
|   stats_.frame_counts = frame_counts; |   stats_.frame_counts = frame_counts; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void ReceiveStatisticsProxy::OnDiscardedPacketsUpdated(int discarded_packets) { | ||||||
|  |   CriticalSectionScoped lock(crit_.get()); | ||||||
|  |   stats_.discarded_packets = discarded_packets; | ||||||
|  | } | ||||||
|  |  | ||||||
| }  // namespace webrtc | }  // namespace webrtc | ||||||
|   | |||||||
| @@ -17,6 +17,7 @@ | |||||||
| #include "webrtc/common_types.h" | #include "webrtc/common_types.h" | ||||||
| #include "webrtc/frame_callback.h" | #include "webrtc/frame_callback.h" | ||||||
| #include "webrtc/modules/remote_bitrate_estimator/rate_statistics.h" | #include "webrtc/modules/remote_bitrate_estimator/rate_statistics.h" | ||||||
|  | #include "webrtc/modules/video_coding/main/interface/video_coding_defines.h" | ||||||
| #include "webrtc/video_engine/include/vie_codec.h" | #include "webrtc/video_engine/include/vie_codec.h" | ||||||
| #include "webrtc/video_engine/include/vie_rtp_rtcp.h" | #include "webrtc/video_engine/include/vie_rtp_rtcp.h" | ||||||
| #include "webrtc/video_receive_stream.h" | #include "webrtc/video_receive_stream.h" | ||||||
| @@ -30,14 +31,11 @@ class ViECodec; | |||||||
| class ViEDecoderObserver; | class ViEDecoderObserver; | ||||||
|  |  | ||||||
| class ReceiveStatisticsProxy : public ViEDecoderObserver, | class ReceiveStatisticsProxy : public ViEDecoderObserver, | ||||||
|  |                                public VCMReceiveStatisticsCallback, | ||||||
|                                public RtcpStatisticsCallback, |                                public RtcpStatisticsCallback, | ||||||
|                                public StreamDataCountersCallback, |                                public StreamDataCountersCallback { | ||||||
|                                public FrameCountObserver { |  | ||||||
|  public: |  public: | ||||||
|   ReceiveStatisticsProxy(uint32_t ssrc, |   ReceiveStatisticsProxy(uint32_t ssrc, Clock* clock); | ||||||
|                          Clock* clock, |  | ||||||
|                          ViECodec* codec, |  | ||||||
|                          int channel); |  | ||||||
|   virtual ~ReceiveStatisticsProxy(); |   virtual ~ReceiveStatisticsProxy(); | ||||||
|  |  | ||||||
|   VideoReceiveStream::Stats GetStats() const; |   VideoReceiveStream::Stats GetStats() const; | ||||||
| @@ -45,6 +43,12 @@ class ReceiveStatisticsProxy : public ViEDecoderObserver, | |||||||
|   void OnDecodedFrame(); |   void OnDecodedFrame(); | ||||||
|   void OnRenderedFrame(); |   void OnRenderedFrame(); | ||||||
|  |  | ||||||
|  |   // Overrides VCMReceiveStatisticsCallback | ||||||
|  |   virtual void OnReceiveRatesUpdated(uint32_t bitRate, | ||||||
|  |                                      uint32_t frameRate) OVERRIDE; | ||||||
|  |   virtual void OnFrameCountsUpdated(const FrameCounts& frame_counts) OVERRIDE; | ||||||
|  |   virtual void OnDiscardedPacketsUpdated(int discarded_packets) OVERRIDE; | ||||||
|  |  | ||||||
|   // Overrides ViEDecoderObserver. |   // Overrides ViEDecoderObserver. | ||||||
|   virtual void IncomingCodecChanged(const int video_channel, |   virtual void IncomingCodecChanged(const int video_channel, | ||||||
|                                     const VideoCodec& video_codec) OVERRIDE {} |                                     const VideoCodec& video_codec) OVERRIDE {} | ||||||
| @@ -69,14 +73,8 @@ class ReceiveStatisticsProxy : public ViEDecoderObserver, | |||||||
|   virtual void DataCountersUpdated(const webrtc::StreamDataCounters& counters, |   virtual void DataCountersUpdated(const webrtc::StreamDataCounters& counters, | ||||||
|                                    uint32_t ssrc) OVERRIDE; |                                    uint32_t ssrc) OVERRIDE; | ||||||
|  |  | ||||||
|   // Overrides FrameCountObserver. |  | ||||||
|   virtual void FrameCountUpdated(const FrameCounts& frame_counts, |  | ||||||
|                                  uint32_t ssrc) OVERRIDE; |  | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   const int channel_; |  | ||||||
|   Clock* const clock_; |   Clock* const clock_; | ||||||
|   ViECodec* const codec_; |  | ||||||
|  |  | ||||||
|   scoped_ptr<CriticalSectionWrapper> crit_; |   scoped_ptr<CriticalSectionWrapper> crit_; | ||||||
|   VideoReceiveStream::Stats stats_ GUARDED_BY(crit_); |   VideoReceiveStream::Stats stats_ GUARDED_BY(crit_); | ||||||
|   | |||||||
| @@ -148,8 +148,8 @@ VideoReceiveStream::VideoReceiveStream(webrtc::VideoEngine* video_engine, | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   stats_proxy_.reset(new ReceiveStatisticsProxy(config_.rtp.local_ssrc, clock_, |   stats_proxy_.reset( | ||||||
|                                                 codec_, channel_)); |       new ReceiveStatisticsProxy(config_.rtp.local_ssrc, clock_)); | ||||||
|  |  | ||||||
|   if (rtp_rtcp_->RegisterReceiveChannelRtcpStatisticsCallback( |   if (rtp_rtcp_->RegisterReceiveChannelRtcpStatisticsCallback( | ||||||
|           channel_, stats_proxy_.get()) != 0) { |           channel_, stats_proxy_.get()) != 0) { | ||||||
|   | |||||||
| @@ -129,6 +129,7 @@ ViEChannel::ViEChannel(int32_t channel_id, | |||||||
|       vie_sender_(channel_id), |       vie_sender_(channel_id), | ||||||
|       vie_sync_(vcm_, this), |       vie_sync_(vcm_, this), | ||||||
|       stats_observer_(new ChannelStatsObserver(this)), |       stats_observer_(new ChannelStatsObserver(this)), | ||||||
|  |       vcm_receive_stats_callback_(NULL), | ||||||
|       module_process_thread_(module_process_thread), |       module_process_thread_(module_process_thread), | ||||||
|       codec_observer_(NULL), |       codec_observer_(NULL), | ||||||
|       do_key_frame_callbackRequest_(false), |       do_key_frame_callbackRequest_(false), | ||||||
| @@ -156,7 +157,6 @@ ViEChannel::ViEChannel(int32_t channel_id, | |||||||
|   rtp_rtcp_.reset(RtpRtcp::CreateRtpRtcp(configuration)); |   rtp_rtcp_.reset(RtpRtcp::CreateRtpRtcp(configuration)); | ||||||
|   vie_receiver_.SetRtpRtcpModule(rtp_rtcp_.get()); |   vie_receiver_.SetRtpRtcpModule(rtp_rtcp_.get()); | ||||||
|   vcm_->SetNackSettings(kMaxNackListSize, max_nack_reordering_threshold_, 0); |   vcm_->SetNackSettings(kMaxNackListSize, max_nack_reordering_threshold_, 0); | ||||||
|   vcm_->RegisterReceiveFrameCountObserver(&receive_frame_count_observer_); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| int32_t ViEChannel::Init() { | int32_t ViEChannel::Init() { | ||||||
| @@ -576,7 +576,9 @@ int32_t ViEChannel::DeRegisterExternalDecoder(const uint8_t pl_type) { | |||||||
|  |  | ||||||
| int32_t ViEChannel::ReceiveCodecStatistics(uint32_t* num_key_frames, | int32_t ViEChannel::ReceiveCodecStatistics(uint32_t* num_key_frames, | ||||||
|                                            uint32_t* num_delta_frames) { |                                            uint32_t* num_delta_frames) { | ||||||
|   receive_frame_count_observer_.GetFrameCount(num_key_frames, num_delta_frames); |   CriticalSectionScoped cs(callback_cs_.get()); | ||||||
|  |   *num_key_frames = receive_frame_counts_.key_frames; | ||||||
|  |   *num_delta_frames = receive_frame_counts_.delta_frames; | ||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1568,13 +1570,23 @@ void ViEChannel::IncomingCodecChanged(const VideoCodec& codec) { | |||||||
|   receive_codec_ = codec; |   receive_codec_ = codec; | ||||||
| } | } | ||||||
|  |  | ||||||
| int32_t ViEChannel::OnReceiveStatisticsUpdate(const uint32_t bit_rate, | void ViEChannel::OnReceiveRatesUpdated(uint32_t bit_rate, uint32_t frame_rate) { | ||||||
|                                               const uint32_t frame_rate) { |  | ||||||
|   CriticalSectionScoped cs(callback_cs_.get()); |   CriticalSectionScoped cs(callback_cs_.get()); | ||||||
|   if (codec_observer_) { |   if (codec_observer_) | ||||||
|     codec_observer_->IncomingRate(channel_id_, frame_rate, bit_rate); |     codec_observer_->IncomingRate(channel_id_, frame_rate, bit_rate); | ||||||
|   } | } | ||||||
|   return 0; |  | ||||||
|  | void ViEChannel::OnDiscardedPacketsUpdated(int discarded_packets) { | ||||||
|  |   CriticalSectionScoped cs(callback_cs_.get()); | ||||||
|  |   if (vcm_receive_stats_callback_ != NULL) | ||||||
|  |     vcm_receive_stats_callback_->OnDiscardedPacketsUpdated(discarded_packets); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void ViEChannel::OnFrameCountsUpdated(const FrameCounts& frame_counts) { | ||||||
|  |   CriticalSectionScoped cs(callback_cs_.get()); | ||||||
|  |   receive_frame_counts_ = frame_counts; | ||||||
|  |   if (vcm_receive_stats_callback_ != NULL) | ||||||
|  |     vcm_receive_stats_callback_->OnFrameCountsUpdated(frame_counts); | ||||||
| } | } | ||||||
|  |  | ||||||
| void ViEChannel::OnDecoderTiming(int decode_ms, | void ViEChannel::OnDecoderTiming(int decode_ms, | ||||||
| @@ -1820,7 +1832,8 @@ void ViEChannel::RegisterSendFrameCountObserver( | |||||||
|  |  | ||||||
| void ViEChannel::RegisterReceiveStatisticsProxy( | void ViEChannel::RegisterReceiveStatisticsProxy( | ||||||
|     ReceiveStatisticsProxy* receive_statistics_proxy) { |     ReceiveStatisticsProxy* receive_statistics_proxy) { | ||||||
|   receive_frame_count_observer_.Set(receive_statistics_proxy); |   CriticalSectionScoped cs(callback_cs_.get()); | ||||||
|  |   vcm_receive_stats_callback_ = receive_statistics_proxy; | ||||||
| } | } | ||||||
|  |  | ||||||
| void ViEChannel::ReceivedBWEPacket(int64_t arrival_time_ms, | void ViEChannel::ReceivedBWEPacket(int64_t arrival_time_ms, | ||||||
|   | |||||||
| @@ -314,8 +314,10 @@ class ViEChannel | |||||||
|   virtual void IncomingCodecChanged(const VideoCodec& codec); |   virtual void IncomingCodecChanged(const VideoCodec& codec); | ||||||
|  |  | ||||||
|   // Implements VCMReceiveStatisticsCallback. |   // Implements VCMReceiveStatisticsCallback. | ||||||
|   virtual int32_t OnReceiveStatisticsUpdate(const uint32_t bit_rate, |   virtual void OnReceiveRatesUpdated(uint32_t bit_rate, | ||||||
|                                     const uint32_t frame_rate); |                                      uint32_t frame_rate) OVERRIDE; | ||||||
|  |   virtual void OnDiscardedPacketsUpdated(int discarded_packets) OVERRIDE; | ||||||
|  |   virtual void OnFrameCountsUpdated(const FrameCounts& frame_counts) OVERRIDE; | ||||||
|  |  | ||||||
|   // Implements VCMDecoderTimingCallback. |   // Implements VCMDecoderTimingCallback. | ||||||
|   virtual void OnDecoderTiming(int decode_ms, |   virtual void OnDecoderTiming(int decode_ms, | ||||||
| @@ -431,20 +433,12 @@ class ViEChannel | |||||||
|     virtual void FrameCountUpdated(const FrameCounts& frame_counts, |     virtual void FrameCountUpdated(const FrameCounts& frame_counts, | ||||||
|                                    uint32_t ssrc) { |                                    uint32_t ssrc) { | ||||||
|       CriticalSectionScoped cs(critsect_.get()); |       CriticalSectionScoped cs(critsect_.get()); | ||||||
|       frame_counts_ = frame_counts; |  | ||||||
|       if (callback_) |       if (callback_) | ||||||
|         callback_->FrameCountUpdated(frame_counts, ssrc); |         callback_->FrameCountUpdated(frame_counts, ssrc); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     void GetFrameCount(uint32_t* num_key_frames, uint32_t* num_delta_frames) { |  | ||||||
|       CriticalSectionScoped cs(critsect_.get()); |  | ||||||
|       *num_key_frames = frame_counts_.key_frames; |  | ||||||
|       *num_delta_frames = frame_counts_.delta_frames; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|    private: |    private: | ||||||
|     FrameCounts frame_counts_ GUARDED_BY(critsect_); |   } send_frame_count_observer_; | ||||||
|   } send_frame_count_observer_, receive_frame_count_observer_; |  | ||||||
|  |  | ||||||
|   class RegisterableSendSideDelayObserver : |   class RegisterableSendSideDelayObserver : | ||||||
|       public RegisterableCallback<SendSideDelayObserver> { |       public RegisterableCallback<SendSideDelayObserver> { | ||||||
| @@ -481,6 +475,9 @@ class ViEChannel | |||||||
|   scoped_ptr<ChannelStatsObserver> stats_observer_; |   scoped_ptr<ChannelStatsObserver> stats_observer_; | ||||||
|  |  | ||||||
|   // Not owned. |   // Not owned. | ||||||
|  |   VCMReceiveStatisticsCallback* vcm_receive_stats_callback_ | ||||||
|  |       GUARDED_BY(callback_cs_); | ||||||
|  |   FrameCounts receive_frame_counts_ GUARDED_BY(callback_cs_); | ||||||
|   ProcessThread& module_process_thread_; |   ProcessThread& module_process_thread_; | ||||||
|   ViEDecoderObserver* codec_observer_; |   ViEDecoderObserver* codec_observer_; | ||||||
|   bool do_key_frame_callbackRequest_; |   bool do_key_frame_callbackRequest_; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 pbos@webrtc.org
					pbos@webrtc.org