91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

i.MX 8M Mini——四核Cortex-A53+Cortex-M4多核CPU如何實(shí)現(xiàn)工控

Tronlong創(chuàng)龍科技 ? 2022-04-29 17:58 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

隨著ARM處理器性能不斷增強(qiáng),當(dāng)前越來(lái)越多產(chǎn)品都傾向盡量用單一架構(gòu)的高性能ARM平臺(tái)來(lái)滿足產(chǎn)品的不同功能要求。但是,在工業(yè)應(yīng)用領(lǐng)域還是要面對(duì)一些實(shí)時(shí)控制和通訊的要求,單一系統(tǒng)架構(gòu)無(wú)法完全滿足。面對(duì)復(fù)雜的工業(yè)應(yīng)用場(chǎng)景,創(chuàng)龍科技推出了基于NXP i.MX 8M Mini設(shè)計(jì)的工業(yè)核心板和評(píng)估板,提供了四核Cortex-A53 + 單核Cortex-M4異構(gòu)多核的組合使用方法,使Cortex-M4發(fā)揮出MCU實(shí)時(shí)控制性的特性,從而滿足復(fù)雜的工業(yè)應(yīng)用場(chǎng)景。

NXP i.MX 8M Mini是一款集成4核ARM Cortex-A53 + 單核ARM Cortex-M4的異構(gòu)多核SoC處理器。Cortex-A53核主頻高達(dá)1.6GHz,運(yùn)行Linux系統(tǒng),可實(shí)現(xiàn)復(fù)雜的人機(jī)交互和高速運(yùn)算等應(yīng)用要求。Cortex-M4核運(yùn)行裸機(jī)或FreeRTOS系統(tǒng),實(shí)現(xiàn)實(shí)時(shí)控制和通訊的任務(wù),比如:電機(jī)實(shí)時(shí)控制、IO實(shí)時(shí)控制、串口通訊、與FPGA通過(guò)FLexSPI實(shí)時(shí)通訊等。

i.MX 8M Mini處理器資源框圖

圖 1 i.MX 8M Mini處理器資源框圖

i.MX 8M Mini Cortex-M4資源框圖

圖 2 i.MX 8M Mini Cortex-M4資源框圖

1 rpmsg_lite_pingpong_rtos案例

1.1 案例功能

(1) Cortex-A53釋放Cortex-M4,然后初始化RPMsg,并創(chuàng)建端點(diǎn)。

(2) Cortex-A53啟動(dòng)Linux系統(tǒng),執(zhí)行握手服務(wù),創(chuàng)建通信信道,并發(fā)送一條信息至Cortex-M4。

(3) Cortex-M4接收到第一條信息時(shí),計(jì)數(shù)器自加1,然后回發(fā)計(jì)數(shù)器值至Cortex-A53。

(4) Cortex-A53接收Cortex-M4發(fā)送的計(jì)數(shù)器數(shù)值,計(jì)數(shù)器自加1,然后回發(fā)計(jì)數(shù)器數(shù)值至Cortex-M4。

(5) 當(dāng)計(jì)數(shù)器數(shù)值大于100時(shí),通信結(jié)束。


1.2 案例測(cè)試

案例bin目錄下分別提供了TCM版本程序鏡像文件rpmsg_lite_pingpong_rtos_linux_remote.bin和DDR版本程序鏡像文件rpmsg_lite_pingpong_rtos_linux_remote_ddr.bin。

在U-Boot命令行加載運(yùn)行Cortex-M4程序鏡像文件后,RS232 UART4調(diào)試串口打印如下信息。

圖 3

運(yùn)行boot命令,在Cortex-A53啟動(dòng)運(yùn)行Linux系統(tǒng)。

U-Boot=>boot

poYBAGJrppuANnohAAAswDU0hsM939.png

圖 4

進(jìn)入評(píng)估板文件系統(tǒng)后,執(zhí)行如下命令加載imx_rpmsg_pingpong模塊,啟動(dòng)核間通信。

