Hi3559v100 sdk中双系统AMP架构的初步了解

hi3559v100是海思推出的camera soc处理器。采用的是双核处理器。一个是a7,运行的linux3.18内核。一个是a17使用的是Huawei liteos操作系统,Hi3559V100 系统中 Huawei LiteOS 负责系统媒体编解码相关业务。两个操作系统实现amp的构建形式。

首先了解一下sdk中的内容。
分别解压两个sdk包目录如下:


sdk包目录

作为嵌入式软件开发来说,重点关注以下两个目录:

hardware

主要是一些datasheet,demo板的原理图。

sofaware

板端,pc端,手机端所使用到的开发调试 维护的软件包,工具包和文档

一: sdk的软件架构:

sdk软件架构
  • OSDRV 层主要提供底层系统支持包,如 Bootloader、OS、Rootfs 模板,关键driver 及交叉编译工具链,双核通信驱动等。
  • MPP 层和原有监控领域 SDK 保持一致,包含主要的媒体模块驱动相关库,如VI、VPSS、VENC、VO 等,对外提供 MPI 接口。
  • Hisyslink 为双核双系统通信组件,用于双系统间的消息通信,数据传递。为了简化降低客户在双系统方面的开发难度,SDK 包提供了 NDK 媒体适配参考代码,供客户参考,客户在实际产品开发过程中,也可以在 MPI 接口上,根据目标市场产品形态,对基础音视频业务功能和数据流进行重新封装。
  • Middleware 层主要提供了典型的业务组件,如录像、拍照、文件管理、回放、GUI 及网传等。

2. sdk中的双核业务部署:

image.png

1.NDK媒体业务在双系统部署。
NDK 即媒体相关的功能模块基本都在 Huawei LiteOS 上具体实现(即 MAPI Local模式),并通过在 linux 侧提供 MAPI client 接口,对外提供媒体服务。MAPI local和 MAPI client 之间通过双核通信组件 Hisyslink 实现通信。

2.Middleware 和 References 在 Linux 侧部署,便于用户扩展。
3.硬件资源在双系统部署。

媒体相关硬件部署在 Huawei LiteOS 侧;但外设控制器及其相关中断,内存等硬件资源应该根据产品需要,进行双系统部署。

3. IPCM

在soc上部署的amp构架,一个linux,一个是huawei liteos。两个系统间的通信机制:ICMP

Linux+Huawei LiteOS 双系统业务部署中,媒体业务的硬件资源及功能实现都部署在Huawei LiteOS 端,并通过核间通信,把媒体服务延伸到 Linux 端,Linux 提供和Huawei LiteOS 端相同的接口定义。这就需要 Linux 和 Huawei LiteOS 提供核间通信机制,为媒体业务提供消息通信和大块数据通信机制。核间通信组件IPCM 就是专门为Linux+Huawei LiteOS 双系统核间通信设计的底层组件。

IPCM 的底层通信机制基于共享内存+中断方式实现。

IPCM 是基于共享内存区域实现多核通信的,每个核(OS)拥有一块自己的内存区域(基址+长度),同时知道其它每个核(OS)拥有的内存区域(基址+长度)。

发送消息(带消息头)时,需指定目标核 ID(target)和端口(port),将消息填充到目标的内存区域。

接收消息时,从自己的内存区域读取数据,根据消息头读取一个消息。

双核之间通过 GIC 中断通知对方有消息准备好,需要对方读取。

Hi3559V100 在 IPCM 基础上再封装实现 HisysLink 子系统,一般情况下不直接访问IPCM 接口进行双核通信。这里只介绍 IPCM 模块的初始化动作。

Linux 端
挂载 hi_ipcm.ko

Huawei LiteOS 端
调用_ipcm_vdd_init();初始化 IPCM 模块。

由于 IPCM 使用一片内存区域供 Linux 与 Huawei LiteOS 共同访问实现消息通信。当执行 rmmod hi_ipcm 卸载完 Linux 的 IPCM 模块后,也需要在 Huawei LiteOS 调用_ipcm_vdd_cleanup 去初始化 IPCM。如果 Linux 与 Huawei LiteOS 两端初始化与去初始化 IPCM 不一致(比如一端去初始化并再次初始化 IPCM,另一端不执行相应操作),将会导致内部共享内存区域未同步,造成访问异常地址而出现系统挂死。

