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

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

3天内不再提示

案例分享!IMX8 Cortex-A53与Cortex-M4多核通信开发详解

Tronlong创龙科技 2021-09-10 11:18 次阅读

前言:本文主要演示i.MX 8M Mini基于OpenAMP的Cortex-A53和Cortex-M4核心的核间通信,其中Cortex-A53运行Linux系统,Cortex-M4运行FreeRTOS系统。


图 1

案例测试硬件平台:TLIMX8-EVM评估板(NXP i.MX 8M Mini)


图 2 TLIMX8-EVM评估板

案例详细说明、源码请扫描下方二维码或点击下载链接:

http://site.tronlong.com/pfdownload

1 rpmsg_lite_pingpong_rtos案例

1.1 案例功能

(1) Cortex-A53释放Cortex-M4,然后初始化RPMsg,并创建端点。

(2) Cortex-A53启动Linux系统,执行握手服务,创建通信信道,并发送一条信息至Cortex-M4。

(3) Cortex-M4接收到第一条信息时,计数器自加1,然后回发计数器值至Cortex-A53。

(4) Cortex-A53接收Cortex-M4发送的计数器数值,计数器自加1,然后回发计数器数值至Cortex-M4。

(5) 当计数器数值大于100时,通信结束。


1.2 案例测试

案例bin目录下分别提供了TCM版本程序镜像文件rpmsg_lite_pingpong_rtos_linux_remote.bin和DDR版本程序镜像文件rpmsg_lite_pingpong_rtos_linux_remote_ddr.bin。

在U-Boot命令行加载运行Cortex-M4程序镜像文件后,RS232 UART4调试串口打印如下信息。


图 3

运行boot命令,在Cortex-A53启动运行Linux系统。

U-Boot=> boot

图 4

进入评估板文件系统后,执行如下命令加载imx_rpmsg_pingpong模块,启动核间通信。

Target# modprobe imx_rpmsg_pingpong

图 5

加载模块后,Cortex-M4将接收Cortex-A53发送的数据,并将其转发回Cortex-A53,循环50次后结束。RS232 UART4调试串口打印信息如下。

图 6

图 7

1.3 关键代码

Linux驱动程序

驱动的实现在imx_rpmsg_pingpong.c中完成,此文件位于内核"drivers/rpmsg/"路径下。

(1) Linux系统加载驱动后,先发送一条helloMsg,然后发送第一条乒乓信息。

图 8

(2) 在回调函数中,每次接收到Cortex-M4的计数器数据后自加1,并回发至Cortex-M4,直到计数器数值大于100。

图 9

FreeRTOS程序

程序主体位于main函数中,定义位于main_remote.c中。

(1) 在main函数中首先初始化引脚等相关资源,然后创建app_task任务,并启动任务列表。

图 10

(2) 在app_task任务中定义共享内存基地址,需和设备树中指定地址一致,再初始化RPMsg资源,并等待连接上远程终端。

图 11

(3) 接收helloMsg,并循环收发乒乓信息。

图 12

(4) 信息以乒乓形式结束后注销RPMsg相关资源,并进入死循环。

图 13

2 rpmsg_lite_str_echo_rtos案例

2.1 案例功能

(1) Cortex-A53释放Cortex-M4,然后初始化RPMsg,并创建端点。

(2) Cortex-A53启动Linux,执行握手服务,并创建通信信道。

(3) Linux驱动生成"/dev/ttyRPMSG30"节点,将用户输入至该节点的数据发送至Cortex-M4。

(4) Cortex-M4接收数据并进行打印,再将数据回发至Cortex-A53。

(5) Cortex-A53(Linux驱动)接收数据并进行打印。

2.2 案例测试

案例bin目录下分别提供了TCM版本程序镜像文件rpmsg_lite_str_echo_rtos.bin和DDR版本程序镜像文件rpmsg_lite_str_echo_rtos_ddr.bin。

在U-Boot命令行加载运行Cortex-M4程序镜像文件后,RS232 UART4调试串口打印如下信息。


图 14

运行boot命令,在Cortex-A53启动运行Linux系统。

U-Boot=> boot

图 15

