hal层之camera显示处理流程分析

hal层camera设备打开流程

int camera_device_open(const hw_module_t* module, const char* name, k\hardware\rockchip\camera\CameraHal\CameraHal_Module.cpp
if (name != NULL) { //获取camera的id
cameraid = atoi(name);

            camera = new android::CameraHal(cameraid);

CameraHal::CameraHal(int cameraId)-> \hardware\rockchip\camera\CameraHal\CameraHal.cpp
mCameraAdapter = new CameraUSBAdapter(cameraId);

int CameraAdapter::initialize() \hardware\rockchip\camera\CameraHal\CameraAdapter.cpp
int CameraAdapter::initialize()
{
int ret = -1;
//create focus thread
LOG_FUNCTION_NAME

if((ret = cameraCreate(mCamId)) < 0)
    return ret;

initDefaultParameters(mCamId);
LOG_FUNCTION_NAME_EXIT
return ret;

}

int CameraAdapter::cameraCreate(int cameraId)

   cameraDevicePathCur = (char*)&gCamInfos[cameraId].device_path[0];
  iCamFd = open(cameraDevicePathCur, O_RDWR);

mCamFd = iCamFd;

hal层camera预览流程梳理

int camera_start_preview(struct camera_device * device) \sdk\hardware\rockchip\camera\CameraHal\CameraHal_Module.cpp
->int CameraHal::startPreview() \sdk\hardware\rockchip\camera\CameraHal\CameraHal.cpp
if ((mCommandThread != NULL)) {
msg.command = CMD_PREVIEW_START;
msg.arg1 = NULL;
setCamStatus(CMD_PREVIEW_START_PREPARE, 1);
commandThreadCommandQ.put(&msg);

-> void CameraHal::commandThread()
case CMD_PREVIEW_START:
err=mCameraAdapter->startPreview(app_previw_w,app_preview_h,drv_w, drv_h, 0, false);调用cameraAdapter来显示
status_t CameraAdapter::startPreview(int preview_w,int preview_h,int w, int h, int fmt,bool is_capture)\hardware\rockchip\camera\CameraHal\CameraAdapter.cpp
mCameraPreviewThread = new CameraPreviewThread(this);
mCameraPreviewThread->run(“CameraPreviewThread”,ANDROID_PRIORITY_DISPLAY);

 void CameraAdapter::previewThread(){ 在这里循环去除camera帧并送到DisplayAdpter显示   \sdk\hardware\rockchip\camera\CameraHal\CameraAdapter.cpp
                        mRefDisplayAdapter->notifyNewFrame(tmpFrame);

void DisplayAdapter::notifyNewFrame(FramInfo_s* frame)\sdk\hardware\rockchip\camera\CameraHal\DisplayAdapter.cpp

void DisplayAdapter::notifyNewFrame(FramInfo_s* frame)
{
mDisplayLock.lock();
//send a frame to display
if((mDisplayRuning == STA_DISPLAY_RUNNING)
&&(mDisplayState != CMD_DISPLAY_PAUSE_PREPARE)
&&(mDisplayState != CMD_DISPLAY_PAUSE_DONE)
&&(mDisplayState != CMD_DISPLAY_STOP_PREPARE)
&&(mDisplayState != CMD_DISPLAY_STOP_DONE))
{
Message_cam msg;
msg.command = CMD_DISPLAY_FRAME;
msg.arg1 = NULL;
msg.arg2 = (void*)frame;
msg.arg3 = (void*)(frame->used_flag);
displayThreadCommandQ.put(&msg);
mDisplayCond.signal(); 发消息给DisplayAdapter开始显示
}else{
//must return frame if failed to send display
if(mFrameProvider)
mFrameProvider->returnFrame(frame->frame_index,frame->used_flag);
}
mDisplayLock.unlock();
}
void DisplayAdapter::displayThread() \hardware\rockchip\camera\CameraHal\DisplayAdapter.cpp 在这里处理显示逻辑
case CMD_DISPLAY_FRAME:

framework层传入window缓冲区过程
void initHalPreviewWindow() frameworks/av/services/camera/libcameraservice/device1/CameraHardwareInterface.h
void initHalPreviewWindow() 生成mHalPreviewWindow.对象
{
mHalPreviewWindow.nw.cancel_buffer = __cancel_buffer;
mHalPreviewWindow.nw.lock_buffer = __lock_buffer;
mHalPreviewWindow.nw.dequeue_buffer = __dequeue_buffer; 获取显示缓冲区
mHalPreviewWindow.nw.enqueue_buffer = __enqueue_buffer;
mHalPreviewWindow.nw.set_buffer_count = __set_buffer_count;
mHalPreviewWindow.nw.set_buffers_geometry = __set_buffers_geometry;
mHalPreviewWindow.nw.set_crop = __set_crop;
mHalPreviewWindow.nw.set_timestamp = __set_timestamp;
mHalPreviewWindow.nw.set_usage = __set_usage;
mHalPreviewWindow.nw.set_swap_interval = __set_swap_interval;

    mHalPreviewWindow.nw.get_min_undequeued_buffer_count =
            __get_min_undequeued_buffer_count;
}

static int __dequeue_buffer(struct preview_stream_ops* w, frameworks/av/services/camera/libcameraservice/device1/CameraHardwareInterface.h
buffer_handle_t** buffer, int *stride)
{
int rc;
ANativeWindow a = anw(w);
ANativeWindowBuffer
anb;
rc = native_window_dequeue_buffer_and_wait(a, &anb);
if (!rc) {
*buffer = &anb->handle;
*stride = anb->stride;
}
return rc;
}

status_t initialize(CameraModule *module)frameworks/av/services/camera/libcameraservice/device1/CameraHardwareInterface.h
{
ALOGI(“Opening camera %s”, mName.string());
camera_info info;
status_t res = module->getCameraInfo(atoi(mName.string()), &info);
if (res != OK) {
return res;
}

    int rc = OK;
    if (module->getModuleApiVersion() >= CAMERA_MODULE_API_VERSION_2_3 &&
        info.device_version > CAMERA_DEVICE_API_VERSION_1_0) {
        // Open higher version camera device as HAL1.0 device.
        rc = module->openLegacy(mName.string(),
                                 CAMERA_DEVICE_API_VERSION_1_0,
                                 (hw_device_t **)&mDevice);
    } else {
        rc = module->open(mName.string(), (hw_device_t **)&mDevice);   打开摄像头模块,获得device指针
    }
    if (rc != OK) {
        ALOGE("Could not open camera %s: %d", mName.string(), rc);
        return rc;
    }
    initHalPreviewWindow();
    return rc;
}

status_t setPreviewWindow(const sp& buf) frameworks/av/services/camera/libcameraservice/device1/CameraHardwareInterface.h
{
ALOGV("%s(%s) buf %p", FUNCTION, mName.string(), buf.get());
if (mDevice->ops->set_preview_window) {
mPreviewWindow = buf;
if (buf != nullptr) {
if (mPreviewScalingMode != NOT_SET) {
setPreviewScalingMode(mPreviewScalingMode);
}
if (mPreviewTransform != NOT_SET) {
setPreviewTransform(mPreviewTransform);
}
}
mHalPreviewWindow.user = this;
ALOGV("%s &mHalPreviewWindow %p mHalPreviewWindow.user %p", FUNCTION,
&mHalPreviewWindow, mHalPreviewWindow.user);
return mDevice->ops->set_preview_window(mDevice, //调用hal层的set_preview_window把mHalPreviewWindow传递过去使用
buf.get() ? &mHalPreviewWindow.nw : 0);
}
return INVALID_OPERATION;
}
int CameraHal::setPreviewWindow(struct preview_stream_ops window) Y:\rk3288_7.1_0907\sdk\hardware\rockchip\camera\CameraHal\CameraHal.cpp
{
LOG_FUNCTION_NAME
Message_cam msg;
Semaphore sem;
Mutex::Autolock lock(mLock);
if ((mCommandThread != NULL)) {
msg.command = CMD_SET_PREVIEW_WINDOW;
sem.Create();
msg.arg1 = (void
)(&sem);
msg.arg2 = (void*)window;
setCamStatus(CMD_SET_PREVIEW_WINDOW_PREPARE, 1);
commandThreadCommandQ.put(&msg);
if(msg.arg1){
sem.Wait();
}
if(mCameraStatus&CMD_SET_PREVIEW_WINDOW_DONE)
LOG1(“set preview window OK.”);
}
LOG_FUNCTION_NAME_EXIT
return 0;
}
hal层利用传入的window显示camera过程
void CameraHal::commandThread()
case CMD_SET_PREVIEW_WINDOW:
mDisplayAdapter->setPreviewWindow((struct preview_stream_ops )msg.arg2);
int DisplayAdapter::setPreviewWindow(struct preview_stream_ops
window) \hardware\rockchip\camera\CameraHal\DisplayAdapter.cpp
{
//mDisplayRuning status
//mANativeWindow null?
//window null ?
LOG_FUNCTION_NAME
if(window == NULL){
LOGW(“set preview window null,stop display?”);
}
if(window == mANativeWindow){
LOGD(“preview native window is the same,so ignore it.”);
return 0;
}
if(mANativeWindow){
pauseDisplay();
}
mANativeWindow = window; 获得window
LOG_FUNCTION_NAME_EXIT
return 0;
}
int DisplayAdapter::cameraDisplayBufferCreate(int width, int height, const char fmt,int numBufs) hardware\rockchip\camera\CameraHal\DisplayAdapter.cpp
err = mANativeWindow->set_buffers_geometry(
err = mANativeWindow->dequeue_buffer(mANativeWindow, (buffer_handle_t
*)&hnd, &stride);
mapper.lock((buffer_handle_t)mDisplayBufInfo[i].priv_hnd, CAMHAL_GRALLOC_USAGE, bounds, y_uv);
mDisplayBufInfo[i].vir_addr = (long)y_uv[0]; 把显示缓冲区地址赋值给vir_addr
void DisplayAdapter::displayThread() 在这个线程里处理显示相关的逻辑

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Android TIF (TV Input Framework) HAL是Android系统中专门用于电视输入设备的HAL,它提供了与电视输入设备交互的接口。本文将从以下几个方面对Android TIF HAL进行分析: 1. TIF HAL的结构 TIF HAL的结构主要包括以下几个部分: - TIF HAL接口:包含了TIF HAL与上应用交互的接口,包括初始化、搜索电视节目、设置电视节目等接口。 - TIF HAL实现:包含了TIF HAL的具体实现,与具体的电视输入设备相关。 - TIF HAL框架:包含了TIF HAL的框架代码,用于管理TIF HAL的实现。 2. TIF HAL的初始化 TIF HAL的初始化主要包括以下几个步骤: - 加载TIF HAL库:系统在启动时会自动加载TIF HAL库。 - 查找TIF HAL接口:系统通过dlsym函数查找TIF HAL接口。 - 初始化TIF HAL实现:系统调用TIF HAL接口中的初始化函数初始化TIF HAL实现。 3. TIF HAL与电视输入设备的交互 TIF HAL与电视输入设备的交互主要包括以下几个步骤: - 搜索电视节目:应用调用TIF HAL接口中的搜索电视节目函数,TIF HAL实现会向电视输入设备发送搜索电视节目的指令,并接收电视输入设备返回的电视节目信息。 - 设置电视节目:应用调用TIF HAL接口中的设置电视节目函数,TIF HAL实现会向电视输入设备发送设置电视节目的指令,并等待电视输入设备返回设置结果。 4. TIF HAL的实现 TIF HAL的具体实现与电视输入设备相关,不同的电视输入设备需要实现不同的TIF HAL。TIF HAL的实现需要遵循Android HAL的规范,包括实现HAL接口、定义HAL结构体等。 总的来说,Android TIF HAL是一个用于电视输入设备的HAL,它提供了与电视输入设备交互的接口,其具体实现与电视输入设备相关。在使用Android TIF HAL时,需要遵循Android HAL的规范,并根据实际的电视输入设备进行相应的实现。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

技术求索者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值