0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

一篇文章玩转T113的ARM+RSIC V+DSP三核异构!

米尔电子 2025-03-20 08:04 次阅读

近年来,随着半导体产业的快速发展和技术的不断迭代,物联网设备种类繁多(如智能家居、工业传感器),对算力、功耗、实时性要求差异大,单一架构无法满足所有需求。因此米尔推出MYD-YT113i开发板(基于全志T113-i)来应对这一市场需求。

f2829666-051e-11f0-9434-92fbcf53809c.png

米尔基于全志T113-i核心板及开发板

part 01

T113-i芯片及OpenAMP简介

T113-i芯片简介

T113-i由两颗ARM A7 、一颗C906(RISC-V)和一颗DSP(HIFI 4)组成。

C906(RISC-V核)特性:

  1. 主频最高1008MHz
  2. 32KB I-cache+32 KB D-cache
  3. 操作系统支持裸跑和FreeRTOS实时操作系统

支持少量数据核间通讯(RPMsg)和大量核间数据(RPBuf)

  • DSP(HIFI 4)特性:
  1. 最高主频600MHz
  2. 32KB L1 I-cache+32 KB L1 D-cache 64KBI-ram+64KB D-ram
  3. 操作系统支持裸跑和FreeRTOS实时操作系统

支持少量数据核间通讯(RPMsg)和大量核间数据(RPBuf)

OpenAMP系统原理

T113-i=2×ARM A7 + 1×C906(RISC-V) + 1×DSP(HIFI 4)组成,其中两个A7核为主核心,C906(RISC-V核)和DSP为双副核心。而其中的RISC-V属于超高能效副核心,标配内存管理单元,可运行RTOS或裸机程序,T113的主核运行Linux进行人机界面的交互和应用流程,而RISC-V则是后台可进行大数据数据采集,或者相关编码器的控制等,降低主核被中断的次数,大大提供了主核的运行效率。每个处理器核心相互隔离,拥有属于自己的内存,既可各自独立运行不同的任务,又可多个核心之间进行核间通信,这些不同架构的核心以及他们上面所运行的软件组合在一起,就成了 AMP 系统(Asymmetric Multiprocessing System 异构多处理系统)即非对称多处理架构。

f2d30254-051e-11f0-9434-92fbcf53809c.png

part 02

AMP系统通信机制详解

AMP通信原理

由于两个核心存在的目的是协同的处理,因此在异构多处理系统中往往会形成Master-Remote结构。主核心启动后启动从核心。当两个核心上的系统都启动完成后,他们之间就通过IPC(Inter Processor Communication)方式进行通信,而 RPMsg就是IPC中的一种。
在AMP系统中,两个核心通过共享内存的方式进行通信。两个核心通过AMP中断来传递讯息。内存的管理由主核负责

f2f0cde8-051e-11f0-9434-92fbcf53809c.png 

使用 RPMsg进行核间通信

RPMsg整体通讯框架

上面介绍了通讯原理,这里讲解如何通讯,AMP使用RPMsg框架进行通讯,该框架用于AMP场景下处理器之间进行相互通信。OpenAMP内部实现了可用于RTOS或裸机系统中的RPMsg框架,与Linux内核的RPMsg框架兼容。

f3121dd6-051e-11f0-9434-92fbcf53809c.png

其通信链路建立流程如下:

  1. RTOS 端调用 rpmsg_create_ept 创建指定 name 的端点。

  1. Linux 端 rpmsg core 层收到端点创建消息,调用 rpmsg_register_device 将其作为一个设备注册到 rpmsg bus。

  1. Linux 端 rpmsg bus 匹配到相应的驱动,触发其 probe 函数。

  1. Linux 端驱动 probe 函数完成一些资源的分配以及文件节点的生成。

  1. Linux 端驱动的 probe 函数调用完后,rpmsg bus 会回复一个 ACK。

RTOS 端收到 ACK 后设置端点的状态,此时使用 is_rpmsg_ept_ready 函数会返回 true。

RPMsg数据传输流程如下:

下面展示一次RPMsg数据传输的通信过程,下面详细说明:

f321bbd8-051e-11f0-9434-92fbcf53809c.png 

  1. arm端把数据拷贝到buffer中,在初始化时已经将buffer和payload memory地址绑定,因此数据拷贝后相当于存放到了payloadmemory中。

在消息传输命令后加上数据在payload memory中的起始地址和长度,组成数据包,调用RPMsg接口发送。

RPBuf:基于共享内存和RPMsg消息通知,实现传输大数据传输的框架。RPMsg:基于VirtIO管理的共享内存,实现数据传输的框架。

