Android R camera Hal启动(下)


前言

接上一篇Android R camera Hal启动(上)接着写,把谷歌的代码都分析完成,高通/MTK的代码就不贴了。


代码流程分析

上一篇说到getProviderImpl函数。实例化了CameraProvider对象,先看CameraProvider的构造函数。

template<typename IMPL>
struct CameraProvider : public ICameraProvider {
   
    CameraProvider() : impl() {
   }
    ...
}

调用了impl也就是LegacyCameraProviderImpl_2_4的构造。

LegacyCameraProviderImpl_2_4::LegacyCameraProviderImpl_2_4() :
        camera_module_callbacks_t({
   sCameraDeviceStatusChange,
                                   sTorchModeStatusChange}) {
   
    mInitFailed = initialize();
}

camera_module_callbacks_t是HAL的回调函数,用于通知FW相机状态更新。直接看构造函数调用camera_module_callbacks_t比较奇怪,先看下LegacyCameraProviderImpl_2_4的类的申明和sCameraDeviceStatusChange/sTorchModeStatusChange两个函数的定义就能明白了。

struct LegacyCameraProviderImpl_2_4 : public camera_module_callbacks_t {
   
    ...
static void sCameraDeviceStatusChange(
    const struct camera_module_callbacks* callbacks,
    int camera_id,
    int new_status);

static void sTorchModeStatusChange(
    const struct camera_module_callbacks* callbacks,
    const char* camera_id,
    int new_status);
    ...
}

LegacyCameraProviderImpl_2_4是继承了camera_module_callbacks_t,所以类构造的同时使用sCameraDeviceStatusChange/sTorchModeStatusChange初始化了camera_module_callbacks_t中的camera_device_status_change/torch_mode_status_change函数指针。
camera_module_callbacks_t结构定义如下:

typedef struct camera_module_callbacks {
   
    void (*camera_device_status_change)(const struct camera_module_callbacks*,
            int camera_id,
            int new_status);

    void (*torch_mode_status_change)(const struct camera_module_callbacks*,
            const char* camera_id,
            int new_status);
} camera_module_callbacks_t;

再继续往下看,调用mInitFailed = initialize();看下initialize的实现:

bool LegacyCameraProviderImpl_2_4::initialize() {
   
    camera_module_t *rawModule;
    int err = hw_get_module(CAMERA_HARDWARE_MODULE_ID,
            (const hw_module_t **)&rawModule);
    if (err < 0) {
   
        ALOGE("Could not load camera HAL module: %d (%s)", err, strerror(-err));
        return true;
    }

    mModule = new CameraModule(rawModule);
    err = mModule->init();
    if (err != OK) {
   
        ALOGE("Could not initialize camera HAL module: %d (%s)", err, strerror(-err));
        mModule.clear();
        return true;
    }
    ALOGI(
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Camera HAL启动流程主要分为以下几个步骤。 首先,上层应用通过调用CameraManager的openCamera方法来请求打开相机。这个方法会调用CameraManagerService中的openCamera方法,并传递相应的参数。 接着,CameraManagerService会查找相应的硬件相机模块,使用hw_get_module函数来获取相机模块的实例。这个函数会根据设备配置文件中的相机模块信息来加载相应的动态库,并返回相机模块的实例。 然后,CameraManagerService会通过getCameraInfo方法获取相机的详细信息,包括相机的ID、方向和镜像设置等。 接下来,CameraManagerService会调用相机模块的open方法来打开相机设备。相机模块会根据具体硬件实现来进行相机设备的初始化工作。 在相机设备打开成功后,CameraManagerService会创建一个CameraDevice实例,并将其返回给上层应用。 最后,上层应用可以通过CameraDevice实例来进行相机的操作,例如拍照、录像等。 总之,Camera HAL启动流程包括应用调用CameraManager的openCamera方法、CameraManagerService查找相机模块、相机模块的初始化和相机设备的打开。通过这些步骤,上层应用可以获取到一个可用的相机设备,并进行相关的操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Camera打开流程](https://download.csdn.net/download/sinat_21855227/9483107)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Android 13 Camera HAL启动流程(1)](https://blog.csdn.net/weixin_41678668/article/details/130958729)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Android 13 Camera HAL启动流程(2)](https://blog.csdn.net/weixin_41678668/article/details/130997399)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值