进入评估板文件系统后,执行如下命令加载imx_rpmsg_tty模块,启动核间通信。

Target# modprobe imx_rpmsg_tty

图 16

Linux系统加载模块后,会发送数据"hello world"至Cortex-M4。Cortex-M4接收到数据后,在RS232 UART4调试串口将数据进行打印。

图 17

USB TO UART2调试串口执行如下命令,将接收到的数据发送至Cortex-M4。

Target# echo tronlong > /dev/ttyRPMSG30

图 18

Cortex-M4接收到数据后,在RS232 UART4调试串口将数据进行打印,同时将数据回发至Cortex-A53。

图 19

在USB TO UART调试串口执行如下命令,可查看Cortex-M4回发的数据。

Target# dmesg | grep rpmsg_tty

图 20

2.3 关键代码

Linux驱动程序

驱动的实现在imx_rpmsg_tty.c中完成,此文件位于内核"drivers/rpmsg/"路径下。

(1) imx_rpmsg_tty.c的写函数实现数据的发送,发送缓存最大设置为256Byte。

图 21

(2) 在回调函数中,每次接收到Cortex-M4的数据后,都以16进制的方式进行打印,打印等级为KERM_DEBUG。

图 22

FreeRTOS程序

程序主体位于main函数中,定义位于main_remote.c中。

(1) 在main函数中初始化引脚等相关资源,然后创建app_task任务,并启动任务列表。

图 23

(2) 在app_task任务中定义共享内存基地址,需和设备树中指定地址一致,再初始化RPMsg资源,并创建通信终端。


图 24

(3) 在for循环中实现数据收发。

图 25

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

    关注

    6

    文章

    360

    浏览量

    41657
  • 嵌入式主板
    +关注

    关注

    7

    文章

    6085

    浏览量

    35196
  • Cortex-M4
    +关注

    关注

    6

    文章

    89

    浏览量

    46510
  • Cortex-A53
    +关注

    关注

    0

    文章

    33

    浏览量

    21291
  • imx8
    +关注

    关注

    3

    文章

    41

    浏览量

    50172
