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

Side by Side Diff: webrtc/video/video_receive_stream.cc

Issue 1691793002: Move the decoder thread into VideoReceiveStream. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 4 years, 10 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/video_receive_stream.h ('k') | webrtc/video/video_send_stream.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 88 matching lines...) Expand 10 before | Expand all | Expand 10 after
99 for (size_t i = 0; i < extensions.size(); ++i) { 99 for (size_t i = 0; i < extensions.size(); ++i) {
100 ss << extensions[i].ToString(); 100 ss << extensions[i].ToString();
101 if (i != extensions.size() - 1) 101 if (i != extensions.size() - 1)
102 ss << ", "; 102 ss << ", ";
103 } 103 }
104 ss << ']'; 104 ss << ']';
105 ss << '}'; 105 ss << '}';
106 return ss.str(); 106 return ss.str();
107 } 107 }
108 108
109 namespace internal {
110 namespace { 109 namespace {
111
112 VideoCodec CreateDecoderVideoCodec(const VideoReceiveStream::Decoder& decoder) { 110 VideoCodec CreateDecoderVideoCodec(const VideoReceiveStream::Decoder& decoder) {
113 VideoCodec codec; 111 VideoCodec codec;
114 memset(&codec, 0, sizeof(codec)); 112 memset(&codec, 0, sizeof(codec));
115 113
116 codec.plType = decoder.payload_type; 114 codec.plType = decoder.payload_type;
117 strncpy(codec.plName, decoder.payload_name.c_str(), sizeof(codec.plName)); 115 strncpy(codec.plName, decoder.payload_name.c_str(), sizeof(codec.plName));
118 if (decoder.payload_name == "VP8") { 116 if (decoder.payload_name == "VP8") {
119 codec.codecType = kVideoCodecVP8; 117 codec.codecType = kVideoCodecVP8;
120 } else if (decoder.payload_name == "VP9") { 118 } else if (decoder.payload_name == "VP9") {
121 codec.codecType = kVideoCodecVP9; 119 codec.codecType = kVideoCodecVP9;
(...skipping 13 matching lines...) Expand all
135 133
136 codec.width = 320; 134 codec.width = 320;
137 codec.height = 180; 135 codec.height = 180;
138 codec.startBitrate = codec.minBitrate = codec.maxBitrate = 136 codec.startBitrate = codec.minBitrate = codec.maxBitrate =
139 Call::Config::kDefaultStartBitrateBps / 1000; 137 Call::Config::kDefaultStartBitrateBps / 1000;
140 138
141 return codec; 139 return codec;
142 } 140 }
143 } // namespace 141 } // namespace
144 142
143 namespace internal {
145 VideoReceiveStream::VideoReceiveStream( 144 VideoReceiveStream::VideoReceiveStream(
146 int num_cpu_cores, 145 int num_cpu_cores,
147 CongestionController* congestion_controller, 146 CongestionController* congestion_controller,
148 const VideoReceiveStream::Config& config, 147 const VideoReceiveStream::Config& config,
149 webrtc::VoiceEngine* voice_engine, 148 webrtc::VoiceEngine* voice_engine,
150 ProcessThread* process_thread, 149 ProcessThread* process_thread,
151 CallStats* call_stats, 150 CallStats* call_stats,
152 VieRemb* remb) 151 VieRemb* remb)
153 : transport_adapter_(config.rtcp_send_transport), 152 : transport_adapter_(config.rtcp_send_transport),
154 encoded_frame_proxy_(config.pre_decode_callback), 153 encoded_frame_proxy_(config.pre_decode_callback),
155 config_(config), 154 config_(config),
156 process_thread_(process_thread), 155 process_thread_(process_thread),
157 clock_(Clock::GetRealTimeClock()), 156 clock_(Clock::GetRealTimeClock()),
157 decode_thread_(DecodeThreadFunction, this, "DecodingThread"),
158 congestion_controller_(congestion_controller), 158 congestion_controller_(congestion_controller),
159 call_stats_(call_stats), 159 call_stats_(call_stats),
160 remb_(remb), 160 remb_(remb),
161 vcm_(VideoCodingModule::Create(clock_, nullptr, nullptr)), 161 vcm_(VideoCodingModule::Create(clock_, nullptr, nullptr)),
162 incoming_video_stream_( 162 incoming_video_stream_(
163 0, 163 0,
164 config.renderer ? config.renderer->SmoothsRenderedFrames() : false), 164 config.renderer ? config.renderer->SmoothsRenderedFrames() : false),
165 stats_proxy_(config_.rtp.remote_ssrc, clock_), 165 stats_proxy_(config_.rtp.remote_ssrc, clock_),
166 vie_channel_(&transport_adapter_, 166 vie_channel_(&transport_adapter_,
167 process_thread, 167 process_thread,
(...skipping 132 matching lines...) Expand 10 before | Expand all | Expand 10 after
300 vcm_->RegisterPreDecodeImageCallback(this); 300 vcm_->RegisterPreDecodeImageCallback(this);
301 incoming_video_stream_.SetExternalCallback(this); 301 incoming_video_stream_.SetExternalCallback(this);
302 vie_channel_.SetIncomingVideoStream(&incoming_video_stream_); 302 vie_channel_.SetIncomingVideoStream(&incoming_video_stream_);
303 vie_channel_.RegisterPreRenderCallback(this); 303 vie_channel_.RegisterPreRenderCallback(this);
304 304
305 process_thread_->RegisterModule(vcm_.get()); 305 process_thread_->RegisterModule(vcm_.get());
306 } 306 }
307 307
308 VideoReceiveStream::~VideoReceiveStream() { 308 VideoReceiveStream::~VideoReceiveStream() {
309 LOG(LS_INFO) << "~VideoReceiveStream: " << config_.ToString(); 309 LOG(LS_INFO) << "~VideoReceiveStream: " << config_.ToString();
310 incoming_video_stream_.Stop(); 310 Stop();
311
311 process_thread_->DeRegisterModule(vcm_.get()); 312 process_thread_->DeRegisterModule(vcm_.get());
312 vie_channel_.RegisterPreRenderCallback(nullptr); 313 vie_channel_.RegisterPreRenderCallback(nullptr);
313 vcm_->RegisterPreDecodeImageCallback(nullptr); 314 vcm_->RegisterPreDecodeImageCallback(nullptr);
314 315
315 call_stats_->DeregisterStatsObserver(vie_channel_.GetStatsObserver()); 316 call_stats_->DeregisterStatsObserver(vie_channel_.GetStatsObserver());
316 rtp_rtcp_->SetREMBStatus(false); 317 rtp_rtcp_->SetREMBStatus(false);
317 remb_->RemoveReceiveChannel(rtp_rtcp_); 318 remb_->RemoveReceiveChannel(rtp_rtcp_);
318 319
319 congestion_controller_->GetRemoteBitrateEstimator(UseSendSideBwe(config_)) 320 congestion_controller_->GetRemoteBitrateEstimator(UseSendSideBwe(config_))
320 ->RemoveStream(vie_receiver_->GetRemoteSsrc()); 321 ->RemoveStream(vie_receiver_->GetRemoteSsrc());
321 } 322 }
322 323
323 void VideoReceiveStream::Start() { 324 void VideoReceiveStream::Start() {
325 if (decode_thread_.IsRunning())
326 return;
324 transport_adapter_.Enable(); 327 transport_adapter_.Enable();
325 incoming_video_stream_.Start(); 328 incoming_video_stream_.Start();
326 vie_channel_.StartReceive(); 329 // Start the decode thread
330 decode_thread_.Start();
331 decode_thread_.SetPriority(rtc::kHighestPriority);
332 vie_receiver_->StartReceive();
327 } 333 }
328 334
329 void VideoReceiveStream::Stop() { 335 void VideoReceiveStream::Stop() {
330 incoming_video_stream_.Stop(); 336 incoming_video_stream_.Stop();
331 vie_channel_.StopReceive(); 337 vie_receiver_->StopReceive();
338 vcm_->TriggerDecoderShutdown();
339 decode_thread_.Stop();
332 transport_adapter_.Disable(); 340 transport_adapter_.Disable();
333 } 341 }
334 342
335 void VideoReceiveStream::SetSyncChannel(VoiceEngine* voice_engine, 343 void VideoReceiveStream::SetSyncChannel(VoiceEngine* voice_engine,
336 int audio_channel_id) { 344 int audio_channel_id) {
337 if (voice_engine != nullptr && audio_channel_id != -1) { 345 if (voice_engine != nullptr && audio_channel_id != -1) {
338 VoEVideoSync* voe_sync_interface = VoEVideoSync::GetInterface(voice_engine); 346 VoEVideoSync* voe_sync_interface = VoEVideoSync::GetInterface(voice_engine);
339 vie_channel_.SetVoiceChannel(audio_channel_id, voe_sync_interface); 347 vie_channel_.SetVoiceChannel(audio_channel_id, voe_sync_interface);
340 voe_sync_interface->Release(); 348 voe_sync_interface->Release();
341 } else { 349 } else {
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after
396 encoded_image, codec_specific_info, fragmentation); 404 encoded_image, codec_specific_info, fragmentation);
397 } 405 }
398 return 0; 406 return 0;
399 } 407 }
400 408
401 void VideoReceiveStream::SignalNetworkState(NetworkState state) { 409 void VideoReceiveStream::SignalNetworkState(NetworkState state) {
402 rtp_rtcp_->SetRTCPStatus(state == kNetworkUp ? config_.rtp.rtcp_mode 410 rtp_rtcp_->SetRTCPStatus(state == kNetworkUp ? config_.rtp.rtcp_mode
403 : RtcpMode::kOff); 411 : RtcpMode::kOff);
404 } 412 }
405 413
414 bool VideoReceiveStream::DecodeThreadFunction(void* ptr) {
415 static_cast<VideoReceiveStream*>(ptr)->Decode();
416 return true;
417 }
418
419 void VideoReceiveStream::Decode() {
420 static const int kMaxDecodeWaitTimeMs = 50;
421 vcm_->Decode(kMaxDecodeWaitTimeMs);
422 }
423
406 } // namespace internal 424 } // namespace internal
407 } // namespace webrtc 425 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/video/video_receive_stream.h ('k') | webrtc/video/video_send_stream.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698