Target#modprobe imx_rpmsg_pingpong

圖 5

加載模塊后,Cortex-M4將接收Cortex-A53發(fā)送的數(shù)據(jù),并將其轉(zhuǎn)發(fā)回Cortex-A53,循環(huán)50次后結(jié)束。RS232 UART4調(diào)試串口打印信息如下。

poYBAGJrppuAer5wAAAcKujtiYo003.png

圖 6

pYYBAGJrpqGAcZuBAAi37MdRkUQ659.png

圖 7

1.3 關(guān)鍵代碼

Linux驅(qū)動(dòng)程序

驅(qū)動(dòng)的實(shí)現(xiàn)在imx_rpmsg_pingpong.c中完成,此文件位于內(nèi)核"drivers/rpmsg/"路徑下。

(1) Linux系統(tǒng)加載驅(qū)動(dòng)后,先發(fā)送一條helloMsg,然后發(fā)送第一條乒乓信息。

圖 8

(2) 在回調(diào)函數(shù)中,每次接收到Cortex-M4的計(jì)數(shù)器數(shù)據(jù)后自加1,并回發(fā)至Cortex-M4,直到計(jì)數(shù)器數(shù)值大于100。

圖 9

FreeRTOS程序

程序主體位于main函數(shù)中,定義位于main_remote.c中。

(1) 在main函數(shù)中首先初始化引腳等相關(guān)資源,然后創(chuàng)建app_task任務(wù),并啟動(dòng)任務(wù)列表。

圖 10

(2) 在app_task任務(wù)中定義共享內(nèi)存基地址,需和設(shè)備樹中指定地址一致,再初始化RPMsg資源,并等待連接上遠(yuǎn)程終端。

圖 11

(3) 接收helloMsg,并循環(huán)收發(fā)乒乓信息。

圖 12

(4) 信息以乒乓形式結(jié)束后注銷RPMsg相關(guān)資源,并進(jìn)入死循環(huán)。

pYYBAGJrpp2AT7hvAACiNc7KToQ962.png

圖 13

2 rpmsg_lite_str_echo_rtos案例

2.1 案例功能

(1) Cortex-A53釋放Cortex-M4,然后初始化RPMsg,并創(chuàng)建端點(diǎn)。

(2) Cortex-A53啟動(dòng)Linux,執(zhí)行握手服務(wù),并創(chuàng)建通信信道。

(3) Linux驅(qū)動(dòng)生成"/dev/ttyRPMSG30"節(jié)點(diǎn),將用戶輸入至該節(jié)點(diǎn)的數(shù)據(jù)發(fā)送至Cortex-M4。

(4) Cortex-M4接收數(shù)據(jù)并進(jìn)行打印,再將數(shù)據(jù)回發(fā)至Cortex-A53。

(5) Cortex-A53(Linux驅(qū)動(dòng))接收數(shù)據(jù)并進(jìn)行打印。

2.2 案例測(cè)試

案例bin目錄下分別提供了TCM版本程序鏡像文件rpmsg_lite_str_echo_rtos.bin和DDR版本程序鏡像文件rpmsg_lite_str_echo_rtos_ddr.bin。

在U-Boot命令行加載運(yùn)行Cortex-M4程序鏡像文件后,RS232 UART4調(diào)試串口打印如下信息。

圖 14

運(yùn)行boot命令,在Cortex-A53啟動(dòng)運(yùn)行Linux系統(tǒng)。

U-Boot=>boot

pYYBAGJrpp2AfBfSAAAsYaJARDU809.png

圖 15

進(jìn)入評(píng)估板文件系統(tǒng)后,執(zhí)行如下命令加載imx_rpmsg_tty模塊,啟動(dòng)核間通信。

Target#modprobe imx_rpmsg_tty

圖 16

