| Index: mojo/services/html_viewer/webmediaplayer_factory.cc
|
| diff --git a/mojo/services/html_viewer/webmediaplayer_factory.cc b/mojo/services/html_viewer/webmediaplayer_factory.cc
|
| index 0b73a9856c6109d7b8b87a7e2b0fa5045c2e30a0..423c5b96824dec6d1746260c6c7632134aef6130 100644
|
| --- a/mojo/services/html_viewer/webmediaplayer_factory.cc
|
| +++ b/mojo/services/html_viewer/webmediaplayer_factory.cc
|
| @@ -17,7 +17,9 @@
|
| #include "media/blink/webmediaplayer_impl.h"
|
| #include "media/blink/webmediaplayer_params.h"
|
| #include "media/cdm/default_cdm_factory.h"
|
| +#include "media/mojo/interfaces/content_decryption_module_factory.mojom.h"
|
| #include "media/mojo/interfaces/media_renderer.mojom.h"
|
| +#include "media/mojo/services/mojo_cdm_factory.h"
|
| #include "media/mojo/services/mojo_renderer_factory.h"
|
| #include "media/renderers/default_renderer_factory.h"
|
| #include "media/renderers/gpu_video_accelerator_factories.h"
|
| @@ -86,18 +88,26 @@ blink::WebMediaPlayer* WebMediaPlayerFactory::CreateMediaPlayer(
|
| #else
|
| scoped_refptr<media::MediaLog> media_log(new media::MediaLog());
|
| scoped_ptr<media::RendererFactory> media_renderer_factory;
|
| + scoped_ptr<media::CdmFactory> cdm_factory;
|
|
|
| if (enable_mojo_media_renderer_) {
|
| - ServiceProviderPtr media_renderer_service_provider;
|
| - shell->ConnectToApplication(
|
| - "mojo:media", GetProxy(&media_renderer_service_provider), nullptr);
|
| + ServiceProviderPtr media_service_provider;
|
| + shell->ConnectToApplication("mojo:media", GetProxy(&media_service_provider),
|
| + nullptr);
|
| +
|
| + // TODO(xhwang): Create only one |cdm_factory_ptr| per process.
|
| + mojo::ContentDecryptionModuleFactoryPtr cdm_factory_ptr;
|
| + mojo::ConnectToService(media_service_provider.get(), &cdm_factory_ptr);
|
| + cdm_factory.reset(new media::MojoCdmFactory(cdm_factory_ptr.Pass()));
|
| +
|
| media_renderer_factory.reset(new media::MojoRendererFactory(make_scoped_ptr(
|
| - new RendererServiceProvider(media_renderer_service_provider.Pass()))));
|
| + new RendererServiceProvider(media_service_provider.Pass()))));
|
| } else {
|
| media_renderer_factory.reset(
|
| new media::DefaultRendererFactory(media_log,
|
| nullptr, // No GPU factory.
|
| GetAudioHardwareConfig()));
|
| + cdm_factory.reset(new media::DefaultCdmFactory());
|
| }
|
|
|
| media::WebMediaPlayerParams params(
|
| @@ -107,8 +117,6 @@ blink::WebMediaPlayer* WebMediaPlayerFactory::CreateMediaPlayer(
|
| initial_cdm);
|
| base::WeakPtr<media::WebMediaPlayerDelegate> delegate;
|
|
|
| - scoped_ptr<media::CdmFactory> cdm_factory(new media::DefaultCdmFactory());
|
| -
|
| return new media::WebMediaPlayerImpl(frame, client, delegate,
|
| media_renderer_factory.Pass(),
|
| cdm_factory.Pass(), params);
|
|
|