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 |