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

一)ais概述

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

二)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

调用到了驱动代码




上图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端。

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

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

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

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

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

相关推荐
冬奇Lab9 小时前
MediaPlayer 播放器架构:NuPlayer 的 Source/Decoder/Renderer 三驾马车
android·音视频开发·源码阅读
炸炸鱼.10 小时前
Python 操作 MySQL 数据库
android·数据库·python·adb
用户416596736935512 小时前
nextlib 项目架构与深度技术指南 (Architecture & Technical Master Guide)
android
aq553560012 小时前
Laravel10.x重磅升级,新特性一览
android·java·开发语言
Trouvaille ~13 小时前
【MySQL篇】数据类型:存储数据的基础
android·数据库·mysql·adb·字符集·数据类型·基础入门
2401_8858850414 小时前
开发视频短信接口好开发吗?图文视频短信接口对接教程
android·音视频
千码君201615 小时前
kotlin:Jetpack Compose 给APP添加声音(点击音效/背景音乐)
android·开发语言·kotlin·音效·jetpack compose
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.15 小时前
MySQL半同步复制与GTID实战详解
android·mysql·adb
用户416596736935516 小时前
深度解码:记一次视频时间戳(PTS)异常导致的播放故障排查
android
大白菜和MySQL18 小时前
linux系统环境常用命令
android·linux·adb