blob: 97b6d909d8efa11058b9a4743ca1335d80877758 [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"
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()) {}
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::GetDevicesInfo(
GetDevicesInfoCallback callback) {
DCHECK(thread_checker_.CalledOnValidThread());
if (!initialized_) {
std::move(callback).Run({});
return;
}
camera_hal_delegate_->GetDevicesInfo(std::move(callback));
}
// 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());
if (!camera_hal_delegate_->RegisterCameraClient()) {
LOG(ERROR) << "Failed to register camera client";
return false;
}
// 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())));
camera_app_device_bridge_->SetVirtualDeviceController(
base::BindRepeating(&CameraHalDelegate::EnableVirtualDevice,
base::Unretained(camera_hal_delegate_.get())));
}
return true;
}
bool VideoCaptureDeviceFactoryChromeOS::IsSupportedCameraAppDeviceBridge() {
return true;
}
} // namespace media