Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(84)

Side by Side Diff: webrtc/video/receive_statistics_proxy.h

Issue 2042603002: Movable support for VideoReceiveStream::Config and avoid copies (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Add TODO Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « webrtc/video/end_to_end_tests.cc ('k') | webrtc/video/receive_statistics_proxy.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 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 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 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
(...skipping 19 matching lines...) Expand all
30 class Clock; 30 class Clock;
31 class ViECodec; 31 class ViECodec;
32 class ViEDecoderObserver; 32 class ViEDecoderObserver;
33 struct CodecSpecificInfo; 33 struct CodecSpecificInfo;
34 34
35 class ReceiveStatisticsProxy : public VCMReceiveStatisticsCallback, 35 class ReceiveStatisticsProxy : public VCMReceiveStatisticsCallback,
36 public RtcpStatisticsCallback, 36 public RtcpStatisticsCallback,
37 public RtcpPacketTypeCounterObserver, 37 public RtcpPacketTypeCounterObserver,
38 public StreamDataCountersCallback { 38 public StreamDataCountersCallback {
39 public: 39 public:
40 ReceiveStatisticsProxy(const VideoReceiveStream::Config& config, 40 ReceiveStatisticsProxy(const VideoReceiveStream::Config* config,
41 Clock* clock); 41 Clock* clock);
42 virtual ~ReceiveStatisticsProxy(); 42 virtual ~ReceiveStatisticsProxy();
43 43
44 VideoReceiveStream::Stats GetStats() const; 44 VideoReceiveStream::Stats GetStats() const;
45 45
46 void OnDecodedFrame(); 46 void OnDecodedFrame();
47 void OnSyncOffsetUpdated(int64_t sync_offset_ms); 47 void OnSyncOffsetUpdated(int64_t sync_offset_ms);
48 void OnRenderedFrame(int width, int height); 48 void OnRenderedFrame(int width, int height);
49 void OnIncomingPayloadType(int payload_type); 49 void OnIncomingPayloadType(int payload_type);
50 void OnDecoderImplementationName(const char* implementation_name); 50 void OnDecoderImplementationName(const char* implementation_name);
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
89 int sum; 89 int sum;
90 int num_samples; 90 int num_samples;
91 }; 91 };
92 struct QpCounters { 92 struct QpCounters {
93 SampleCounter vp8; 93 SampleCounter vp8;
94 }; 94 };
95 95
96 void UpdateHistograms() EXCLUSIVE_LOCKS_REQUIRED(crit_); 96 void UpdateHistograms() EXCLUSIVE_LOCKS_REQUIRED(crit_);
97 97
98 Clock* const clock_; 98 Clock* const clock_;
99 const VideoReceiveStream::Config config_; 99 // Ownership of this object lies with the owner of the ReceiveStatisticsProxy
100 // instance. Lifetime is guaranteed to outlive |this|.
101 // TODO(tommi): In practice the config_ reference is only used for accessing
102 // config_.rtp.fec.ulpfec_payload_type. Instead of holding a pointer back,
103 // we could just store the value of ulpfec_payload_type and change the
104 // ReceiveStatisticsProxy() ctor to accept a const& of Config (since we'll
105 // then no longer store a pointer to the object).
106 const VideoReceiveStream::Config& config_;
100 107
101 rtc::CriticalSection crit_; 108 rtc::CriticalSection crit_;
102 VideoReceiveStream::Stats stats_ GUARDED_BY(crit_); 109 VideoReceiveStream::Stats stats_ GUARDED_BY(crit_);
103 RateStatistics decode_fps_estimator_ GUARDED_BY(crit_); 110 RateStatistics decode_fps_estimator_ GUARDED_BY(crit_);
104 RateStatistics renders_fps_estimator_ GUARDED_BY(crit_); 111 RateStatistics renders_fps_estimator_ GUARDED_BY(crit_);
105 rtc::RateTracker render_fps_tracker_ GUARDED_BY(crit_); 112 rtc::RateTracker render_fps_tracker_ GUARDED_BY(crit_);
106 rtc::RateTracker render_pixel_tracker_ GUARDED_BY(crit_); 113 rtc::RateTracker render_pixel_tracker_ GUARDED_BY(crit_);
107 SampleCounter render_width_counter_ GUARDED_BY(crit_); 114 SampleCounter render_width_counter_ GUARDED_BY(crit_);
108 SampleCounter render_height_counter_ GUARDED_BY(crit_); 115 SampleCounter render_height_counter_ GUARDED_BY(crit_);
109 SampleCounter sync_offset_counter_ GUARDED_BY(crit_); 116 SampleCounter sync_offset_counter_ GUARDED_BY(crit_);
110 SampleCounter decode_time_counter_ GUARDED_BY(crit_); 117 SampleCounter decode_time_counter_ GUARDED_BY(crit_);
111 SampleCounter jitter_buffer_delay_counter_ GUARDED_BY(crit_); 118 SampleCounter jitter_buffer_delay_counter_ GUARDED_BY(crit_);
112 SampleCounter target_delay_counter_ GUARDED_BY(crit_); 119 SampleCounter target_delay_counter_ GUARDED_BY(crit_);
113 SampleCounter current_delay_counter_ GUARDED_BY(crit_); 120 SampleCounter current_delay_counter_ GUARDED_BY(crit_);
114 SampleCounter delay_counter_ GUARDED_BY(crit_); 121 SampleCounter delay_counter_ GUARDED_BY(crit_);
115 ReportBlockStats report_block_stats_ GUARDED_BY(crit_); 122 ReportBlockStats report_block_stats_ GUARDED_BY(crit_);
116 QpCounters qp_counters_; // Only accessed on the decoding thread. 123 QpCounters qp_counters_; // Only accessed on the decoding thread.
117 std::map<uint32_t, StreamDataCounters> rtx_stats_ GUARDED_BY(crit_); 124 std::map<uint32_t, StreamDataCounters> rtx_stats_ GUARDED_BY(crit_);
118 }; 125 };
119 126
120 } // namespace webrtc 127 } // namespace webrtc
121 #endif // WEBRTC_VIDEO_RECEIVE_STATISTICS_PROXY_H_ 128 #endif // WEBRTC_VIDEO_RECEIVE_STATISTICS_PROXY_H_
OLDNEW
« no previous file with comments | « webrtc/video/end_to_end_tests.cc ('k') | webrtc/video/receive_statistics_proxy.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698