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

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

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

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

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

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

掃碼添加小助手

加入工程師交流群

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

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

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)建端點。

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

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

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

(5) 當計數(shù)器數(shù)值大于100時,通信結(jié)束。


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調(diào)試串口打印如下信息。

圖 3

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

U-Boot=>boot

poYBAGJrppuANnohAAAswDU0hsM939.png

圖 4

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

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ū)動程序

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

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

圖 8

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

圖 9

FreeRTOS程序

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

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

圖 10

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

圖 11

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

圖 12

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

pYYBAGJrpp2AT7hvAACiNc7KToQ962.png

圖 13

2 rpmsg_lite_str_echo_rtos案例

2.1 案例功能

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

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

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

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

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

2.2 案例測試

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

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

圖 14

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

U-Boot=>boot

pYYBAGJrpp2AfBfSAAAsYaJARDU809.png

圖 15

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

Target#modprobe imx_rpmsg_tty

圖 16

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

圖 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ù)進行打印,同時將數(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ū)動程序

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

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

圖 21

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

圖 22

FreeRTOS程序

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

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

圖 23

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

圖 24

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

圖 25

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

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

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

    關(guān)注

    1660

    文章

    22424

    瀏覽量

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

    關(guān)注

    135

    文章

    9561

    瀏覽量

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

    關(guān)注

    5200

    文章

    20476

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    請問qemu 可以模擬 i.MX 8M Plus 嗎?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    創(chuàng)龍科技SOM-TL3506是一款基于瑞芯微RK3506J/RK3506B處理器設(shè)計的3ARM Cortex-A7 + ARM Cortex-M0全國產(chǎn)工業(yè)核心板,主頻高達1.5GHz。核心板
    的頭像 發(fā)表于 04-09 09:04 ?3613次閱讀
    瑞芯微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)核的工作時鐘頻率降低到 0 ?
    發(fā)表于 04-09 07:28

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

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

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

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

    在 NXP i.MX 8M Plus EVK上比較Yocto 4.0和Yocto 5.0時,空閑模式下的功耗增加了 20%,為什么?

    尊敬的先生: 在 NXP i.MX 8M Plus EVK 上比較 Yocto 4.0(內(nèi)核 5.15.71-2.2.2)和 Yocto 5.0(內(nèi)核 6.6.52-2.2.0)時,我們觀察到空閑
    發(fā)表于 03-26 07:15

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

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