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

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

Issue 2257413002: Replace interface VideoCapturerInput with VideoSinkInterface. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Fix EXPECT_GT order. Created 4 years, 3 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
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2012 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 26 matching lines...) Expand all
37 class SendStatisticsProxy; 37 class SendStatisticsProxy;
38 38
39 // VieEncoder represent a video encoder that accepts raw video frames as input 39 // VieEncoder represent a video encoder that accepts raw video frames as input
40 // and produces an encoded bit stream. 40 // and produces an encoded bit stream.
41 // Usage: 41 // Usage:
42 // Instantiate. 42 // Instantiate.
43 // Call SetStartRate and SetSink. 43 // Call SetStartRate and SetSink.
44 // Call ConfigureEncoder with the codec settings. 44 // Call ConfigureEncoder with the codec settings.
45 // Provide frames to encode by calling IncomingCapturedFrame. 45 // Provide frames to encode by calling IncomingCapturedFrame.
46 // Call Stop() when done. 46 // Call Stop() when done.
47 class ViEEncoder : public VideoCaptureInput, 47 class ViEEncoder : public rtc::VideoSinkInterface<VideoFrame>,
48 public EncodedImageCallback, 48 public EncodedImageCallback,
49 public VCMSendStatisticsCallback, 49 public VCMSendStatisticsCallback,
50 public CpuOveruseObserver { 50 public CpuOveruseObserver {
51 public: 51 public:
52 ViEEncoder(uint32_t number_of_cores, 52 ViEEncoder(uint32_t number_of_cores,
53 SendStatisticsProxy* stats_proxy, 53 SendStatisticsProxy* stats_proxy,
54 const webrtc::VideoSendStream::Config::EncoderSettings& settings, 54 const webrtc::VideoSendStream::Config::EncoderSettings& settings,
55 rtc::VideoSinkInterface<VideoFrame>* pre_encode_callback, 55 rtc::VideoSinkInterface<VideoFrame>* pre_encode_callback,
56 LoadObserver* overuse_callback, 56 LoadObserver* overuse_callback,
57 EncodedFrameObserver* encoder_timing); 57 EncodedFrameObserver* encoder_timing);
58 ~ViEEncoder(); 58 ~ViEEncoder();
59 // RegisterProcessThread register |module_process_thread| with those objects 59 // RegisterProcessThread register |module_process_thread| with those objects
60 // that use it. Registration has to happen on the thread where 60 // that use it. Registration has to happen on the thread where
61 // |module_process_thread| was created (libjingle's worker thread). 61 // |module_process_thread| was created (libjingle's worker thread).
62 // TODO(perkj): Replace the use of |module_process_thread| with a TaskQueue. 62 // TODO(perkj): Replace the use of |module_process_thread| with a TaskQueue.
63 void RegisterProcessThread(ProcessThread* module_process_thread); 63 void RegisterProcessThread(ProcessThread* module_process_thread);
64 void DeRegisterProcessThread(); 64 void DeRegisterProcessThread();
65 65
66 void SetSource(rtc::VideoSourceInterface<VideoFrame>* source);
66 void SetSink(EncodedImageCallback* sink); 67 void SetSink(EncodedImageCallback* sink);
67 68
68 // TODO(perkj): Can we remove VideoCodec.startBitrate ? 69 // TODO(perkj): Can we remove VideoCodec.startBitrate ?
69 void SetStartBitrate(int start_bitrate_bps); 70 void SetStartBitrate(int start_bitrate_bps);
70 71
71 void ConfigureEncoder(const VideoEncoderConfig& config, 72 void ConfigureEncoder(const VideoEncoderConfig& config,
72 size_t max_data_payload_length); 73 size_t max_data_payload_length);
73 74
74 // Permanently stop encoding. After this method has returned, it is 75 // Permanently stop encoding. After this method has returned, it is
75 // guaranteed that no encoded frames will be delivered to the sink. 76 // guaranteed that no encoded frames will be delivered to the sink.
76 void Stop(); 77 void Stop();
77 78
78 // Implements VideoCaptureInput.
79 // TODO(perkj): Refactor ViEEncoder to inherit rtc::VideoSink instead of
80 // VideoCaptureInput.
81 void IncomingCapturedFrame(const VideoFrame& video_frame) override;
82
83 void SendKeyFrame(); 79 void SendKeyFrame();
84 80
85 // virtual to test EncoderStateFeedback with mocks. 81 // virtual to test EncoderStateFeedback with mocks.
86 virtual void OnReceivedIntraFrameRequest(size_t stream_index); 82 virtual void OnReceivedIntraFrameRequest(size_t stream_index);
87 virtual void OnReceivedSLI(uint8_t picture_id); 83 virtual void OnReceivedSLI(uint8_t picture_id);
88 virtual void OnReceivedRPSI(uint64_t picture_id); 84 virtual void OnReceivedRPSI(uint64_t picture_id);
89 85
90 void OnBitrateUpdated(uint32_t bitrate_bps, 86 void OnBitrateUpdated(uint32_t bitrate_bps,
91 uint8_t fraction_lost, 87 uint8_t fraction_lost,
92 int64_t round_trip_time_ms); 88 int64_t round_trip_time_ms);
93 89
94 private: 90 private:
95 class EncodeTask; 91 class EncodeTask;
92 class VideoSourceProxy;
96 93
97 void ConfigureEncoderInternal(const VideoCodec& video_codec, 94 void ConfigureEncoderInternal(const VideoCodec& video_codec,
98 size_t max_data_payload_length); 95 size_t max_data_payload_length);
99 96
97 // Implements VideoSinkInterface.
98 void OnFrame(const VideoFrame& video_frame) override;
99
100 // Implements VideoSendStatisticsCallback. 100 // Implements VideoSendStatisticsCallback.
101 void SendStatistics(uint32_t bit_rate, 101 void SendStatistics(uint32_t bit_rate,
102 uint32_t frame_rate) override; 102 uint32_t frame_rate) override;
103 103
104 void EncodeVideoFrame(const VideoFrame& frame); 104 void EncodeVideoFrame(const VideoFrame& frame);
105 105
106 // Implements EncodedImageCallback. 106 // Implements EncodedImageCallback.
107 EncodedImageCallback::Result OnEncodedImage( 107 EncodedImageCallback::Result OnEncodedImage(
108 const EncodedImage& encoded_image, 108 const EncodedImage& encoded_image,
109 const CodecSpecificInfo* codec_specific_info, 109 const CodecSpecificInfo* codec_specific_info,
110 const RTPFragmentationHeader* fragmentation) override; 110 const RTPFragmentationHeader* fragmentation) override;
111 111
112 // webrtc::CpuOveruseObserver implementation. 112 // webrtc::CpuOveruseObserver implementation.
113 void OveruseDetected() override; 113 void OveruseDetected() override;
114 void NormalUsage() override; 114 void NormalUsage() override;
115 115
116 bool EncoderPaused() const; 116 bool EncoderPaused() const;
117 void TraceFrameDropStart(); 117 void TraceFrameDropStart();
118 void TraceFrameDropEnd(); 118 void TraceFrameDropEnd();
119 119
120 rtc::Event shutdown_event_; 120 rtc::Event shutdown_event_;
121 121
122 const uint32_t number_of_cores_; 122 const uint32_t number_of_cores_;
123
124 const std::unique_ptr<VideoSourceProxy> source_proxy_;
123 EncodedImageCallback* sink_; 125 EncodedImageCallback* sink_;
124 const VideoSendStream::Config::EncoderSettings settings_; 126 const VideoSendStream::Config::EncoderSettings settings_;
125 127
126 const std::unique_ptr<VideoProcessing> vp_; 128 const std::unique_ptr<VideoProcessing> vp_;
127 vcm::VideoSender video_sender_ ACCESS_ON(&encoder_queue_); 129 vcm::VideoSender video_sender_ ACCESS_ON(&encoder_queue_);
128 OveruseFrameDetector overuse_detector_; 130 OveruseFrameDetector overuse_detector_;
129 LoadObserver* const load_observer_ ACCESS_ON(&module_process_thread_checker_); 131 LoadObserver* const load_observer_ ACCESS_ON(&module_process_thread_checker_);
130 132
131 SendStatisticsProxy* const stats_proxy_; 133 SendStatisticsProxy* const stats_proxy_;
132 rtc::VideoSinkInterface<VideoFrame>* const pre_encode_callback_; 134 rtc::VideoSinkInterface<VideoFrame>* const pre_encode_callback_;
133 ProcessThread* module_process_thread_; 135 ProcessThread* module_process_thread_;
134 rtc::ThreadChecker module_process_thread_checker_; 136 rtc::ThreadChecker module_process_thread_checker_;
137 rtc::ThreadChecker main_thread_checker_;
135 138
136 VideoCodec encoder_config_ ACCESS_ON(&encoder_queue_); 139 VideoCodec encoder_config_ ACCESS_ON(&encoder_queue_);
137 140
138 int encoder_start_bitrate_bps_ ACCESS_ON(&encoder_queue_); 141 int encoder_start_bitrate_bps_ ACCESS_ON(&encoder_queue_);
139 uint32_t last_observed_bitrate_bps_ ACCESS_ON(&encoder_queue_); 142 uint32_t last_observed_bitrate_bps_ ACCESS_ON(&encoder_queue_);
140 bool encoder_paused_and_dropped_frame_ ACCESS_ON(&encoder_queue_); 143 bool encoder_paused_and_dropped_frame_ ACCESS_ON(&encoder_queue_);
141 bool has_received_sli_ ACCESS_ON(&encoder_queue_); 144 bool has_received_sli_ ACCESS_ON(&encoder_queue_);
142 uint8_t picture_id_sli_ ACCESS_ON(&encoder_queue_); 145 uint8_t picture_id_sli_ ACCESS_ON(&encoder_queue_);
143 bool has_received_rpsi_ ACCESS_ON(&encoder_queue_); 146 bool has_received_rpsi_ ACCESS_ON(&encoder_queue_);
144 uint64_t picture_id_rpsi_ ACCESS_ON(&encoder_queue_); 147 uint64_t picture_id_rpsi_ ACCESS_ON(&encoder_queue_);
145 Clock* const clock_; 148 Clock* const clock_;
146 149
147 rtc::RaceChecker incoming_frame_race_checker_; 150 rtc::RaceChecker incoming_frame_race_checker_;
148 Atomic32 posted_frames_waiting_for_encode_; 151 Atomic32 posted_frames_waiting_for_encode_;
149 // Used to make sure incoming time stamp is increasing for every frame. 152 // Used to make sure incoming time stamp is increasing for every frame.
150 int64_t last_captured_timestamp_ GUARDED_BY(incoming_frame_race_checker_); 153 int64_t last_captured_timestamp_ GUARDED_BY(incoming_frame_race_checker_);
151 // Delta used for translating between NTP and internal timestamps. 154 // Delta used for translating between NTP and internal timestamps.
152 const int64_t delta_ntp_internal_ms_; 155 const int64_t delta_ntp_internal_ms_;
153 156
154 // All public methods are proxied to |encoder_queue_|. It must must be 157 // All public methods are proxied to |encoder_queue_|. It must must be
155 // destroyed first to make sure no tasks are run that use other members. 158 // destroyed first to make sure no tasks are run that use other members.
156 rtc::TaskQueue encoder_queue_; 159 rtc::TaskQueue encoder_queue_;
160
161 RTC_DISALLOW_COPY_AND_ASSIGN(ViEEncoder);
157 }; 162 };
158 163
159 } // namespace webrtc 164 } // namespace webrtc
160 165
161 #endif // WEBRTC_VIDEO_VIE_ENCODER_H_ 166 #endif // WEBRTC_VIDEO_VIE_ENCODER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698