• 736查看
  • 0回复

[芯片硬件] A核与M核异构通信过程解析

[复制链接]

  • TA的每日心情
    无聊
    1-7-2015 18:46
  • 签到天数: 1 天

    [LV.1]初来乍到

    发表于 3-12-2023 19:08:07 | 显示全部楼层 |阅读模式

    汽车零部件采购、销售通信录       填写你的培训需求,我们帮你找      招募汽车专业培训老师


    前言

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

    正文


      一、 硬件层通信实现原理

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

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


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

    A核与M核异构通信过程解析w1.jpg

    通信过程整体架构说明


    一、 硬件层通信实现原理

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

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

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

    A核与M核异构通信过程解析w2.jpg

    寄存器输入输出通信模型

    (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 设备。

    A核与M核异构通信过程解析w3.jpg


      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 ,后端设备承担的主体功能分为两部分:

      virtio后端设备的模拟;依据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完成过程的封装,流程框图如下方所示。

    A核与M核异构通信过程解析w4.jpg

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

    (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函数进行调用,不做重点阐述。从整体架构上看,关系如下:

    A核与M核异构通信过程解析w5.jpg


    

    该用户从未签到

    发表于 17-3-2025 12:43:00 | 显示全部楼层
    回复:

    本文主要针对多核异构中A核与M核通信过程进行解析。概述如下:

    一、硬件层通信实现原理:基于硬件设计和寄存器交互,确保A核与M核间信息准确传输。

    二、驱动层Virtio下RPMsg通信实现:通过驱动层提供的Virtio接口实现RPMsg通信机制,保证实时性与稳定性。

    三、应用层双核通信实现方式:结合共享内存机制与中断传递消息技术,确保A核与M核间高效数据交换。在硬件架构上,虽然不同品牌处理器存在差异,但多核通信原理基本一致。如NXP的i.MX8系列等,均采用了类似的通信机制。

    总结,本文详细解析了A核与M核在多核异构中的通信过程,为相关领域提供了重要参考。
    回复 支持 反对

    使用道具 举报

    

    该用户从未签到

    发表于 17-3-2025 12:43:00 | 显示全部楼层
    A核与M核异构通信过程解析

    一、硬件层通信实现原理:

    在多核异构系统中,A核与M核的通信依赖于硬件层面的支持。通常,芯片内部设计有专门的通信接口和寄存器,以实现两核之间的数据传输和状态通知。

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

    在驱动层,A核与M核通过RPMsg(实时消息协议)进行通信。RPMsg提供了一种高效、可靠的消息传递机制,能够实现两核之间的实时数据传输和中断处理。而Virtio作为一种虚拟化I/O解决方案,为多核通信提供了良好的支持。

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

    在应用层,A核与M核的通信可以通过共享内存、消息队列等方式实现。共享内存是最直接的通信方式,而消息队列则提供了更为灵活的数据传输机制。

    当前域控项目中,采用多核异构芯片已成为趋势。如NXP的i.MX8系列等,都采用了A核与M核的异构架构,以满足实时性要求和生态需求。在多核通信方面,虽然不同品牌的处理器可能存在差异,但通信原理基本一致。
    回复 支持 反对

    使用道具 举报

    快速发帖

    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    QQ|手机版|小黑屋|Archiver|汽车工程师之家 ( 渝ICP备18012993号-1 )

    GMT+8, 19-8-2025 05:18 , Processed in 0.376438 second(s), 36 queries .

    Powered by Discuz! X3.5

    © 2001-2013 Comsenz Inc.