STM32MP1处理器下实现RT-Thread和Linux同时运行

发布者:科技飞翔最新更新时间:2023-08-30 来源: elecfans关键字:STM32MP1  处理器  RT-Thread  Linux 手机看文章 扫描二维码
随时随地手机看文章

架构说明

本项目以 STM32MP157A-DK1 为硬件平台。作为能够支持轻松开发更广泛应用的通用微处理器产品线,STM32MP157 系列基于双核Cortex-A7 与 Cortex-M4 组成的异构架构,加强了支持多应用和灵活应用的能力,可以随时实现最佳性能和功率数据。Cortex-A7 内核提供对开源操作系统(Linux/Android)的支持,而 Cortex-M4 内核可以利用 STM32 MCU 的生态系统。本篇文章将介绍如何在 STM32MP157 上运行 RT-Thread OS。

2d43c572-580b-11ed-b468-dac502259ad0.png

启动方式

Forced USB boot For flashing : 通过 USB 烧写固件。在此模式下,可以使用 STM32Cube Programmer 工具烧写 A7 核固件。

Engineer Mode: 一般用于 M4 核的调试。由于 STM32MP1 没有 Flash,所以代码会被烧写到 Cortex-M4 核有访问权限的 RAM 里面,因此掉电程序会丢失。

SD card on SDMMC1 : 从 SD card 启动。


工作模式

STM32MP1 有两种工作模式

工程模式(Engineer Mode),系统上电后,不会启动 A7 核。M4 核此时可以像平常 STM32 的开发流程,借助于调试工具进行调试。

产品模式(Production Mode),系统上电后,会先启动 A7 核,然后由 A7 核来启动 M4 核。


OpenAMP

开源的非对称多处理框架(OpenAMP)为开发 AMP 系统提供了必要的 API 函数。OpenAMP 是 Xilinx 和M entor Graphic 于2014年发起的一个开源项目,旨在提供一份协处理器的标准通信框架。OpenAMP 提供用于开发 AMP 系统软件应用程序所需的软件组件,它允许操作系统在各种复杂的同构和异构结构中交互,并允许不对称的多处理应用程序利用多核配置提供并行性。在 STM32MP1 系列中,A7 和 M4 两个核心的通信是通过底层的 IPCC 控制器进行,软件层使用 RPMsg 框架与用户进行交互。


IPCC

处理器间通信控制器 (IPCC) 用于两个处理器之间的数据交换。它提供了一种非阻塞的信号机制,以原子方式发布和检索信息。IPCC 外设提供了硬件支持来管理两个处理器之间的通信,每个处理器都拥有特定的寄存器库和中断。IPCC 为内核间的通信提供了硬件基础。


STM32MP1 使用 IPCC 外设进行处理器间通信,配置如下:

IPCC 处理器 1 接口被分配到 ARM Cortex-A7 不安全上下文,由 Linux 邮箱框架进行处理

IPCC 处理器 2 接口被分配到 ARM Cortex-M4 上下文,由 IPCC HAL 驱动程序进行处理

2d62a14a-580b-11ed-b468-dac502259ad0.png

REMOTEPROC

远程处理器框架(remoteproc)的主要作用作用是对远程从处理器进行生命周期的管理,启动和停止远程处理器。在 STM32MP157 中,当系统启动时,A7 核会被先启动,然后借助于 Linux RemoteProc 框架加载 M4 固件,启动 M4 内核代码。

2d7f3620-580b-11ed-b468-dac502259ad0.png

RPMsg

Remoteproc 框架实现了对远程处理器生命周期的管理,RPMsg 框架则实现了对远程处理器的信息传递。

Linux RPMsg (Remote Processor Messaging)框架是在 virtio 框架上实现的信息传递机制,以便与远程处理器进行通信,它基于 virtio vrings 通过共享内存发送、接收来自远程处理器的消息。

vrings 是单向的,一个 vring 专门用于发送消息到远程处理器,另外一个 vring 用于接收来自远程服务器的消息。消息服务基于共享内存,共享内存(shared memory)是在两个处理器都具有访问权限的内存空间中创建的;信号通知(mailbox)服务基于内部 IPCC。

2db7803e-580b-11ed-b468-dac502259ad0.png

编译&运行

生成 ELF 文件

在 rt-thread/bsp/stm32/stm32mp157a-st-discovery 目录下打开 env 工具;

输入 menuconfig,打开 OpenAMP:

2e6ba636-580b-11ed-b468-dac502259ad0.png

配置串口。由于官方默认的程序中 A7 核(OpenSTLinux)需要使用串口 4 ,所以这里修改 M4 核(RT-Thread)的调试串口为 UART3:

2e82d266-580b-11ed-b468-dac502259ad0.png

2ea2157c-580b-11ed-b468-dac502259ad0.png

保存配置,输入命令 scons --target=iar 生成 IAR 工程。