VirtIO:原本是一套用在虚拟化环境中传输数据的框架,这里用作共享内存(VRING)的管理。

OpenAMP:OpenAMP框架为RTOS、裸机和Linux用户空间提供了RPMsg、VirtIO、re-moteproc(未列出)的实现,并且与Linux内核兼容。Msgbox:是全志平台提供的一套消息中断机制,已通过linux内核中原生的mailbox框架作适配。

MSGBOX_IRO_REG:Msgbox的中断相关寄存器

buffer:表示申请到的共享内存。用户通过操作buffer对象,可直接访问对应的共享内存。

payload memory:用来存放实际传输数据的共享内存,因此称为payload(有效负载)。

VRING:由Virtl0管理的一个环形共享内存。


part 03

案例与性能测试

A核与RISC-V核通讯流程

A核与RISC-V核通讯流程如下:

f3465948-051e-11f0-9434-92fbcf53809c.png 

1. 首先监听端点

f3584356-051e-11f0-9434-92fbcf53809c.png

2. 创建端点

f3652ff8-051e-11f0-9434-92fbcf53809c.png

3. 节点通讯

linux向riscv发送

f3749132-051e-11f0-9434-92fbcf53809c.png

4. riscv接收数据

f3855f9e-051e-11f0-9434-92fbcf53809c.png 

A核与RISC-V核数据传输性能测试

A核与RISC-V核数据传输性能测试,使用rpmsg_test命令对rpmsg进行性能测试,测试发送方向和接收方向各自的耗时以及速率。

1. 主核测试结果:

f3a439f0-051e-11f0-9434-92fbcf53809c.png

2. 从核测试结果:

f3b37582-051e-11f0-9434-92fbcf53809c.png

3. 通过输出的结果可以得到:

[rpmsg1] send: 496.000000Kb 20.000000ms 24.799999M/s

[rpmsg1] receive : 496.000000Kb 9980.000000ms 0.049699Mb/s

发送496KB数据耗时20ms发送速率为24.79Mb/s

接收496KB数据耗时9980ms发送速率为0.049699Mb/s

  • DSP GPADC采集测试

采集流程如下:

f3c096e0-051e-11f0-9434-92fbcf53809c.png 

1. 开启DSP

f3d9e7c6-051e-11f0-9434-92fbcf53809c.png

2. DSP核打印

f3ddd570-051e-11f0-9434-92fbcf53809c.png

3. 开启DSP后,把GPADC0引脚接入1.8V电源,此时用户可以执行A核应用程序与DSP进行通讯,使DSP进行GPADC采集并返回数据

f40c508a-051e-11f0-9434-92fbcf53809c.png

可以看到GPADC0收的电压数据为1792,转换为电压值为:1792/1000=1.792V。

米尔T113-i核心板配置型号

产品型号

主芯片

内存

存储器

工作温度

MYC-YT113i-4E256D-110-IT113-i256MB DDR34GB eMMC-40℃~+85℃
MYC-YT113i-4E512D-110-IT113-i512MB DDR34GB eMMC-40℃~+85℃
MYC-YT113i-8E512D-110-IT113-i512MB DDR38GB eMMC-40℃~+85℃
MYC-YT113i-8E1D-110-IT113-i1GB DDR38GB eMMC-40℃~+85℃

表MYC-YT113-i核心板选型表

米尔T113-i开发板配置型号

产品型号

对应核心板型号

工作温度

MYD-YT113i-4E256D-110-IMYC-YT113i-4E256D-110-I-40℃~+85℃ 工业级
MYD-YT113i-4E512D-110-IMYC-YT113i-4E512D-110-I-40℃~+85℃工业级
MYD-YT113i-8E512D-110-IMYC-YT113i-8E512D-110-I-40℃~+85℃工业级
MYD-YT113i-8E1D-110-IMYC-YT113i-8E1D-110-I-40℃~+85℃工业级

表MYD-YT113-i开发板选型表

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • dsp
    dsp
    +关注

    关注

    555

    文章

    8088

    浏览量

    352974
  • ARM
    ARM
    +关注

    关注

    134

    文章

    9237

    浏览量

    371944
  • 开发板
    +关注

    关注

    25

    文章

    5260

    浏览量

    99746
  • RSIC-V
    +关注

    关注

    4

    文章

    15

    浏览量

    6616
  • 米尔电子
    +关注

    关注

    0

    文章

    123

    浏览量

    617