收藏 人收藏

    评论

    相关推荐

    执法记录仪定制方案_单北斗执法记录仪_4G音视频执法记录仪定制开发方案

    这款执法记录仪的安卓主板采用了基于MT8768高效处理器的先进设计方案。该处理器包括四个主频高达2.0GHz的Cortex-A53核心和四个主频1.5GHz的Cortex-A53节能核心,提供强大
    的头像 发表于 08-22 17:53 438次阅读
    执法记录仪定制方案_单北斗执法记录仪_<b class='flag-5'>4</b>G音视频执法记录仪定制<b class='flag-5'>开发</b>方案

    【北京迅为】《i.MX8MM嵌入式Linux开发指南》-第四篇 嵌入式Linux系统移植篇-第六十七章 Uboot编译及移植

    i.MX8MM处理器采用了先进的14LPCFinFET工艺,提供更快的速度和更高的电源效率;四核Cortex-A53,单核Cortex-M4,多达五个内核,主频高达1.8GHz,2GDDR4
    的头像 发表于 08-07 15:08 607次阅读
    【北京迅为】《i.MX<b class='flag-5'>8</b>MM嵌入式Linux<b class='flag-5'>开发</b>指南》-第四篇 嵌入式Linux系统移植篇-第六十七章 Uboot编译及移植

    在ARM平台部署Windows,研扬助您踏入物联网生态系的全新领域

    ArmNXPi.MX8MPlus四核心Cortex-A53Cortex-M7处理器,以及提供高达2.3TOPSAI性能的NPU,研扬的SRG-IMX8P和SRT-
    的头像 发表于 05-11 08:05 358次阅读
    在ARM平台部署Windows,研扬助您踏入物联网生态系的全新领域

    ARM Cortex-A53嵌入式开发平台FETT507-C OKT507-C用户编译手册

    电子发烧友网站提供《ARM Cortex-A53嵌入式开发平台FETT507-C OKT507-C用户编译手册.pdf》资料免费下载
    发表于 04-28 15:20 0次下载

    ARM Cortex-A53嵌入式开发平台Android手册

    电子发烧友网站提供《ARM Cortex-A53嵌入式开发平台Android手册.pdf》资料免费下载
    发表于 04-28 15:10 0次下载

    Imagination新推APXM-6200 CPU,性能超越Cortex-A53

    该CPU为新时代的64位应用型处理器,采用11级别双通道线(11-stage, dual-issue pipeline),相较现有市场产品,其性能超出Arm Cortex-A53高达65%,赛过Cortex-A510则多出20%之多。
    的头像 发表于 04-09 15:04 591次阅读

    STM32H757XI使用STM32CubeIDE双核一起调试,cortex-M7无法运行怎么解决?

    ) != RESET) (timeout-- &gt; 0)); 然后用尽时间进入Error_Handler(void)。 但是与此同时cortex-M4可以正常调试。 如果不勾选
    发表于 04-01 06:02

    东芝推出适用于电机控制的Arm Cortex-M4微控制器

    东芝电子元件及存储装置株式会社(“东芝”)近日重磅推出新款适用于电机控制的TXZ+™族高级系列32位微控制器。该系列基于高效的Cortex®-M4内核,并集成了浮点单元(FPU),为电机控制提供了强大的计算支持。
    的头像 发表于 03-28 10:38 633次阅读

    适用于 ARM Cortex®—A53 处理器TPS65219-Q1数据表

    电子发烧友网站提供《适用于 ARM Cortex®—A53 处理器TPS65219-Q1数据表.pdf》资料免费下载
    发表于 03-27 13:46 0次下载
    适用于 ARM <b class='flag-5'>Cortex</b>®—<b class='flag-5'>A53</b> 处理器TPS65219-Q1数据表

    Cortex-M0+内核介绍

    8位的价位实现32位性能。处理器的低门数使其能够部署在需要简单功能的应用中。 作为ARM Cortex-M处理器系列的最新成员,32位Cortex-M0+处理器采用了低成本90纳米低功耗(LP)工艺,耗电量仅9μ
    的头像 发表于 03-27 09:13 947次阅读
    <b class='flag-5'>Cortex-M</b>0+内核介绍

    适用于ARM CortexA53处理器和FPGA TPS65219数据表

    电子发烧友网站提供《适用于ARM CortexA53处理器和FPGA TPS65219数据表.pdf》资料免费下载
    发表于 03-06 14:46 0次下载
    适用于ARM <b class='flag-5'>Cortex</b>—<b class='flag-5'>A53</b>处理器和FPGA TPS65219数据表

    Cortex-M85内核单片机如何快速上手

    2022年4月,Arm推出了全新的MCU级内核Cortex-M85。截止目前(2024年2月),Cortex-M85是最新、最强的Cortex-M内核。
    发表于 02-29 09:35 667次阅读
    <b class='flag-5'>Cortex-M</b>85内核单片机如何快速上手

    Cortex-A72应用实战

    下面Cortex-A72培训营VIP学员问:单核CPU PR做完后,怎么输出数据到TOP去做多核的hierarchy集成?
    的头像 发表于 01-24 10:17 768次阅读
    <b class='flag-5'>Cortex-A</b>72应用实战

    GD32A490 Arm®Cortex®-M4 32位MCU用户手册

    电子发烧友网站提供《GD32A490 Arm®Cortex®-M4 32位MCU用户手册.pdf》资料免费下载
    发表于 12-14 10:30 3次下载
    GD32<b class='flag-5'>A</b>490 Arm®<b class='flag-5'>Cortex</b>®-<b class='flag-5'>M4</b> 32位MCU用户手册

    基于iMX8处理器的SGTL5000音频接口设计

    iMX8 处理器具有多路 SAI 通道,SAI1 已经被模块片上的 SGTL5000 使用,SAI0 通道引出到模块金手指上,并且是兼容 Apalis 标准数字音频接口,该通道在基于其他 CPU 的 Apalis 模块也可以直接使用。因此,我们选择 SAI0 扩展外部 SGTL5000。
    发表于 12-01 14:38 438次阅读
    基于<b class='flag-5'>iMX8</b>处理器的SGTL5000音频接口设计