Android相机-架构

引言:

主要是针对CameraAPI v2 + HAL3的架构对Android相机系统进行梳理。

相机架构

 App和FrameWork

Camera API v2位于:

packages/apps/Camer2

frameworks/ex/camera2 

应用框架级别,使用Camera2 API与相机的硬件进行交互。通过调用Binder接口访问与相机native层代码

AIDL

与CameraService关联的binder接口位于:

frameworks/av/camera/aidl/android/hardware

AIDL产生的Java代码访问natvie层,获取物理设备相机的访问权限并返回应用框架层,用于创建CameraDevice,最终创建CameraCaptureSession。

Native框架

CameraDevice 和 CameraCaptureSession 类的原生类位于:

frameworks/av/camera

CameraDevice:

CameraCaptureSession:

binder IPC接口

实现跨进程通信。调用相机服务的binder类位于如下路径:

frameworks/av/camera/aidl/android/hardware

ICameraService:相机服务的接口

ICameraDeviceUser:一打开的特定相机设备

ICameraServiceListener:用于应用框架层的 CameraService的回调

ICameraDeviceCallbacks:用于应用框架层的 CameraDevice的回调

相机服务

CameraService的实现类位于:

frameworks/av/services/camera/libcameraservice/CameraService.cpp

实际与HAL交互的代码

HAL

提供CameraService调用的相机硬件运行标准接口的实现

HIDL

相机HAL的HIDL接口定义位于:

hardware/interfaces/camera

需要被实现的相机服务的HAL(hardware abstract layer)层标准接口

实现HAL

HAL层是位于相机驱动和Android Frameworks之间。

HAL定义了必须实现的接口,以便应用可以正确地操作相机硬件

典型的HAL binder 必须实现如下HIDL接口: 

ICameraProvider:用于枚举独立的相机设备以及管理他们的状态。

ICameraDevice:相机设备的接口

ICameraDeviceSession:激活的相机设备会话接口

输入验证

由于HAL可以访问与相机服务不同的资源,因此两者之间的边界被视为安全性边界。

因此,相机HAL必须验证从相机服务传递到HAL层的参数。包括:检查缓冲区长度值是否在允许范围内,并在使用参数以及将参数传递给硬件或内核驱动程序之前对参数进行排错。

猜你喜欢

转载自blog.csdn.net/haigand/article/details/132439967