Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "content/renderer/media/media_stream_dependency_factory.h" | 5 #include "content/renderer/media/media_stream_dependency_factory.h" |
| 6 | 6 |
| 7 #include <vector> | 7 #include <vector> |
| 8 | 8 |
| 9 #include "base/command_line.h" | |
| 9 #include "base/synchronization/waitable_event.h" | 10 #include "base/synchronization/waitable_event.h" |
| 10 #include "base/utf_string_conversions.h" | 11 #include "base/utf_string_conversions.h" |
| 12 #include "content/public/common/content_switches.h" | |
| 11 #include "content/renderer/media/media_stream_source_extra_data.h" | 13 #include "content/renderer/media/media_stream_source_extra_data.h" |
| 12 #include "content/renderer/media/rtc_media_constraints.h" | 14 #include "content/renderer/media/rtc_media_constraints.h" |
| 13 #include "content/renderer/media/rtc_peer_connection_handler.h" | 15 #include "content/renderer/media/rtc_peer_connection_handler.h" |
| 14 #include "content/renderer/media/rtc_video_capturer.h" | 16 #include "content/renderer/media/rtc_video_capturer.h" |
| 17 #include "content/renderer/media/rtc_video_decoder_factory.h" | |
| 15 #include "content/renderer/media/video_capture_impl_manager.h" | 18 #include "content/renderer/media/video_capture_impl_manager.h" |
| 16 #include "content/renderer/media/webaudio_capturer_source.h" | 19 #include "content/renderer/media/webaudio_capturer_source.h" |
| 17 #include "content/renderer/media/webrtc_audio_device_impl.h" | 20 #include "content/renderer/media/webrtc_audio_device_impl.h" |
| 18 #include "content/renderer/media/webrtc_uma_histograms.h" | 21 #include "content/renderer/media/webrtc_uma_histograms.h" |
| 19 #include "content/renderer/p2p/ipc_network_manager.h" | 22 #include "content/renderer/p2p/ipc_network_manager.h" |
| 20 #include "content/renderer/p2p/ipc_socket_factory.h" | 23 #include "content/renderer/p2p/ipc_socket_factory.h" |
| 21 #include "content/renderer/p2p/port_allocator.h" | 24 #include "content/renderer/p2p/port_allocator.h" |
| 22 #include "jingle/glue/thread_wrapper.h" | 25 #include "jingle/glue/thread_wrapper.h" |
| 23 #include "third_party/WebKit/Source/Platform/chromium/public/WebMediaConstraints .h" | 26 #include "third_party/WebKit/Source/Platform/chromium/public/WebMediaConstraints .h" |
| 24 #include "third_party/WebKit/Source/Platform/chromium/public/WebMediaStream.h" | 27 #include "third_party/WebKit/Source/Platform/chromium/public/WebMediaStream.h" |
| (...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 192 WebKit::WebMediaStream* description_; | 195 WebKit::WebMediaStream* description_; |
| 193 MediaStreamDependencyFactory::MediaSourcesCreatedCallback ready_callback_; | 196 MediaStreamDependencyFactory::MediaSourcesCreatedCallback ready_callback_; |
| 194 bool live_; | 197 bool live_; |
| 195 typedef std::vector<scoped_refptr<webrtc::MediaSourceInterface> > | 198 typedef std::vector<scoped_refptr<webrtc::MediaSourceInterface> > |
| 196 ObservedSources; | 199 ObservedSources; |
| 197 ObservedSources sources_; | 200 ObservedSources sources_; |
| 198 }; | 201 }; |
| 199 | 202 |
| 200 MediaStreamDependencyFactory::MediaStreamDependencyFactory( | 203 MediaStreamDependencyFactory::MediaStreamDependencyFactory( |
| 201 VideoCaptureImplManager* vc_manager, | 204 VideoCaptureImplManager* vc_manager, |
| 205 const scoped_refptr<media::GpuVideoDecoder::Factories>& gpu_factories, | |
| 202 P2PSocketDispatcher* p2p_socket_dispatcher) | 206 P2PSocketDispatcher* p2p_socket_dispatcher) |
| 203 : network_manager_(NULL), | 207 : network_manager_(NULL), |
| 204 vc_manager_(vc_manager), | 208 vc_manager_(vc_manager), |
| 209 gpu_factories_(gpu_factories), | |
|
Ami GONE FROM CHROMIUM
2013/04/26 00:42:05
DCHECK this is NULL iff the cmd-line flag is missi
wuchengli
2013/04/26 11:49:14
I changed the place where MediaStreamDependencyFac
| |
| 205 p2p_socket_dispatcher_(p2p_socket_dispatcher), | 210 p2p_socket_dispatcher_(p2p_socket_dispatcher), |
| 206 signaling_thread_(NULL), | 211 signaling_thread_(NULL), |
| 207 worker_thread_(NULL), | 212 worker_thread_(NULL), |
| 208 chrome_worker_thread_("Chrome_libJingle_WorkerThread") { | 213 chrome_worker_thread_("Chrome_libJingle_WorkerThread"), |
| 214 decoder_worker_thread_("DecoderWorkerThread") { | |
| 215 if (!decoder_worker_thread_.Start()) { | |
|
Ami GONE FROM CHROMIUM
2013/04/26 00:42:05
Shouldn't this be conditional on wanting to use GV
wuchengli
2013/04/26 11:49:14
I moved this to EnsurePeerConnectionFactory and st
wuchengli
2013/05/08 15:58:56
Sounds good. I've used gpu_factories_ to decide wh
| |
| 216 LOG(ERROR) << "Could not start decoder worker thread"; | |
| 217 } | |
| 209 } | 218 } |
| 210 | 219 |
| 211 MediaStreamDependencyFactory::~MediaStreamDependencyFactory() { | 220 MediaStreamDependencyFactory::~MediaStreamDependencyFactory() { |
| 212 CleanupPeerConnectionFactory(); | 221 CleanupPeerConnectionFactory(); |
| 213 } | 222 } |
| 214 | 223 |
| 215 WebKit::WebRTCPeerConnectionHandler* | 224 WebKit::WebRTCPeerConnectionHandler* |
| 216 MediaStreamDependencyFactory::CreateRTCPeerConnectionHandler( | 225 MediaStreamDependencyFactory::CreateRTCPeerConnectionHandler( |
| 217 WebKit::WebRTCPeerConnectionHandlerClient* client) { | 226 WebKit::WebRTCPeerConnectionHandlerClient* client) { |
| 218 // Save histogram data so we can see how much PeerConnetion is used. | 227 // Save histogram data so we can see how much PeerConnetion is used. |
| (...skipping 197 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 416 return type == WebKit::WebMediaStreamSource::TypeAudio ? | 425 return type == WebKit::WebMediaStreamSource::TypeAudio ? |
| 417 native_stream->RemoveTrack(native_stream->FindAudioTrack(track_id)) : | 426 native_stream->RemoveTrack(native_stream->FindAudioTrack(track_id)) : |
| 418 native_stream->RemoveTrack(native_stream->FindVideoTrack(track_id)); | 427 native_stream->RemoveTrack(native_stream->FindVideoTrack(track_id)); |
| 419 } | 428 } |
| 420 | 429 |
| 421 bool MediaStreamDependencyFactory::CreatePeerConnectionFactory() { | 430 bool MediaStreamDependencyFactory::CreatePeerConnectionFactory() { |
| 422 DVLOG(1) << "MediaStreamDependencyFactory::CreatePeerConnectionFactory()"; | 431 DVLOG(1) << "MediaStreamDependencyFactory::CreatePeerConnectionFactory()"; |
| 423 if (!pc_factory_.get()) { | 432 if (!pc_factory_.get()) { |
| 424 DCHECK(!audio_device_); | 433 DCHECK(!audio_device_); |
| 425 audio_device_ = new WebRtcAudioDeviceImpl(); | 434 audio_device_ = new WebRtcAudioDeviceImpl(); |
| 435 | |
| 436 RTCVideoDecoderFactory* decoder_factory = NULL; | |
| 437 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); | |
| 438 if (command_line.HasSwitch(switches::kEnableWebRTCHWDecoding)) { | |
| 439 decoder_factory = new RTCVideoDecoderFactory( | |
| 440 decoder_worker_thread_.message_loop_proxy(), gpu_factories_); | |
| 441 } | |
| 442 | |
| 426 scoped_refptr<webrtc::PeerConnectionFactoryInterface> factory( | 443 scoped_refptr<webrtc::PeerConnectionFactoryInterface> factory( |
| 427 webrtc::CreatePeerConnectionFactory(worker_thread_, | 444 webrtc::CreatePeerConnectionFactory(worker_thread_, |
| 428 signaling_thread_, | 445 signaling_thread_, |
| 429 audio_device_)); | 446 audio_device_, |
| 447 decoder_factory)); | |
| 430 if (factory.get()) | 448 if (factory.get()) |
| 431 pc_factory_ = factory; | 449 pc_factory_ = factory; |
| 432 else | 450 else |
| 433 audio_device_ = NULL; | 451 audio_device_ = NULL; |
|
Ami GONE FROM CHROMIUM
2013/04/26 00:42:05
need to delete the decoder_factory in this case?
(
wuchengli
2013/05/08 15:58:56
No need to delete the decoder_factory because Crea
| |
| 434 } | 452 } |
| 435 return pc_factory_.get() != NULL; | 453 return pc_factory_.get() != NULL; |
| 436 } | 454 } |
| 437 | 455 |
| 438 bool MediaStreamDependencyFactory::PeerConnectionFactoryCreated() { | 456 bool MediaStreamDependencyFactory::PeerConnectionFactoryCreated() { |
| 439 return pc_factory_.get() != NULL; | 457 return pc_factory_.get() != NULL; |
| 440 } | 458 } |
| 441 | 459 |
| 442 scoped_refptr<webrtc::PeerConnectionInterface> | 460 scoped_refptr<webrtc::PeerConnectionInterface> |
| 443 MediaStreamDependencyFactory::CreatePeerConnection( | 461 MediaStreamDependencyFactory::CreatePeerConnection( |
| (...skipping 245 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 689 // processed before returning. We wait for the above task to finish before | 707 // processed before returning. We wait for the above task to finish before |
| 690 // letting the the function continue to avoid any potential race issues. | 708 // letting the the function continue to avoid any potential race issues. |
| 691 chrome_worker_thread_.Stop(); | 709 chrome_worker_thread_.Stop(); |
| 692 } else { | 710 } else { |
| 693 NOTREACHED() << "Worker thread not running."; | 711 NOTREACHED() << "Worker thread not running."; |
| 694 } | 712 } |
| 695 } | 713 } |
| 696 } | 714 } |
| 697 | 715 |
| 698 } // namespace content | 716 } // namespace content |
| OLD | NEW |