blob: c80842023f81e212cbdb774255a4c166934adbcb [file] [log] [blame]
// Copyright 2017 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 "media/capture/video/chromeos/video_capture_device_factory_chromeos.h"
#include <utility>
#include "base/memory/ptr_util.h"
#include "media/base/bind_to_current_loop.h"
#include "media/capture/video/chromeos/camera_app_device_bridge_impl.h"
#include "media/capture/video/chromeos/camera_hal_dispatcher_impl.h"
#include "mojo/public/cpp/bindings/strong_binding.h"
namespace media {
namespace {
gpu::GpuMemoryBufferManager* g_gpu_buffer_manager = nullptr;
} // namespace
VideoCaptureDeviceFactoryChromeOS::VideoCaptureDeviceFactoryChromeOS(
scoped_refptr<base::SingleThreadTaskRunner> task_runner_for_screen_observer,
CameraAppDeviceBridgeImpl* camera_app_device_bridge)
: task_runner_for_screen_observer_(task_runner_for_screen_observer),
camera_hal_ipc_thread_("CameraHalIpcThread"),
camera_app_device_bridge_(camera_app_device_bridge),
initialized_(Init()),
weak_ptr_factory_(this) {}
VideoCaptureDeviceFactoryChromeOS::~VideoCaptureDeviceFactoryChromeOS() {
if (camera_app_device_bridge_) {
camera_app_device_bridge_->UnsetCameraInfoGetter();
}
camera_hal_delegate_->Reset();
camera_hal_ipc_thread_.Stop();
}
std::unique_ptr<VideoCaptureDevice>
VideoCaptureDeviceFactoryChromeOS::CreateDevice(
const VideoCaptureDeviceDescriptor& device_descriptor) {
DCHECK(thread_checker_.CalledOnValidThread());
if (!initialized_) {
return std::unique_ptr<VideoCaptureDevice>();
}
return camera_hal_delegate_->CreateDevice(task_runner_for_screen_observer_,
device_descriptor,
camera_app_device_bridge_);
}
void VideoCaptureDeviceFactoryChromeOS::GetSupportedFormats(
const VideoCaptureDeviceDescriptor& device_descriptor,
VideoCaptureFormats* supported_formats) {
DCHECK(thread_checker_.CalledOnValidThread());
camera_hal_delegate_->GetSupportedFormats(device_descriptor,
supported_formats);
}
void VideoCaptureDeviceFactoryChromeOS::GetDeviceDescriptors(
VideoCaptureDeviceDescriptors* device_descriptors) {
DCHECK(thread_checker_.CalledOnValidThread());
if (!initialized_) {
return;
}
camera_hal_delegate_->GetDeviceDescriptors(device_descriptors);
}
// static
gpu::GpuMemoryBufferManager*
VideoCaptureDeviceFactoryChromeOS::GetBufferManager() {
return g_gpu_buffer_manager;
}
// static
void VideoCaptureDeviceFactoryChromeOS::SetGpuBufferManager(
gpu::GpuMemoryBufferManager* buffer_manager) {
g_gpu_buffer_manager = buffer_manager;
}
bool VideoCaptureDeviceFactoryChromeOS::Init() {
if (!camera_hal_ipc_thread_.Start()) {
LOG(ERROR) << "Module thread failed to start";
return false;
}
if (!CameraHalDispatcherImpl::GetInstance()->IsStarted()) {
LOG(ERROR) << "CameraHalDispatcherImpl is not started";
return false;
}
camera_hal_delegate_ =
new CameraHalDelegate(camera_hal_ipc_thread_.task_runner());
camera_hal_delegate_->RegisterCameraClient();
// Since the |camera_hal_delegate_| is initialized on the constructor of this
// object and is destroyed after |camera_app_device_bridge_| unsetting its
// reference, it is safe to use base::Unretained() here.
if (camera_app_device_bridge_) {
camera_app_device_bridge_->SetCameraInfoGetter(
base::BindRepeating(&CameraHalDelegate::GetCameraInfoFromDeviceId,
base::Unretained(camera_hal_delegate_.get())));
}
return true;
}
bool VideoCaptureDeviceFactoryChromeOS::IsSupportedCameraAppDeviceBridge() {
return true;
}
} // namespace media