http://007sbw.cn 2025-11-07 09:23 來源:米爾電子
在嵌入式系統(tǒng)設(shè)計中,如何平衡高性能計算與實時控制一直是工程師面臨的挑戰(zhàn)。STM32MP257的異構(gòu)架構(gòu)為這一難題提供了優(yōu)雅的解決方案,而其中的Cortex-M33實時核更是實現(xiàn)硬實時性能的關(guān)鍵所在。
一、異構(gòu)架構(gòu):分工明確,效能卓越
STM32MP257采用創(chuàng)新的雙核子系統(tǒng)設(shè)計:
Cortex-A35應(yīng)用核(雙核1.5GHz):運行Linux系統(tǒng),負(fù)責(zé)復(fù)雜UI、網(wǎng)絡(luò)通信、文件管理等非實時任務(wù)。
Cortex-M33實時核(400MHz):專攻實時控制,具備納秒級中斷響應(yīng),集成FPU和DSP指令集。
二、架構(gòu)優(yōu)勢凸顯:
硬件級資源隔離:通過RIF單元確保M33核獨占關(guān)鍵外設(shè),避免核間沖突
能效精細(xì)控制:支持獨立電源域,M33可在A核休眠時單獨運行
安全可靠:TrustZone技術(shù),為關(guān)鍵代碼提供硬件級保護
三、OpenAMP:異構(gòu)通信的橋梁
OpenAMP是異構(gòu)系統(tǒng)中核心間消息通信的開源框架,基于RPMsg+共享內(nèi)存+中斷,讓Linux核和Cortex-M核可以可靠地傳遞消息和數(shù)據(jù),高效地共享數(shù)據(jù)或協(xié)調(diào)任務(wù)的機制,簡化異構(gòu)多核開發(fā)。
在STM32MP257中,典型實現(xiàn)方式包括remoteproc+virtio+RPMsg等。它的核心目標(biāo)是讓Cortex-A核和Cortex-M核協(xié)同工作,同時保持資源隔離和實時性能。
STM32MP257使用了RemoteProc框架讓A核運行的Linux系統(tǒng)可以更加輕松的和M核進行通信控制,RemoteProc主要作用就是對遠(yuǎn)程處理器的生命周期進行管理,即啟動、停止遠(yuǎn)程處理器。該框架還會創(chuàng)建 RPMsg Virtio 設(shè)備。以下是RemoteProc的邏輯框圖:

圖1 RemoteProc運行邏輯
在RemoteProc框架中,需要在Linux系統(tǒng)中將M核的固件通過命令加載到M核的內(nèi)存中。
RPMsg框架( Remote Processor Messaging Framework )則是實現(xiàn)對遠(yuǎn)程處理器信息傳遞。RPMsg是基于VirtIO的消息總線,它允許內(nèi)核驅(qū)動程序與系統(tǒng)上可用的遠(yuǎn)程處理器進行通信。通訊框架入下圖:

圖2 RPMSG框架
消息服務(wù)基于共享內(nèi)存,使用 RPMsg 和 Virtio 框架,RemoteProc框架則控制遠(yuǎn)程處理器生命周期。信號通知( Mailbox )服務(wù)則基于內(nèi)部IPCC( Inter-Processor communication controller ),ST提供 OpenAMP相關(guān)庫。
Virtio 是一個支持虛擬化的 I/O 框架,通過共享環(huán)形緩沖區(qū)(vring)提供高效的消息傳輸層。Virtio中有兩個單向的vring,分別用于處理器之間的消息傳遞,RX VRING 用于接收來自遠(yuǎn)程處理器的消息,TX VRING專用于將消息發(fā)送到遠(yuǎn)程處理器。
四、實戰(zhàn)演練:異核控制LED
基于異構(gòu)通訊框架,A核通過發(fā)送LED控制命令,驅(qū)動M33核響應(yīng)并實現(xiàn)LDE燈的開關(guān)操作。
在構(gòu)建前需要將開發(fā)板設(shè)備樹中的gpio_led的藍(lán)燈關(guān)閉,關(guān)閉A核占用,設(shè)備樹中修改位置具體如下:

圖3 設(shè)備樹屏蔽藍(lán)燈
關(guān)閉后將設(shè)備樹單獨構(gòu)建并更新到開發(fā)板中,具體方式請查閱《MYD-LD25X Linux 軟件開發(fā)指南》中4.3章節(jié)。
在IDE中導(dǎo)入OpenAMP_TTY_echo_Led例程,導(dǎo)入完成后如下所示:

圖4 例程導(dǎo)入
該例程由官方例程OpenAMP_TTY_echo修改,主要修改即為下圖中虛擬串口回調(diào)函數(shù)的框選部分:

圖5 回調(diào)函數(shù)修改
實現(xiàn)過程比較簡單,基本是對A核的消息進行了判斷處理,針對GPIO的主要控制使用了HAL_GPIO_WritePin函數(shù),該函數(shù)位于Drivers/BSP/stm32mp2xx_hal_gpio.c:

圖6 函數(shù)實現(xiàn)
程序運行流程圖:

圖7 OpenAMP_TTY_echo_Led流程圖
然后繼續(xù)構(gòu)建,點擊上圖4中的OpenAMP_TTY_echo_Led_CM33_NonSecure,然后點擊上方錘子右邊箭頭并選擇CA35TDCID_m33_ns_sign:

圖8 編譯選擇
選擇后會立即構(gòu)建編譯,完成后在CA35TDCID_m33_ns_sign目錄中拷貝elf文件到開發(fā)板中:

圖9 拷貝文件
確保在開發(fā)板中目錄結(jié)構(gòu)如下:

圖10 目錄結(jié)構(gòu)
輸入以下內(nèi)容執(zhí)行腳本,運行后如圖所示:
root@myd-ld25x:~/OpenAMP_TTY_echo_Led# ./fw_cortex_m33.sh start

圖11 運行程序
在A核輸入以下命令后臺監(jiān)控M核虛擬串口反饋:
root@myd-ld25x:~/OpenAMP_TTY_echo_Led# cat /dev/ttyRPMSG0 &
root@myd-ld25x:~/OpenAMP_TTY_echo_Led#
輸入以下命令控制Led藍(lán)燈亮滅:
root@myd-ld25x:~/OpenAMP_TTY_echo_Led# echo on > /dev/ttyRPMSG0
root@myd-ld25x:~/OpenAMP_TTY_echo_Led# echo off > /dev/ttyRPMSG0
結(jié)果如下:

圖12 運行結(jié)果

圖13 米爾基于STM32MP257核心板及開發(fā)板