收藏 人收藏

    相关推荐

    开源项目!DIY了台无人机,用全志T113芯片

    给电机控制输出,以实现自稳飞行的功能。 主控: 全志T113,双ARM A7 内存: 内置128MB DDR 磁力计: IST8310 气压计: BMP388 IMU: BMI088 操作系统: 全志
    发表于 10-22 13:50

    DIY了台无人机,用全志T113芯片

    T113通过USB直接与WiFi模块连接,接收机则是连接串口通过SBUS和T113直接连接,收到指令信号后由4路PWM直接给电机控制输出,以实现自稳飞行的功能。 主控:全志T113,双
    发表于 11-13 09:43

    全志T113异构处理器的使用基于Tina Linux5.0——RTOS简介

    全志T113-i是款双Cortex-A7国产工业级处理器平台,并内置玄铁C906 RISC-V和HiFi4 DSP双副核心,可流畅运行L
    发表于 11-18 09:33

    全志T113异构处理器的使用基于Tina Linux5.0——RTOS编译开发说明

    /t113_s4_linux_sbc_t113s4_uart0.img,可以使用PhoenixSuit工具烧录到主板上。 3.4、RISC-V启动 进入主Linux控制台后,执行如
    发表于 11-18 09:45

    全志T113异构处理器的使用基于Tina Linux5.0——异构通信的具体实现

    5、TinaLinux异构通信的具体实现: 本章节以SBC-T113S4主板的TinaLinux为例,介绍异构通信的实现。该方法也同
    发表于 11-20 09:45

    国产开发板—米尔全志T113-i如何实现ARM+RISC-V+DSP协同计算?

    01T113-i芯片及OpenAMP简介[/fly] T113-i芯片简介 T113-i由两颗ARM A7 、颗C906(RISC-
    发表于 03-21 16:50

    Arm+RISC-V异构前景如何?

    2021航顺HK32MCU新品发布会上,航顺介绍了自主研发的双异构MCU-HK32U1xx9系列产品。Arm Cortex-M3大负责主运算;RISC-
    发表于 04-14 10:06

    【米尔-全志T113-S3开发板- 极致双A7国产处理器-试用体验】米尔-全志T113-S3开发板初次接触体验感不错

    先来介绍下米尔-全志T113-S3开发板: 全志科技 T113 系列处理器是款基于双A7@1.2GHz + HiFi4
    发表于 08-17 23:59

    68元工业级双A7,全新T113核心板震撼上市!

    万象奥科全新T113核心板震撼上市,仅68元、工业级品质、双A7处理器、外设丰富,诠释极致性价比!
    的头像 发表于 05-05 17:45 991次阅读
    68元工业级双<b class='flag-5'>核</b>A7,全新<b class='flag-5'>T113</b>核心板震撼上市!

    全志T113核心板|T113芯片,双A7米尔核心板零售价低至79元!

    全志T113核心板|T113芯片,双A7米尔核心板零售价低至79元!米尔基于全志T113-S3核心板,它的特色在于不仅限于国产化、性价比高。入门级核心板开发板
    的头像 发表于 05-22 18:09 5672次阅读
    全志<b class='flag-5'>T113</b>核心板|<b class='flag-5'>T113</b>芯片,双<b class='flag-5'>核</b>A7米尔核心板零售价低至79元!

    全志D1和t113对比

    的不同之处。 1. CPU 全志D1和t113的CPU都是基于ARM Cortex-A7架构设计的,但是全志D1的16位DDR接口和单内核ARMv7-A处理器速度较慢。而t113则使用双
    的头像 发表于 08-17 11:28 4329次阅读

    基于T113开发板优化启动速度方法

    T113核心板+及底板天嵌核心板规格书以下介绍T113开发板优化启动速度的方法:Uboot修改1、修改u-boot-2018/cmd/sunxi_burn.c大约快0.7秒2、去掉延时
    的头像 发表于 08-17 14:46 2011次阅读
    基于<b class='flag-5'>T113</b>开发板优化启动速度方法

    T113开发平台修改分区办法

    T113开发平台修改分区办法
    的头像 发表于 09-28 09:56 1002次阅读
    <b class='flag-5'>T113</b>开发平台修改分区办法

    T113开发平台mipi 5.5寸屏调试

    T113平台5.5寸1080x1920mipi屏调试指导
    的头像 发表于 10-19 16:22 1605次阅读
    <b class='flag-5'>T113</b>开发平台mipi 5.5寸屏调试

    7折购!米尔基于全志T113系列开发板

    -i的核心板兼容T113-S的核心板,同个硬件设计,有多种更适合的选择。2种芯片,多种配置,全志T113系列产品自上市以来已得到各行各业的应用。为回馈广大客户的支持,助
    的头像 发表于 06-21 08:01 737次阅读
    7折购!米尔基于全志<b class='flag-5'>T113</b>系列开发板