2eaa228a-580b-11ed-b468-dac502259ad0.png

打开 IAR 工程。编译,生成 ELF 文件:

2eb9ff84-580b-11ed-b468-dac502259ad0.png

KEIL 的操作和上面 IAR 的操作是一样的,只不过 KEIL 生成的是 axf 文件,一样可以正常使用。

加载 ELF 文件

设置 Boot mode 为 SD card on SDMMC1 模式,复位开发板:

等待系统初始化完成,输入命令ifconfig获取开发板 IP 地址;

使用 ssh 工具连接开发板:

2ed85ae2-580b-11ed-b468-dac502259ad0.png

上传 ELF 文件:

2ee6f192-580b-11ed-b468-dac502259ad0.png

连接串口3,作为 M4 核(RT-Thread OS)调试串口:

2efa9120-580b-11ed-b468-dac502259ad0.png

使用 Linux Remoteproc 框架加载 Cortex-M4 固件,启动 Cortex-M4 内核:

mv /tmp/RT-Thread-STM32MP1_CM4.elf /lib/firmware/echo RT-Thread-STM32MP1_CM4.elf > /sys/class/remoteproc/remoteproc0/firmwareecho start > /sys/class/remoteproc/remoteproc0/state

2f2e4f24-580b-11ed-b468-dac502259ad0.png

2f57c58e-580b-11ed-b468-dac502259ad0.png

启动 OpenAMP

在 RT-Thread 终端输入命令 console set openamp 切换 RT-Thread console 设备为 openamp:

2f7527f0-580b-11ed-b468-dac502259ad0.png

在 Linux 终端输入以下命令:

stty-onlcr-echo-F/dev/ttyRPMSG0cat/dev/ttyRPMSG0&

在 Linux 终输入命令进行验证:

2f7f3ed4-580b-11ed-b468-dac502259ad0.png

完整操作流程

2f9601c8-580b-11ed-b468-dac502259ad0.png

结语

STM32MP1 作为 ST 推出的第一颗支持 Linux 系统的 MPU,依托于 STM32 成熟的生态系统(STM32CubeMX、STM32Cube Programmer),用户可以快速的进行开发,验证。非对称多处理器架构虽然目前在嵌入式领域还不是主流,但未来肯定是趋势。通过 Linux 与 RT-Thread 操作系统的结合,可以很轻松的开发多场景应用,如工业、家居、消费品、物联网、卫生和健康等领域。期待未来 RT-Smart 和 RT-Thread 能同时运行在非对称多处理器上。


关键字:STM32MP1  处理器  RT-Thread  Linux 引用地址:STM32MP1处理器下实现RT-Thread和Linux同时运行

上一篇:STM32CUBEMX开发GD32F303(13)----定时器TIM捕获PWM测量频率与占空比
下一篇:基于STM32+RC522设计的门禁系统

推荐阅读最新更新时间:2024-11-12 13:00

