| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "media/mojo/services/interface_factory_impl.h" | 5 #include "media/mojo/services/interface_factory_impl.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/threading/thread_task_runner_handle.h" | 8 #include "base/threading/thread_task_runner_handle.h" |
| 9 #include "media/base/media_log.h" | 9 #include "media/base/media_log.h" |
| 10 #include "media/mojo/services/mojo_media_client.h" | 10 #include "media/mojo/services/mojo_media_client.h" |
| 11 #include "mojo/public/cpp/bindings/strong_binding.h" | 11 #include "mojo/public/cpp/bindings/strong_binding.h" |
| 12 #include "services/service_manager/public/interfaces/interface_provider.mojom.h" | 12 #include "services/service_manager/public/interfaces/interface_provider.mojom.h" |
| 13 | 13 |
| 14 #if defined(ENABLE_MOJO_AUDIO_DECODER) | 14 #if defined(ENABLE_MOJO_AUDIO_DECODER) |
| 15 #include "media/mojo/services/mojo_audio_decoder_service.h" | 15 #include "media/mojo/services/mojo_audio_decoder_service.h" |
| 16 #endif // defined(ENABLE_MOJO_AUDIO_DECODER) | 16 #endif // defined(ENABLE_MOJO_AUDIO_DECODER) |
| 17 | 17 |
| 18 #if defined(ENABLE_MOJO_VIDEO_DECODER) | 18 #if defined(ENABLE_MOJO_VIDEO_DECODER) |
| 19 #include "media/mojo/services/mojo_video_decoder_service.h" | 19 #include "media/mojo/services/mojo_video_decoder_service.h" |
| 20 #endif // defined(ENABLE_MOJO_VIDEO_DECODER) | 20 #endif // defined(ENABLE_MOJO_VIDEO_DECODER) |
| 21 | 21 |
| 22 #if defined(ENABLE_MOJO_RENDERER) | 22 #if defined(ENABLE_MOJO_RENDERER) |
| 23 #include "base/bind_helpers.h" |
| 23 #include "media/base/audio_renderer_sink.h" | 24 #include "media/base/audio_renderer_sink.h" |
| 24 #include "media/base/renderer_factory.h" | 25 #include "media/base/renderer_factory.h" |
| 25 #include "media/base/video_renderer_sink.h" | 26 #include "media/base/video_renderer_sink.h" |
| 26 #include "media/mojo/services/mojo_renderer_service.h" | 27 #include "media/mojo/services/mojo_renderer_service.h" |
| 27 #endif // defined(ENABLE_MOJO_RENDERER) | 28 #endif // defined(ENABLE_MOJO_RENDERER) |
| 28 | 29 |
| 29 #if defined(ENABLE_MOJO_CDM) | 30 #if defined(ENABLE_MOJO_CDM) |
| 30 #include "media/base/cdm_factory.h" | 31 #include "media/base/cdm_factory.h" |
| 31 #include "media/mojo/services/mojo_cdm_service.h" | 32 #include "media/mojo/services/mojo_cdm_service.h" |
| 32 #endif // defined(ENABLE_MOJO_CDM) | 33 #endif // defined(ENABLE_MOJO_CDM) |
| (...skipping 28 matching lines...) Expand all Loading... |
| 61 scoped_refptr<base::SingleThreadTaskRunner> task_runner( | 62 scoped_refptr<base::SingleThreadTaskRunner> task_runner( |
| 62 base::ThreadTaskRunnerHandle::Get()); | 63 base::ThreadTaskRunnerHandle::Get()); |
| 63 | 64 |
| 64 std::unique_ptr<AudioDecoder> audio_decoder = | 65 std::unique_ptr<AudioDecoder> audio_decoder = |
| 65 mojo_media_client_->CreateAudioDecoder(task_runner); | 66 mojo_media_client_->CreateAudioDecoder(task_runner); |
| 66 if (!audio_decoder) { | 67 if (!audio_decoder) { |
| 67 LOG(ERROR) << "AudioDecoder creation failed."; | 68 LOG(ERROR) << "AudioDecoder creation failed."; |
| 68 return; | 69 return; |
| 69 } | 70 } |
| 70 | 71 |
| 71 mojo::MakeStrongBinding( | 72 audio_decoder_bindings_.AddBinding( |
| 72 base::MakeUnique<MojoAudioDecoderService>( | 73 base::MakeUnique<MojoAudioDecoderService>( |
| 73 cdm_service_context_.GetWeakPtr(), std::move(audio_decoder)), | 74 cdm_service_context_.GetWeakPtr(), std::move(audio_decoder)), |
| 74 std::move(request)); | 75 std::move(request)); |
| 75 #endif // defined(ENABLE_MOJO_AUDIO_DECODER) | 76 #endif // defined(ENABLE_MOJO_AUDIO_DECODER) |
| 76 } | 77 } |
| 77 | 78 |
| 78 void InterfaceFactoryImpl::CreateVideoDecoder( | 79 void InterfaceFactoryImpl::CreateVideoDecoder( |
| 79 mojom::VideoDecoderRequest request) { | 80 mojom::VideoDecoderRequest request) { |
| 80 #if defined(ENABLE_MOJO_VIDEO_DECODER) | 81 #if defined(ENABLE_MOJO_VIDEO_DECODER) |
| 81 mojo::MakeStrongBinding( | 82 video_decoder_bindings_.AddBinding( |
| 82 base::MakeUnique<MojoVideoDecoderService>(mojo_media_client_), | 83 base::MakeUnique<MojoVideoDecoderService>(mojo_media_client_), |
| 83 std::move(request)); | 84 std::move(request)); |
| 84 #endif // defined(ENABLE_MOJO_VIDEO_DECODER) | 85 #endif // defined(ENABLE_MOJO_VIDEO_DECODER) |
| 85 } | 86 } |
| 86 | 87 |
| 87 void InterfaceFactoryImpl::CreateRenderer( | 88 void InterfaceFactoryImpl::CreateRenderer( |
| 88 const std::string& audio_device_id, | 89 const std::string& audio_device_id, |
| 89 mojo::InterfaceRequest<mojom::Renderer> request) { | 90 mojo::InterfaceRequest<mojom::Renderer> request) { |
| 90 #if defined(ENABLE_MOJO_RENDERER) | 91 #if defined(ENABLE_MOJO_RENDERER) |
| 91 RendererFactory* renderer_factory = GetRendererFactory(); | 92 RendererFactory* renderer_factory = GetRendererFactory(); |
| 92 if (!renderer_factory) | 93 if (!renderer_factory) |
| 93 return; | 94 return; |
| 94 | 95 |
| 95 scoped_refptr<base::SingleThreadTaskRunner> task_runner( | 96 scoped_refptr<base::SingleThreadTaskRunner> task_runner( |
| 96 base::ThreadTaskRunnerHandle::Get()); | 97 base::ThreadTaskRunnerHandle::Get()); |
| 97 auto audio_sink = | 98 auto audio_sink = |
| 98 mojo_media_client_->CreateAudioRendererSink(audio_device_id); | 99 mojo_media_client_->CreateAudioRendererSink(audio_device_id); |
| 99 auto video_sink = mojo_media_client_->CreateVideoRendererSink(task_runner); | 100 auto video_sink = mojo_media_client_->CreateVideoRendererSink(task_runner); |
| 100 auto renderer = renderer_factory->CreateRenderer( | 101 auto renderer = renderer_factory->CreateRenderer( |
| 101 task_runner, task_runner, audio_sink.get(), video_sink.get(), | 102 task_runner, task_runner, audio_sink.get(), video_sink.get(), |
| 102 RequestSurfaceCB()); | 103 RequestSurfaceCB()); |
| 103 if (!renderer) { | 104 if (!renderer) { |
| 104 LOG(ERROR) << "Renderer creation failed."; | 105 LOG(ERROR) << "Renderer creation failed."; |
| 105 return; | 106 return; |
| 106 } | 107 } |
| 107 | 108 |
| 108 MojoRendererService::Create( | 109 std::unique_ptr<MojoRendererService> mojo_renderer_service = |
| 109 cdm_service_context_.GetWeakPtr(), std::move(audio_sink), | 110 base::MakeUnique<MojoRendererService>( |
| 110 std::move(video_sink), std::move(renderer), | 111 cdm_service_context_.GetWeakPtr(), std::move(audio_sink), |
| 111 MojoRendererService::InitiateSurfaceRequestCB(), std::move(request)); | 112 std::move(video_sink), std::move(renderer), |
| 113 MojoRendererService::InitiateSurfaceRequestCB()); |
| 114 |
| 115 MojoRendererService* mojo_renderer_service_ptr = mojo_renderer_service.get(); |
| 116 |
| 117 StrongBindingSet<mojom::Renderer>::BindingId binding_id = |
| 118 renderer_bindings_.AddBinding(std::move(mojo_renderer_service), |
| 119 std::move(request)); |
| 120 |
| 121 // base::Unretained() is safe because the callback will be fired by |
| 122 // |mojo_renderer_service|, which is owned by |renderer_bindings_|. |
| 123 mojo_renderer_service_ptr->set_bad_message_cb(base::Bind( |
| 124 base::IgnoreResult(&StrongBindingSet<mojom::Renderer>::RemoveBinding), |
| 125 base::Unretained(&renderer_bindings_), binding_id)); |
| 112 #endif // defined(ENABLE_MOJO_RENDERER) | 126 #endif // defined(ENABLE_MOJO_RENDERER) |
| 113 } | 127 } |
| 114 | 128 |
| 115 void InterfaceFactoryImpl::CreateCdm( | 129 void InterfaceFactoryImpl::CreateCdm( |
| 116 mojo::InterfaceRequest<mojom::ContentDecryptionModule> request) { | 130 mojo::InterfaceRequest<mojom::ContentDecryptionModule> request) { |
| 117 #if defined(ENABLE_MOJO_CDM) | 131 #if defined(ENABLE_MOJO_CDM) |
| 118 CdmFactory* cdm_factory = GetCdmFactory(); | 132 CdmFactory* cdm_factory = GetCdmFactory(); |
| 119 if (!cdm_factory) | 133 if (!cdm_factory) |
| 120 return; | 134 return; |
| 121 | 135 |
| 122 mojo::MakeStrongBinding(base::MakeUnique<MojoCdmService>( | 136 cdm_bindings_.AddBinding(base::MakeUnique<MojoCdmService>( |
| 123 cdm_service_context_.GetWeakPtr(), cdm_factory), | 137 cdm_service_context_.GetWeakPtr(), cdm_factory), |
| 124 std::move(request)); | 138 std::move(request)); |
| 125 #endif // defined(ENABLE_MOJO_CDM) | 139 #endif // defined(ENABLE_MOJO_CDM) |
| 126 } | 140 } |
| 127 | 141 |
| 128 #if defined(ENABLE_MOJO_RENDERER) | 142 #if defined(ENABLE_MOJO_RENDERER) |
| 129 RendererFactory* InterfaceFactoryImpl::GetRendererFactory() { | 143 RendererFactory* InterfaceFactoryImpl::GetRendererFactory() { |
| 130 if (!renderer_factory_) { | 144 if (!renderer_factory_) { |
| 131 renderer_factory_ = mojo_media_client_->CreateRendererFactory(media_log_); | 145 renderer_factory_ = mojo_media_client_->CreateRendererFactory(media_log_); |
| 132 LOG_IF(ERROR, !renderer_factory_) << "RendererFactory not available."; | 146 LOG_IF(ERROR, !renderer_factory_) << "RendererFactory not available."; |
| 133 } | 147 } |
| 134 return renderer_factory_.get(); | 148 return renderer_factory_.get(); |
| 135 } | 149 } |
| 136 #endif // defined(ENABLE_MOJO_RENDERER) | 150 #endif // defined(ENABLE_MOJO_RENDERER) |
| 137 | 151 |
| 138 #if defined(ENABLE_MOJO_CDM) | 152 #if defined(ENABLE_MOJO_CDM) |
| 139 CdmFactory* InterfaceFactoryImpl::GetCdmFactory() { | 153 CdmFactory* InterfaceFactoryImpl::GetCdmFactory() { |
| 140 if (!cdm_factory_) { | 154 if (!cdm_factory_) { |
| 141 cdm_factory_ = mojo_media_client_->CreateCdmFactory(interfaces_.get()); | 155 cdm_factory_ = mojo_media_client_->CreateCdmFactory(interfaces_.get()); |
| 142 LOG_IF(ERROR, !cdm_factory_) << "CdmFactory not available."; | 156 LOG_IF(ERROR, !cdm_factory_) << "CdmFactory not available."; |
| 143 } | 157 } |
| 144 return cdm_factory_.get(); | 158 return cdm_factory_.get(); |
| 145 } | 159 } |
| 146 #endif // defined(ENABLE_MOJO_CDM) | 160 #endif // defined(ENABLE_MOJO_CDM) |
| 147 | 161 |
| 148 } // namespace media | 162 } // namespace media |
| OLD | NEW |