blob: e7c224e08514ae5a555d4115ae03cc965be46f2d [file] [log] [blame]
// Copyright 2015 The Chromium Authors
// 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/no_destructor.h"
#include "base/task/single_thread_task_runner.h"
#include "base/task/thread_pool.h"
#include "build/build_config.h"
#include "gpu/command_buffer/service/shared_context_state.h"
#include "gpu/ipc/service/gpu_channel_manager.h"
#include "gpu/ipc/service/gpu_memory_buffer_factory.h"
#include "media/base/media_switches.h"
#include "media/gpu/ipc/service/media_gpu_channel_manager.h"
#include "media/media_buildflags.h"
#if BUILDFLAG(ENABLE_MOJO_MEDIA_IN_GPU_PROCESS)
#include "base/functional/bind.h"
#include "media/base/media_switches.h"
#include "media/mojo/services/gpu_mojo_media_client.h" // nogncheck
#include "media/mojo/services/media_service_factory.h" // nogncheck
#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,
const gpu::GPUInfo& gpu_info,
base::WeakPtr<media::MediaGpuChannelManager> media_gpu_channel_manager,
gpu::GpuMemoryBufferFactory* gpu_memory_buffer_factory,
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;
gpu_info_ = gpu_info;
task_runner_ = base::SingleThreadTaskRunner::GetCurrentDefault();
media_gpu_channel_manager_ = std::move(media_gpu_channel_manager);
gpu_memory_buffer_factory_ = gpu_memory_buffer_factory;
android_overlay_factory_cb_ = std::move(android_overlay_factory_cb);
#endif
}
GpuServiceFactory::~GpuServiceFactory() {}
void GpuServiceFactory::RunMediaService(
mojo::PendingReceiver<media::mojom::MediaService> receiver) {
#if BUILDFLAG(ENABLE_MOJO_MEDIA_IN_GPU_PROCESS)
// 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::SequencedTaskRunner> task_runner = task_runner_;
if (media::IsDedicatedMediaServiceThreadEnabled(
gpu_info_.gl_implementation_parts.angle)) {
if (base::FeatureList::IsEnabled(
media::kUseSequencedTaskRunnerForMediaService)) {
task_runner = base::ThreadPool::CreateSequencedTaskRunner(
{base::TaskPriority::USER_BLOCKING});
} else {
task_runner = base::ThreadPool::CreateSingleThreadTaskRunner(
{base::TaskPriority::USER_BLOCKING});
}
}
media::GpuMojoMediaClientTraits traits(
gpu_preferences_, gpu_workarounds_, gpu_feature_info_, gpu_info_,
/*gpu_task_runner=*/task_runner_, android_overlay_factory_cb_,
media_gpu_channel_manager_);
auto gpu_client = media::GpuMojoMediaClient::Create(traits);
using FactoryCallback =
base::OnceCallback<std::unique_ptr<media::MediaService>()>;
FactoryCallback factory =
base::BindOnce(&media::CreateGpuMediaService, std::move(receiver),
std::move(gpu_client));
task_runner->PostTask(
FROM_HERE,
base::BindOnce(
[](FactoryCallback factory) {
static base::NoDestructor<std::unique_ptr<media::MediaService>>
service{std::move(factory).Run()};
},
std::move(factory)));
return;
#endif // BUILDFLAG(ENABLE_MOJO_MEDIA_IN_GPU_PROCESS)
}
} // namespace content