blob: c4efc4ae9e3d23a9a071ad55ecd60f6004cf8c17 [file] [log] [blame]
// Copyright 2019 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/renderer/media/fuchsia_renderer_factory.h"
#include <fuchsia/media/cpp/fidl.h>
#include <memory>
#include <utility>
#include "base/bind.h"
#include "media/base/decoder_factory.h"
#include "media/fuchsia/audio/fuchsia_audio_renderer.h"
#include "media/renderers/renderer_impl.h"
#include "media/renderers/video_renderer_impl.h"
#include "media/video/gpu_memory_buffer_video_frame_pool.h"
#include "media/video/gpu_video_accelerator_factories.h"
#include "media/fuchsia/mojom/fuchsia_media_resource_provider.mojom.h"
#include "mojo/public/cpp/bindings/pending_remote.h"
#include "mojo/public/cpp/bindings/remote.h"
#include "third_party/blink/public/common/browser_interface_broker_proxy.h"
namespace content {
FuchsiaRendererFactory::FuchsiaRendererFactory(
media::MediaLog* media_log,
media::DecoderFactory* decoder_factory,
GetGpuFactoriesCB get_gpu_factories_cb,
blink::BrowserInterfaceBrokerProxy* interface_broker)
: media_log_(media_log),
decoder_factory_(decoder_factory),
get_gpu_factories_cb_(std::move(get_gpu_factories_cb)),
interface_broker_(interface_broker) {
DCHECK(decoder_factory_);
}
FuchsiaRendererFactory::~FuchsiaRendererFactory() = default;
std::vector<std::unique_ptr<media::VideoDecoder>>
FuchsiaRendererFactory::CreateVideoDecoders(
const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner,
media::RequestOverlayInfoCB request_overlay_info_cb,
const gfx::ColorSpace& target_color_space,
media::GpuVideoAcceleratorFactories* gpu_factories) {
std::vector<std::unique_ptr<media::VideoDecoder>> video_decoders;
decoder_factory_->CreateVideoDecoders(
media_task_runner, gpu_factories, media_log_,
std::move(request_overlay_info_cb), target_color_space, &video_decoders);
return video_decoders;
}
std::unique_ptr<media::Renderer> FuchsiaRendererFactory::CreateRenderer(
const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner,
const scoped_refptr<base::TaskRunner>& worker_task_runner,
media::AudioRendererSink* audio_renderer_sink,
media::VideoRendererSink* video_renderer_sink,
media::RequestOverlayInfoCB request_overlay_info_cb,
const gfx::ColorSpace& target_color_space) {
mojo::PendingRemote<media::mojom::FuchsiaMediaResourceProvider>
media_resource_provider;
interface_broker_->GetInterface(
media_resource_provider.InitWithNewPipeAndPassReceiver());
mojo::Remote<media::mojom::FuchsiaMediaResourceProvider>
remote_media_resource_provider;
remote_media_resource_provider.Bind(std::move(media_resource_provider));
fidl::InterfaceHandle<fuchsia::media::AudioConsumer> audio_consumer_handle;
remote_media_resource_provider->CreateAudioConsumer(
audio_consumer_handle.NewRequest());
auto audio_renderer = std::make_unique<media::FuchsiaAudioRenderer>(
media_log_, std::move(audio_consumer_handle));
media::GpuVideoAcceleratorFactories* gpu_factories = nullptr;
if (get_gpu_factories_cb_)
gpu_factories = get_gpu_factories_cb_.Run();
std::unique_ptr<media::GpuMemoryBufferVideoFramePool> gmb_pool;
if (gpu_factories && gpu_factories->ShouldUseGpuMemoryBuffersForVideoFrames(
/*for_media_stream=*/false)) {
gmb_pool = std::make_unique<media::GpuMemoryBufferVideoFramePool>(
media_task_runner, std::move(worker_task_runner), gpu_factories);
}
std::unique_ptr<media::VideoRenderer> video_renderer(
new media::VideoRendererImpl(
media_task_runner, video_renderer_sink,
// Unretained is safe here, because the RendererFactory is guaranteed
// to outlive the RendererImpl. The RendererImpl is destroyed when
// WMPI destructor calls pipeline_controller_.Stop() ->
// PipelineImpl::Stop() -> RendererWrapper::Stop ->
// RendererWrapper::DestroyRenderer(). And the RendererFactory is
// owned by WMPI and gets called after WMPI destructor finishes.
base::BindRepeating(&FuchsiaRendererFactory::CreateVideoDecoders,
base::Unretained(this), media_task_runner,
std::move(request_overlay_info_cb),
target_color_space, gpu_factories),
/*drop_frames=*/true, media_log_, std::move(gmb_pool)));
return std::make_unique<media::RendererImpl>(
media_task_runner, std::move(audio_renderer), std::move(video_renderer));
}
} // namespace content