华为开始采购高通处理器:生产4G手机、待大翻盘
之前高通方面已经证实,可以向华为供应处理器,不过仅局限在4G方面,而5G方面还在观察中。   据第一财经报道称,华为的4G新手机订单已经陆续开始备,按照市场订单出货节奏,现阶段的手机订单成品预计明年上半年上市。从时间点判断,最快将会在一季度。   报道中还提到,华为内部员工表示,4G芯片的供应,可以解决海外大部分区域手机和平板的需求问题,这样就能够把海外主要地区的渠道养住,保留队伍和火种,等待未来的翻盘机会。“目前,东欧、俄罗斯、亚太、中东、非洲以及拉美等地区仍然是4G市场,部分地区只提供4G网络,4G产品依然具有竞争力。”   从获得许可的情况来看,能为华为提供4G芯片的厂商目前只有高通。   据了解,高通此前曾积极推动美国
[手机便携]
s3c6410在linux下的WATCHDOG TIMER(看门狗定时器)驱动(3)
前面两篇一篇分析了看门狗定时器的驱动架构,另一篇分析了平台设备对应的probe函数,虽然对应的remove函数没分析,其实和别的平台设备驱动一样,做和probe函数相反的工作。这一篇要说点啥呢? S3c2410_wdt.c (linux2.6.28driverswatchdog)在这个文件中还有很多函数,我们都没有分析过,这一篇就找些重要的函数分析下。 1、那就先从s3c2410wdt_start函数开始,此函数开启看门狗,源码如下: static void s3c2410wdt_start(void) { unsigned long wtcon; spin_lock(&wdt_lock); __s3c2410
[单片机]
s3c6410在<font color='red'>linux</font>下的WATCHDOG TIMER(看门狗定时器)驱动(3)
移植Linux-5.4+内核到4412开发板
前言 ITOP-4412开发板被 Linux 官方支持,所以我们在4412上学习新的内核是非常方便的,本文作者是4412精英群8群一位技术高手,接下来,我们一起来欣赏下他的表演。 环境说明 OS版本 Ubuntu 20 LTS 交叉编译环境配置 ~$ sudo apt install gcc-arm-linux-gnueabihf ~$ sudo apt install flex ~$ sudo apt install bison ~$ sudo apt install u-boot-tools 目标开发板 CPU (Exynos4412,四核 Cortex -A9,主频为1.4GHz-1.6GHz) RAM (1GB 双通道
[单片机]
移植<font color='red'>Linux</font>-5.4+内核到4412开发板
飞思卡尔C29x加密协处理器:网络数据安全的“门神”
从网银密码说起 先来问您一个问题,您的网银密码是多少位的?您可能还需要用手指数一数吧?现在越来越多的人使用网上银行并且进行网上购物,而随之而来的是网络犯罪率的迅速增长。人们对于网络安全的防范意识正在逐步提高(例如增加密码复杂度),使得很多企业(如社交网站)对于数据安全的要求也越来越高。例如,Facebook支持HTTPS协议加密,谷歌所有的搜索都使用SSL,对所有的邮件都进行加密,并且升级为2 048 bit的密钥。“棱镜门”事件也使得一些敏感部门(如银行、政府及国防)对于自身数据安全性的要求也更为严格。 针对目前的网络安全需求,市场亟需高性能、具有成本效益和低功耗的安全协处理器,然而目前很少有厂商进入这一领域。飞思
[网络通信]
飞思卡尔C29x加密协<font color='red'>处理器</font>:网络数据安全的“门神”
利用堆叠同步降压转换器支持大电流的ADAS处理器
车辆系统的电气化在高级驾驶辅助系统 (ADAS) 中不断发展,其中包括自动驾驶视觉分析、停车辅助和自适应控制功能。 智能连接、安全关键软件应用程序和神经网络处理都需要增强的实时计算能力。 作者:Canan Priess,德州仪器 (TI) 汽车产品营销工程师 满足这些高级需求需要 TDA4VH-Q1 等多核处理器,它的功耗超过 100 A。与高功率相关的设计挑战包括实现更高电流轨的效率、控制热性能和负载瞬态相应,并满足功能安全要求。 提供 ADAS 处理能力 TPS62876-Q1 降压转换器可帮助设计人员通过新颖的可堆叠功能实现超过 30A 的电流,该功能可实现为 TDA4VH-Q1 等片上系统 (SoC) 供电
[汽车电子]
利用堆叠同步降压转换器支持大电流的ADAS<font color='red'>处理器</font>
深度揭秘麒麟970 人工智能处理器,它的强大超出你想象!
  2017年9月2日, 华为 消费者业务CEO余承东在德国柏林IFA2017大会官方论坛发表“Mobile AI. The Ultimate Intelligent Experience”为主题的演讲,全面阐释了 华为 消费者业务的人工智能战略,并正式发布了麒麟970芯片。这款有55亿晶体管、全球首款内置神经网络处理单元(NPU)的人工智能处理器震撼了产业,震撼了全球!从公布的数据来看,NPU运算能力达到1.92T FP16 OPS!是同等CPU处理器能力的25倍!能效是其50倍!这款处理器让 华为 一举站在了全球移动人工智能(AI)领域的最前沿!下面就随网络通信小编一起来了解一下相关内容吧。        深度揭秘麒麟9
[网络通信]
只有原子厚度的微处理器,让可弯曲电子产品变成可能
维也纳大学的研究人员使用了一种特别的材料──过渡金属二硫属性元素(transition-metal dichalcogenide,TMD) ,来打造可以改变形状的微处理器,像是奇迹材料石墨烯一样,TMD 可以形成只有一个原子厚度的层状结构,打造出一个接近二维的表面,像是一张超级轻薄的纸,这就是为什么可以让电器产品变形的关键。 Network World 报导,这处理器的功效远不及我们现在使用的那么强大,实际上,它只是一个具有 115 个晶体管的单一位(bit)处理器,只能执行 4 个指令。 然而,在研究人员论文于《Nature》杂志上发表,他们指出,这是「开发二维半导体微处理器的第一步。 」虽然功能单一,但却是开发可变形电子产品
[半导体设计/制造]
13.ARM协处理器的知识
在处理器中有协处理器来辅助处理器完成部分功能的,主要是协助作用。 协处理器: 协处理器用于执行特定的处理任务,如:数学协处理器可以控制数字处理,以减轻处理器的负担。ARM可支持多达16个协处理器,其中CP15是最重要的一个。 在ARM9、ARM11、cortexa8等核中,CP15的功能都是一样的。 在ARM11核的文档看到图1-1: The section gives an overall view of the system control coprocessor. For detail of the registers in the system control coprocessor, see System contr
[单片机]
13.ARM协<font color='red'>处理器</font>的知识
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
随便看看

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved