A核与M核异构通信过程解析
创始人
2024-01-08 04:07:16
0

原标题:A核与M核异构通信过程解析

前言

目前域控项目有的采用S32G这类多核异构的芯片,转载一篇分析下多核异构中A核与M核通信过程的文章。

正文

  • 一、 硬件层通信实现原理
  • 二、驱动层Virtio下RPMsg通信实现
  • 三、应用层双核通信实现方式

现在越来越多的产品具有M core和A core的异构架构,既能达到M核的实时要求,又能满足A核的生态和算力。比如NXP的i.MX8系列、瑞萨的RZ/G2L系列以及TI的AM62x系列等等。虽然这些处理器的品牌及性能有所不同,但多核通信原理基本一致,都是基于寄存器和中断传递消息,基于共享内存传输数据。

通信过程整体架构说明

一、 硬件层通信实现原理

通过物理内存DDR分配,将硬件层分为了两部分:TXVring Buffer(发送虚拟环状缓冲区)和RXVring Buffer(接收虚拟环状缓冲区);其中M核从TXVring区发送数据,从RXVring区读取接收数据,A核反之。

处理器支持消息传递单元(MessagingUnit,简称MU)功能模块,通过MU传递消息进行通信和协调,M核和A核之间通过寄存器中断的方式传递命令,最多支持4组MU双向传递消息,既可通过中断告知对方数据传递的状态,也可发送最多4字节数据,还可在低功耗模式下唤醒对方,是保证双核通信实时性的重要手段。

下面看下完成了1次从CoreA向CoreB 传递消息的具体过程:

寄存器输入输出通信模型

(1)CoreA写入数据;

(2)MU将Tx 空位清0,Rx满位置1;

(3)产生接收中断请求,通知CoreB接收状态寄存器中的接收器满,可以读取数据;

(4)CoreB响应中断,读取数据;

(5)CoreB读完数据后,MU将Rx满位清0,Tx空位置1;

(6)状态寄存器向CoreA生成发送中断请求,告知CoreB读完数据,发送寄存器空。

二、驱动层Virtio下RPMsg通信实现

virtio 是一个通用的 I/O 虚拟化框架, 位于设备之上的抽象层,负责前后端之间的通知机制和控制流程,为异构多核间数据通信提供了层的实现。hypervisor 通过他模拟出一系列的虚拟化设备,例如:virtio-net、virtio-blk等,并使得这些设备在虚拟机内部通过 api 调用的方式变得可用。它包含4个部分:前端驱动、后端驱动、 vring 及通信间统一的接口。与其他的模拟 I/O 方式对比, virtio 减少了虚拟机的退出和数据拷贝,能够极大地提高 I/O 性能。计算机中存在不同的总线标准,而 virtio 采用的是 pci 总线(当然也可以用其他总线来实现)。每一个 virtio 设备就是一个 pci 设备。

  • virtio前端驱动

virtio 前端驱动位于 Linux 内核中,运行在虚拟机 VM,针对不同类型的设备有不同类型的驱动程序,包括virtio-net、virtio-blk、virtio-pci等,这些驱动程序与后端驱动交互的接口都是统一的。

  • virtio层

virtio层实现虚拟队列接口,作为前后端通信的桥梁,不同类型的设备使用的虚拟队列数量不同,例如 virtio-net 使用两个虚拟队列,一个用于接收,一个用于发送;virtio-blk 驱动仅使用一个虚拟队列。虚拟队列实际上被实现为跨越客户机操作系统和 hypervisor 的衔接点,可以通过任意方式实现,前提是客户机操作系统和 virtio 后端程序都遵循一定的标准,以相互匹配的方式实现它。

  • virtio-ring层

virtio-ring 是虚拟队列的具体实现,其中实现了环形缓冲区(ring buffer),用于保存前端驱动和后端处理程序执行的信息,并且它可以一次性保存前端驱动的多次I/O请求,并且交由后端驱动去批量处理,最后实际调用宿主机中设备驱动实现物理上的I/O操作,这样做就可以根据约定实现批量处理而不是客户机中每次I/O请求都需要处理一次,从而提高客户机与 hypervisor 信息交换的效率。

  • virtio后端驱动

virtio 后端驱动位于 qemu ,后端设备承担的主体功能分为两部分:

  1. virtio后端设备的模拟;
  2. 依据virtio协议处理来自虚拟机端发送的请求。

在 QEMU 的实现中, virtio 设备是 QEMU 为虚拟机模拟的 PCI 设备,遵循 PCI-SIG 定义的 PCI 规范,具有配置空间、中断配置等功能;virtio 后端驱动运行在宿主机中,用于实现 virtio 后端操作硬件设备,例如向内核协议栈发送一个数据包完成虚拟机对网络数据的操作。

RPMsg消息框架是Linux系统基于Virtio缓存队列实现的主处理核和协处理核间进行消息通信的框架,当客户端驱动需要发送消息时,RPMsg会把消息封装成Virtio缓存并添加到缓存队列中以完成消息的发送,当消息总线接收到协处理器送到的消息时也会合理地派送给客户驱动程序进行处理。

在驱动层,对A核,Linux采用RPMsg框架+Virtio驱动模型,将RPMsg封装为了tty文件供应用层调用;在M核,将Virtio移植,并使用简化版的RPMsg,因为涉及到互斥锁和信号量,最终使用FreeRTOS完成过程的封装,流程框图如下方所示。

主处理核与协处理核数据传递流程图

(1)Core0向Core1发送数据,通过rpmsg_send函数将数据打包至Virtioavail链表区;

(2)在avail链表寻找共享内存中空闲缓存,将数据置于共享内存中;

(3)通过中断通知Core1数据到来,共享内存由avail链表区变至used区;

(4)Core1收到中断,触发rpmsg的接收回调函数,从used区获取数据所在的共享内存的物理地址,完成数据接收;

(5)通过中断通知Core0数据接收完成,共享内存缓存由used区变为avail区,供下次传输使用。

三、应用层双核通信实现方式

在应用层,对A核可使用open、write和read函数对 /dev下设备文件进行调用;对M核,可使用rpmsg_lite_remote_init、rpmsg_lite_send和rpmsg_queue_recv函数进行调用,不做重点阐述。从整体架构上看,关系如下:

本文来源:汽车电子嵌入式

相关内容

热门资讯

【一周连连看】AI重构教育公司... 来源|多知 Hi,节日快乐~在刚刚过去的这一周,教育科技行业依然保持着勃勃生机。在本篇中你将看到: ...
工业和信息化部:加强通用大模型... 新华社北京5月4日电(记者张辛欣、周圆)记者近日从工业和信息化部获悉,下一步将加强通用大模型和行业大...
上海兆钠新能源申请磷碳复合负极... 金融界 2025 年 5 月 3 日消息,国家知识产权局信息显示,上海兆钠新能源科技有限公司申请一项...
深信服获得发明专利授权:“数据... 证券之星消息,根据天眼查APP数据显示深信服(300454)新获得一项发明专利授权,专利名为“数据采...
多年来首次设计重构:微软13英... IT之家 5 月 4 日消息,除了 12 英寸的 Surface Pro 外,Roland Quan...
原创 原... 给梦想插上翅膀 人们自从诞生以来,就没有停止对未知事物的探索,尤其是对外太空的探索,从来没有停止过。...
美濒临「科研末日」,经费腰斩!... 新智元报道 编辑:犀牛 好困 【新智元导读】 特朗普政府提议的2026财年预算案对美国科研机构发起...
加快服务机器人市场普及 伴随人口老龄化、社会服务需求多样化,服务机器人迎来巨大市场机遇。真正让服务机器人“飞入寻常百姓家”,...
华为技术申请 UWB 系统中的... 金融界 2025 年 5 月 3 日消息,国家知识产权局信息显示,华为技术有限公司申请一项名为“UW...
黄仁勋:AI江湖“法则缔造者”... 你可能没听过黄仁勋的名字,但是今天刷到的每张AI生成图片、自动驾驶汽车的每次变道、甚至好莱坞特效师电...
肯尼亚青年成都“求学记”:用中... 肯尼亚青年成都“求学记”:用中国智慧铺设家乡现代化快车道 中新网成都5月4日电 题:肯尼亚青年成都...
人工智能革命就是广告革命 当然,登上热门播客节目来展现更人性化的一面是不错的做法。 但宣称通过人工智能来推动整个广告市场的增长...
重要进展!深圳先进院“太空”实... 深圳商报·读创客户端首席记者 陈小慧 4月30日13时许,神舟十九号飞船携空间站第八批空间科学实验样...
从手术台到生产线,光谷这家企业... 在光谷的武汉奥绿新生物科技股份有限公司(以下简称“奥绿新”),临床医生与工程师的协作打破了传统科研的...
中国青年五四奖章获得者冷晓琨:... 今年以来,关于人形机器人的讨论一直没有断过:从亮相春晚舞台的宇树机器人,到闪耀两会现场的机器人“记者...
2025年分布式推理网络技术白... 《分布式推理网络(DIN)技术白皮书(2025年)》由中国移动通信有限公司研究院发布,全面剖析了AI...
二外学子 | 张淙博:揽十余项... 深圳商报·读创客户端记者 刘娥 在深圳市南山区二外集团学府中学,有一位光芒耀眼的初三学子——张淙博。...
联合光电获得发明专利授权:“V... 证券之星消息,根据天眼查APP数据显示联合光电(300691)新获得一项发明专利授权,专利名为“VC...
卵巢里发现塑料微粒!意大利科学... 近日,一项最新研究证实了科学界长期担忧的猜测:微塑料污染正在侵蚀人类生育能力。 意大利一科学团队首...
深圳市炫宁电子取得多功能 LE... 金融界 2025 年 5 月 3 日消息,国家知识产权局信息显示,深圳市炫宁电子有限公司取得一项名为...