Linux系統(tǒng)加載模塊后,會(huì)發(fā)送數(shù)據(jù)"hello world"至Cortex-M4。Cortex-M4接收到數(shù)據(jù)后,在RS232 UART4調(diào)試串口將數(shù)據(jù)進(jìn)行打印。

圖 17

USB TO UART2調(diào)試串口執(zhí)行如下命令,將接收到的數(shù)據(jù)發(fā)送至Cortex-M4。

Target#echo tronlong > /dev/ttyRPMSG30

圖 18

Cortex-M4接收到數(shù)據(jù)后,在RS232 UART4調(diào)試串口將數(shù)據(jù)進(jìn)行打印,同時(shí)將數(shù)據(jù)回發(fā)至Cortex-A53。

pYYBAGJrpp6AOW_FAAAW8Yl4K3U335.png

圖 19

在USB TO UART調(diào)試串口執(zhí)行如下命令,可查看Cortex-M4回發(fā)的數(shù)據(jù)。

Target#dmesg | grep rpmsg_tty

圖 20

2.3 關(guān)鍵代碼

Linux驅(qū)動(dòng)程序

驅(qū)動(dòng)的實(shí)現(xiàn)在imx_rpmsg_tty.c中完成,此文件位于內(nèi)核"drivers/rpmsg/"路徑下。

(1) imx_rpmsg_tty.c的寫函數(shù)實(shí)現(xiàn)數(shù)據(jù)的發(fā)送,發(fā)送緩存最大設(shè)置為256Byte。

圖 21

(2) 在回調(diào)函數(shù)中,每次接收到Cortex-M4的數(shù)據(jù)后,都以16進(jìn)制的方式進(jìn)行打印,打印等級(jí)為KERM_DEBUG。

圖 22

FreeRTOS程序

程序主體位于main函數(shù)中,定義位于main_remote.c中。

(1) 在main函數(shù)中初始化引腳等相關(guān)資源,然后創(chuàng)建app_task任務(wù),并啟動(dòng)任務(wù)列表。

圖 23

(2) 在app_task任務(wù)中定義共享內(nèi)存基地址,需和設(shè)備樹中指定地址一致,再初始化RPMsg資源,并創(chuàng)建通信終端。

圖 24

(3) 在for循環(huán)中實(shí)現(xiàn)數(shù)據(jù)收發(fā)。

圖 25

IMX8 Cortex-A53與Cortex-M4多核通信開發(fā)案例是創(chuàng)龍科技(Tronlong)基于NXP i.MX 8M Mini處理器設(shè)計(jì)的工業(yè)評(píng)估板——TLIMX8-EVM上實(shí)現(xiàn)的,它由核心板+底板構(gòu)成,用戶使用核心板進(jìn)行二次開發(fā)時(shí),僅需專注上層運(yùn)用,降低了開發(fā)難度和時(shí)間成本,可快速進(jìn)行產(chǎn)品方案評(píng)估與技術(shù)預(yù)研。