4.共享文件系统sharefs:

Huawei LiteOS 上运行的某些应用需要进行一些配置文件的读写和临时中间文件的产生和删除。但 Hi3559V100 的 flash、sd、usb 均部署在 Linux 端,导致 Huawei LiteOS 无法使用 yaffs、FAT 之类文件系统进行文件的访问。因此开发 Sharefs 文件系统,在Huawei LiteOS 端虚拟一个文件系统,利用 IPCM 通信和共享内存,实现其读写 Linux上指定目录下的内容。Sharefs 可以帮助 Huawei LiteOS 从 Linux 端读写文件,类似于NFS。Sharefs 指定访问 Linux 的目录可作为 flash,sd,usb,nfs 等的挂载点。这样,可实现 Huawei LiteOS 通过 Sharefs 访问 yaffs、FAT、NFS 等文件系统。将 Huawei LiteOS 需要访问的文件放在 Linux 端 Sharefs 指定目录,Huawei LiteOS 即可访问其需要的文件。假如共享的目录是liteos这个目录,Huawei LiteOS 端访问/liteos 目录,即为 Linux 端实际目录/liteos。在 Huawei LiteOS 端可使用 open/read/write/lseek/close 等系统调用,也可使用 fopen/fread/fwrite/fclose 等标准 I/O 库访问/liteos 目录。具体的使用如下:

4.1 sharefs的使用:

将 Huawei LiteOS 需要访问的文件放在 Linux 端 Sharefs 指定目录,Huawei LiteOS 即可访问其需要的文件。Sharefs 使用步骤如下:

步骤1. Sharefs 在目录 osdrv/ components/sharefs/sharefs 下,在其目录执行./build.sh 编译出Linux 端使用的库(sharefs/out/linux/ liblinux_sharefs.a)和 APP(sharefs/out/linux/sharefs),Huawei LiteOS 端使用的库(sharefs/out/liteos/ libsharefs.a)。(此步骤已通过顶层 SDK 编译执行完成,可不做)

步骤2. Huawei LiteOS/Linux 使用方法

Huawei LiteOS 端使用方法:sharefs/include/sharefs_client.h 为其使用 Sharefs 用到的头文件。首先执行 IPCM 初始化,调用 _ipcm_vdd_init();再调用HI_ShareFs_Client_Init("/liteos");

完成初始化,其传参"/liteos"为 Sharefs 指定访问的文件目录,在 Linux 端需要有一个与其同名的目录。用户可自行指定 Sharefs 访问目录。可使用 HI_ShareFs_Client_Check()接口查看 Sharefs 是否建立连接。返回 true 表示建立连接。方可执行文件访问。可使用 HI_ShareFs_Client_Get_Path()接口获得 Sharefs 指定访问的目录。此目录实际存在于 Linux 端文件系统中。

Linux 端使用方法:首先加载 IPCM 模块,在单板根文件系统下执行/komod/ipcm 或insmod /komod/hi_ipcm.ko;如果采用 APP 执行:sharefs &,如果采用库,则在用户APP 中调用 HI_ShareFs_Server_Init()。

Sharefs 在 Linux 端使用的是用户态程序,其会与其它用户态程序一起竞争 CPU 资源。当 Linux 端 CPU 使用率太高(大80%)时,Sharefs 的 APP 执行效率会受到一定影响,会引起 Huawei LiteOS 端通过 Sharefs 访问 Linux 端文件效率下降,访问时长增加。此时需要提高 Sharefs 进程的优先级优先抢占 CPU 资源,命令:nice --19 sharefs&。采用 Sharefs 库时,需要提高使用其库的 APP 优先级。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,565评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,021评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,003评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,015评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,020评论 5 370
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,856评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,178评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,824评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,264评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,788评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,913评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,535评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,130评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,102评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,334评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,298评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,622评论 2 343

推荐阅读更多精彩内容