blob: 71ae3dee0170c708136e4f7f2a251eae014207a5 [file] [log] [blame]
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "content/gpu/gpu_service_factory.h"
#include <memory>
#include "base/task/post_task.h"
#include "base/threading/thread_task_runner_handle.h"
#include "build/build_config.h"
#include "services/shape_detection/public/mojom/constants.mojom.h"
#include "services/shape_detection/shape_detection_service.h"
#if BUILDFLAG(ENABLE_MOJO_MEDIA_IN_GPU_PROCESS)
#include "base/bind.h"
#include "media/mojo/interfaces/constants.mojom.h" // nogncheck
#include "media/mojo/services/media_service_factory.h" // nogncheck
#if BUILDFLAG(ENABLE_LIBRARY_CDMS)
#include "content/public/gpu/content_gpu_client.h"
#endif // BUILDFLAG(ENABLE_LIBRARY_CDMS)
#endif // BUILDFLAG(ENABLE_MOJO_MEDIA_IN_GPU_PROCESS)
namespace content {
GpuServiceFactory::GpuServiceFactory(
const gpu::GpuPreferences& gpu_preferences,
const gpu::GpuDriverBugWorkarounds& gpu_workarounds,
const gpu::GpuFeatureInfo& gpu_feature_info,
base::WeakPtr<media::MediaGpuChannelManager> media_gpu_channel_manager,
media::AndroidOverlayMojoFactoryCB android_overlay_factory_cb) {
#if BUILDFLAG(ENABLE_MOJO_MEDIA_IN_GPU_PROCESS)
gpu_preferences_ = gpu_preferences;
gpu_workarounds_ = gpu_workarounds;
gpu_feature_info_ = gpu_feature_info;
task_runner_ = base::ThreadTaskRunnerHandle::Get();
media_gpu_channel_manager_ = std::move(media_gpu_channel_manager);
android_overlay_factory_cb_ = std::move(android_overlay_factory_cb);
#endif
}
GpuServiceFactory::~GpuServiceFactory() {}
void GpuServiceFactory::RunService(
const std::string& service_name,
mojo::PendingReceiver<service_manager::mojom::Service> receiver) {
auto request = service_manager::mojom::ServiceRequest(std::move(receiver));
#if BUILDFLAG(ENABLE_MOJO_MEDIA_IN_GPU_PROCESS)
if (service_name == media::mojom::kMediaServiceName) {
media::CdmProxyFactoryCB cdm_proxy_factory_cb;
#if BUILDFLAG(ENABLE_LIBRARY_CDMS)
cdm_proxy_factory_cb =
base::BindRepeating(&ContentGpuClient::CreateCdmProxy,
base::Unretained(GetContentClient()->gpu()));
#endif // BUILDFLAG(ENABLE_LIBRARY_CDMS)
// This service will host audio/video decoders, and if these decoding
// operations are blocked, user may hear audio glitch or see video freezing,
// hence "user blocking".
scoped_refptr<base::SingleThreadTaskRunner> task_runner;
#if defined(OS_WIN)
// Run everything on the gpu main thread, since that's where the CDM runs.
task_runner = task_runner_;
#else
// TODO(crbug.com/786169): Check whether this needs to be single threaded.
task_runner = base::CreateSingleThreadTaskRunnerWithTraits(
{base::TaskPriority::USER_BLOCKING});
#endif // defined(OS_WIN)
using FactoryCallback =
base::OnceCallback<std::unique_ptr<service_manager::Service>()>;
FactoryCallback factory = base::BindOnce(
&media::CreateGpuMediaService, std::move(request), gpu_preferences_,
gpu_workarounds_, gpu_feature_info_, task_runner_,
media_gpu_channel_manager_, android_overlay_factory_cb_,
std::move(cdm_proxy_factory_cb));
task_runner->PostTask(
FROM_HERE, base::BindOnce(
[](FactoryCallback factory) {
service_manager::Service::RunAsyncUntilTermination(
std::move(factory).Run());
},
std::move(factory)));
return;
}
#endif // BUILDFLAG(ENABLE_MOJO_MEDIA_IN_GPU_PROCESS)
if (service_name == shape_detection::mojom::kServiceName) {
service_manager::Service::RunAsyncUntilTermination(
std::make_unique<shape_detection::ShapeDetectionService>(
std::move(request)));
return;
}
}
} // namespace content