IMX8 Cortex-A53與Cortex-M4多核通信開發(fā)案例是創(chuàng)龍科技(Tronlong)基于NXP i.MX 8M Mini處理器設(shè)計(jì)的工業(yè)評(píng)估板——TLIMX8-EVM上實(shí)現(xiàn)的,它由核心板+底板構(gòu)成,用戶使用核心板進(jìn)行二次開發(fā)時(shí),僅需專注上層運(yùn)用,降低了開發(fā)難度和時(shí)間成本,可快速進(jìn)行產(chǎn)品方案評(píng)估與技術(shù)預(yù)研。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1660

    文章

    22415

    瀏覽量

    636544
  • ARM
    ARM
    +關(guān)注

    關(guān)注

    135

    文章

    9554

    瀏覽量

    392064
  • 嵌入式
    +關(guān)注

    關(guān)注

    5199

    文章

    20454

    瀏覽量

    334269
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    請(qǐng)問(wèn)qemu 可以模擬 i.MX 8M Plus 嗎?

    我們沒(méi)有i.MX 8M Plus板,所以我想問(wèn)一下 qemu 是否可以模擬i.MX 8M Plus? 我想運(yùn)行基于i.MX
    發(fā)表于 03-05 08:10

    最小化ARM Cortex-M CPU功耗的方法與技巧分享

    完成填充。在Cortex-M3或Cortex-M4內(nèi)核中,CPU配備了一條3級(jí)流水線。刷新整條流水線將導(dǎo)致CPU延遲3個(gè)時(shí)鐘周期,如果有Flash存儲(chǔ)器等待狀態(tài)發(fā)生,時(shí)間會(huì)更長(zhǎng),以便完
    發(fā)表于 01-21 06:19

    FRDM i.MX 9平臺(tái)選型指南:FRDM i.MX 9系列開發(fā)平臺(tái)解析

    FRDM i.MX 9系列開發(fā)平臺(tái)的入門級(jí)產(chǎn)品 FRDM i.MX 9系列概述 恩智浦FRDM i.MX 9系列基于圍繞Arm^?^ Cortex ^?
    的頭像 發(fā)表于 12-11 15:15 ?3.4w次閱讀
    FRDM <b class='flag-5'>i.MX</b> 9平臺(tái)選型指南:FRDM <b class='flag-5'>i.MX</b> 9系列開發(fā)平臺(tái)解析

    恩智浦FRDM i.MX 8M Plus開發(fā)板詳解

    在開發(fā)高級(jí)HMI應(yīng)用、計(jì)算機(jī)視覺系統(tǒng)以及邊緣AI項(xiàng)目時(shí),開發(fā)人員常常面臨一個(gè)共同挑戰(zhàn):如何在不依賴昂貴且復(fù)雜的開發(fā)平臺(tái)的前提下,獲得足夠的處理能力。這正是FRDM i.MX 8M Plus的價(jià)值所在,該解決方案是一款專為開發(fā)人員打造的平臺(tái)。
    的頭像 發(fā)表于 11-18 15:07 ?1414次閱讀

    基于恩智浦i.MX RT1180芯片的EtherCAT+伺服電機(jī)控制方案

    i.MX RT1180是恩智浦最近推出的一款高性能跨界處理器,其中包含了300MHz的Arm Cortex-M33以及800MHz的Arm Cortex-M7
    的頭像 發(fā)表于 09-22 16:27 ?8585次閱讀
    基于恩智浦<b class='flag-5'>i.MX</b> RT1180芯片的EtherCAT+伺服電機(jī)控制方案

    恩智浦FRDM i.MX 8M Plus開發(fā)板上架

    i.MX 8M Plus應(yīng)用處理器集成2個(gè)或4個(gè)Arm Cortex-A53、1個(gè)專用于實(shí)時(shí)控制的Arm
    的頭像 發(fā)表于 08-16 17:38 ?2211次閱讀
    恩智浦FRDM <b class='flag-5'>i.MX</b> <b class='flag-5'>8M</b> Plus開發(fā)板上架

    【飛凌嵌入式】基于i.MX9352開發(fā)板M的FreeRTOS設(shè)計(jì)例程

    i.MX 9352作為NXP 推出的新一代輕量級(jí)邊緣AI處理器,集成2個(gè)Cortex-A55和1個(gè)Cortex-M33實(shí)時(shí),其架構(gòu)設(shè)計(jì)充
    的頭像 發(fā)表于 06-13 16:14 ?2175次閱讀
    【飛凌嵌入式】基于<b class='flag-5'>i.MX</b>9352開發(fā)板<b class='flag-5'>M</b><b class='flag-5'>核</b>的FreeRTOS設(shè)計(jì)例程

    米爾NXP i.MX 91核心板發(fā)布,助力新一代入門級(jí)Linux應(yīng)用開發(fā)

    使用。 MYC-LMX91核心板及開發(fā)板?基于 NXP i.MX 91作為NXP新款入門級(jí)處理器,具有低成本、低功耗的特點(diǎn)。i.MX 91配備單核 Cortex-A55@1.4 GHz,可與i
    發(fā)表于 05-30 11:20

    TPS6521825 適用于 NXP i.MX 8M mini 的電源管理 IC數(shù)據(jù)手冊(cè)

    TPS6521825 是一款單芯片電源管理 IC (PMIC),專門用于支持 i.MX 8M Mini 處理器和 LP873347 器件。該器件的額定溫度范圍為 –40°C 至 +105°C,適用于各種工業(yè)應(yīng)用。
    的頭像 發(fā)表于 05-04 10:44 ?923次閱讀
    TPS6521825 適用于 NXP <b class='flag-5'>i.MX</b> <b class='flag-5'>8M</b> <b class='flag-5'>mini</b> 的電源管理 IC數(shù)據(jù)手冊(cè)

    瑞芯微RK3506(3ARM+Cortex-A7 + ARM Cortex-M0)工業(yè)核心板選型資料

    創(chuàng)龍科技SOM-TL3506是一款基于瑞芯微RK3506J/RK3506B處理器設(shè)計(jì)的3ARM Cortex-A7 + ARM Cortex-M0全國(guó)產(chǎn)工業(yè)核心板,主頻高達(dá)1.5GHz。核心板
    的頭像 發(fā)表于 04-09 09:04 ?3602次閱讀
    瑞芯微RK3506(3<b class='flag-5'>核</b>ARM+<b class='flag-5'>Cortex-A</b>7 + ARM <b class='flag-5'>Cortex-M</b>0)工業(yè)核心板選型資料

    如何禁用i.MX RT1170 MCU中的M4內(nèi)核?

    如何禁用 i.MX RT1170 MCU 中的 M4 內(nèi)核? 您能否提供具體的可行方法? 或者是否可以將內(nèi)核的工作時(shí)鐘頻率降低到 0 ?
    發(fā)表于 04-09 07:28

    如何在i.MX 8XDXL EVK的A35上運(yùn)行Yocto Linux,在M4上運(yùn)行FreeRTOS?

    我正在使用i.MX 8XDXL 評(píng)估套件并希望在 Cortex-A35 上運(yùn)行 Yocto Linux 映像cores 的Cortex-M4 上的 FreeRTOS 映像核心。
    發(fā)表于 04-04 06:02

    i.MX8MMini中的Cortex-M4不支持SDIO嗎?

    我們正在嘗試使用 i.MX8MMini (Cortex-A53/-M4) 并考慮在 Cortex-M4 協(xié)處理器中實(shí)現(xiàn)無(wú)線模塊 (SDIO
    發(fā)表于 04-03 06:45

    將Deepseek移植到i.MX 8MP|93 EVK的步驟

    測(cè)試了不同模型對(duì)不同電路板的影響。需要注意的是,限制模型在電路板上運(yùn)行的最大障礙是內(nèi)存。包括 CPU 和內(nèi)存使用情況在內(nèi)的測(cè)試結(jié)果如下: a. i.MX8mp 深度搜索-r1-蒸餾
    發(fā)表于 03-26 06:08

    Arm Cortex-A57和Arm Cortex-A53 CPU的RZ/G2H超高性能微處理器數(shù)據(jù)手冊(cè)

    具有超高處理性能的 Arm?Cortex?-A57(1.5GHz)和 Arm
    的頭像 發(fā)表于 03-12 17:59 ?1355次閱讀
    帶<b class='flag-5'>四</b><b class='flag-5'>核</b>Arm <b class='flag-5'>Cortex-A</b>57和<b class='flag-5'>四</b><b class='flag-5'>核</b>Arm <b class='flag-5'>Cortex-A53</b> <b class='flag-5'>CPU</b>的RZ/G2H超高性能微處理器數(shù)據(jù)手冊(cè)