高通ais over hab高概率导致安卓系统起不来原因分析及解决方案

本文详细描述了在高通8155设备中,AIS框架如何通过HAB机制在QNX主机和安卓客机之间传输控制和数据。重点讨论了控制与数据通道的工作原理以及aisclient进程异常导致系统崩溃的解决策略,包括内存释放顺序的优化和硬解码HAL服务的内存分配特性。
摘要由CSDN通过智能技术生成

一)ais概述

  1. 高通8155的摄像头驱动在hostOS qnx上,guestOS 安卓要使用摄像头,就需要就需要通过hab机制与qnx通信。 
  2. Ais框架如下

0b0ada589528443886ec8869ec80b169.png

      

二)ais的控制通道与数据通道

         a)控制通道即,front end需要将start/stop摄像头的控制命令发送给back end。数据通道即,back end将摄像头数据存放的地方,这个地方同样需要俩端可以访问。控制通道的共享内存是在固定的一块内存上面(hab的physical channel)。但是数据通道却不是。

         b)ais的数据通道的建立。安卓端会从ion申请dma_buf(一个buf存放一帧数据),然后会将dma_buf的物理页帧号告知qnx,然后qnx端就可以将摄像头数据放到这块内存上,再通过控制道通通知安卓端。数据通道建立源码如下:

整个调用过程如下:

one)hab_mem_export——》habmem_hyp_grant_user-》habmem_add_export_compress-》habmem_compress_pfns

two)hab_mem_export——》habmem_export_vchan

    25ee7bbc41f043ac9e10fcc9ae874da0.png

cad1faa0c2bf4e1989adf99311d8fc03.png

498cff2cbbf94941982044626d7e1f2b.png

调用到了内核空间代码

016d293a43cb4d2cbb0b4381336ccd0d.png

-----------------------

66e8c4be720d4d0290695f85d5f81e38.png

86c4e0f9e3784c5d8ce5bc8f172c0f80.png

989bcf9d07864b7fb0a4b0a6806e5466.png

上图exp是一个结构体struct export_desc。定义如下图:

habmem_compress_pfns函数会将dma_buf的物理pfn写到exp上.然后继续调用static int habmem_export_vchan(struct uhab_context *ctx,
        struct virtual_channel *vchan,
        int payload_size,
        uint32_t flags,
        uint32_t export_id)函数走控制通道把exp发送到到qnx端。

38c118e0e1f04e71a1d326b0e40bab9b.png

三)那么ais client进程异常crash为什么会导致安卓系统起不来。

        原因在于ais的数据通道内存是安卓分配, client进程crash后,释放流程很大概率会先释放数据通道,再释放控制通道。如果数据通道释放后,这块内存又被分配给内核其他模块使用,但此时控制通道还没有释放,即qnx不知道数据通道释放了,他还往上面填充摄像头数据,导致安卓kernel panic。然后安卓重启后,qnx又不断再写数据通道,而数据通道的内存在安卓重启后又可能被分配给内核使用。导致安卓系统一直起不来。

  1. 解决方案
    1. 修改内核代码,先释放控制通道,再释放数据通道,比较复杂
    2. 搞一个稳定的ais client hal服务进程。再暴露接口给app使用。
  2. 安卓端硬解码hal服务,也是走hab机制使用qnx提供的硬编解码服务,为什么它不会导致安卓系统crash?

原因是它的数据通道内存是由qnx分配。如下图代码截图:

cfc444ea5b9f4bdaaac026cc854b93a0.png

        3.数据通道建立的俩个重要应用层接口注释如下:

755cc39f3d724e5d855759718e14987b.png

以下是高通Camera AIS框架的基本流程图: ``` +----------------+ +-----------------------+ +------------------+ | Camera Service | | Camera HAL | | Camera Sensor | | | | | | | | | | | | | | | | | | | | +------------+ | | +-----------------+ | | +--------------+ | | | Application| | | | Camera Provider |<--|-------|>| Camera Driver| | | +------------+ | | +-----------------+ | | +--------------+ | | | | | | | | +------------+ | | | | +--------------+ | | | Camera | | | | | | Camera Sensor| | | | HAL Proxy | | | | | +--------------+ | | +------------+ | | | | | | | | | | | | | | | | | | +------------+ | | | | +--------------+ | | | Camera | | | | | | Camera Sensor| | | | Service | | | | | +--------------+ | | +------------+ | | | | | +----------------+ +-----------------------+ +------------------+ ``` 1. Camera Service:应用程序通过Camera Service调用Camera API,拍照、录像、预览等操作。 2. Camera HAL:Camera Service通过Camera HAL与Camera Provider进行通信。Camera HAL提供了一组API给Camera Provider,使其可以直接访问Camera Sensor硬件。 3. Camera Provider:Camera Provider是Camera HAL的一个实现,通过它可以直接访问Camera Driver。Camera Provider负责将Camera HAL的API转换成底层驱动程序可以理解的指令,从而控制Camera Sensor硬件。 4. Camera Driver:Camera Driver是Camera Sensor硬件的底层驱动程序,负责驱动和控制硬件,将采集到的原始数据传输给Camera Provider。 5. Camera Sensor:Camera Sensor是实现图像采集功能的硬件设备,它可以采集图像或视频数据,传输给Camera Driver进行处理。 6. Camera HAL Proxy:Camera HAL Proxy是Camera HAL和Camera Service之间的代理程序,它负责将Camera HAL的API转发给Camera Service,并将Camera Service的请求转发给Camera HAL。 以上是基本的高通Camera AIS框架流程图,其中还包含了其他一些细节处理,比如图像处理、数据传输等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

无v邪

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

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

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

打赏作者

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

抵扣说明:

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

余额充值