大家好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給大家介紹的是MCUXpresso IDE開發環境下i.MXRT的串行NOR Flash下載算法設計。
在i.MXRT硬件那些事系列之《在串行NOR Flash XIP調試原理》一文中,痞子衡簡單提了一下串行NOR Flash下載算法的概念,並沒有介紹具體設計細節,關於NOR Flash下載算法每個IDE都有自己的一套設計,雖然基本設計理念是一樣的,但是細節方面還是有區別。在前面的文章里,痞子衡分別介紹過《J-Link下算法設計》、《Keil MDK下算法設計》、《IAR EWARM下算法設計》,今天痞子衡就來細聊MCUXpresso IDE下的NOR Flash下載算法:
一、MCUXpresso IDE各版本對i.MXRT的支持
MCUXpresso IDE是飛思卡爾和恩智浦合並之后推出的全新IDE,這個IDE是免費的,可用於新恩智浦全系列ARM Cortex-M控制器(Kinetis、LPC、JN、QN、i.MXRT等)。熟悉這兩家公司的人應該知道,其實MCUXpresso IDE就是原恩智浦LPCXpresso IDE與原飛思卡爾Kinetis Design Studio IDE的合體。
從恩智浦官網上看,目前最新的MCUXpresso IDE版本是v11.2.1,其能夠支持目前所有已量產的i.MXRT系列。從 MCUXpresso IDE歷史各版本Release Note 上看,我們可以看到其各版本對i.MXRT支持情況如下:
各版本下載地址:https://nxp.flexnetoperations.com/control/frse/product?child_plneID=756637&ver=ARC
MCUXpresso IDE對新MCU型號的支持雖然並不是與自身版本嚴格綁定,但通過類似打patch的方式比較復雜,且官方不支持這么做,反正這個IDE是免費的,升級又不要錢,也不需要申請license,最好還是通過安裝最新版本的方式來實現新型號的支持。
二、為當前MCUXpresso IDE增加新下載算法支持
痞子衡安裝的是最新的v11.2.1,我們以為RT600這顆芯片新增flash下載算法為例介紹MCUXpresso IDE下的使用。在開始之前要特別強調一下MCUXpresso IDE與MDK/IAR非常不同的地方,MDK/IAR自帶的flash下載算法是跟具體硬件仿真器無關的,它可以在所有支持的仿真器(JLink/DAPLink等)下正常使用,但是MCUXpresso IDE自帶的flash下載算法只能在CMSIS-DAP類型的仿真器下使用。如果你在MCUXPresso IDE下使用JLink,那么下載算法只能用JLink的算法。
現在我們隨便打開一個i.MXRT600 SDK工程,右擊工程進入Properties設置界面,在MCU Settings下可以看到LinkServer Flash Driver的設置界面,這里就是選擇flash下載算法。MCUXpresso IDE默認自帶了非常多的flash下載算法(文件后綴名是.cfx,其實就是可執行文件elf),即使是同一顆芯片RT600,可以看到其有很多個.cfg可選,這分別對應了不同的flash種類以及與主芯片連接端口。
如果默認選擇的Flash下載算法文件不適用你的板子,那么你需要自己提供合適的算法文件(.cfx),並將其放入MCUXpresso IDE安裝目錄下(\MCUXpressoIDE_11.2.1_4149\ide\binaries\Flash),重新打開工程選項,新增的算法會自動刷新到待選算法列表:
三、NOR Flash下載算法設計
MCUXpresso IDE下Flash下載算法是公開的,\MCUXpressoIDE_11.2.1_4149\MCUXpresso_IDE_User_Guide.pdf 文檔的 LinkServer Flash Support 章節有一些使用方面的介紹,可以看一下。
3.1 下載算法模板工程
雖然下載算法本身是公開的,但設計文檔很少,只給了示例工程。但對於工程師來說,還有什么比給代碼來得更直接呢。
- 示例算法工程路徑:\MCUXpressoIDE_11.2.1_4149\ide\Examples\Flashdrivers\NXP\iMXRT
我們就以iMXRT1050_QSPI.zip示例包里代碼來分析其結構設計。這個示例包包含兩個工程(LPCXFlashDriverLib和iMXRT1050_QSPI),需要先編譯LPCXFlashDriverLib工程生成libLPCXFlashDriverLib.a,這個庫是iMXRT1050_QSPI工程的源文件,然后編譯iMXRT1050_QSPI工程生成我們需要的算法文件MIMXRT1050-EVK_IS25WP064A.cfx。
MCUXpresso IDE下載算法這種兩級編譯的設計,與IAR/MDK下載算法結構完全不同,這么設計的主要原因是恩智浦ARM Cortex-M內核MCU產品線眾多,而MCUXpresso IDE需要支持所有MCU,因此將公共設計的部分提取到了LPCXFlashDriverLib工程里(為了通用性,工程采用CM0指令集來編譯)。此外,從工程名你就能看出,還保留着上一代LPCXpresso IDE的基因。
LPCXFlashDriverLib工程有很多build,可以根據ServiceMessages.c文件里的條件編譯宏了解到它們的差異,其中Release_SectorHashing工程是默認選擇用於最終生成.cfx的,這個build主要是利用32 bit Fowler/Noll/Vo FNV-1a哈希算法對每個Sector的數據下載做了校驗。
再到iMXRT1050_QSPI工程,這個工程就是采用具體MCU的內核指令集(CM7)來編譯,在工程設置里可以看到鏈接了LPCXFlashDriverLib工程的Release_SectorHashing生成的.a文件,如果LPCXFlashDriverLib工程選擇了其他build,這里也要相應改一下。
3.2 下載算法結構設計
算法本身設計算是幾個常用IDE里最復雜的一個了。iMXRT1050_QSPI工程除了一般的FlexSPI驅動外,有兩個源文件FlashDev.c和FlashPrg.c,對這文件名有沒有很熟悉?是的,這就是標准的CMSIS開源flash算法API定義,里面的內容也是類似的,這里就不贅述了,需要特別強調的是這些Flash擦寫API並不是MCUXpresso IDE在下載時實際調用入口。
算法最核心的設計在LPCXFlashDriverLib工程,先看lpcx_flash_memdev.c里內容,這個文件里定義了一個重要的常量結構體MemoryDevice,這個MemoryDevice會被鏈接在算法執行區域(前64KB的DTCM)的起始位置(0x20000000),給MCUXpresso IDE調試器提供算法全部的信息。
// MemoryDevice Instance (fill it in)
EXTERN_MEMORY_DEVICE
MemoryDeviceMsg_t MemoryDevice =
{
MEM_FLASH_VER2_MAJ+0x0, // Version of flash interface
// Magic number to identify flash driver
// interface
{ 0x01, 0x23, 0x45, 0x00, 0x00, 0x54, 0x32, 0x10 },
(uint32_t)&__load_base, // Driver load address
(uint32_t)&__image_size, // Size of .text and .data
(uint32_t)&__cache, // RAM buffer location
(uint32_t)&__cache_size, // RAM buffer size
(uint32_t)&__initial_sp, // Stack top
(uint32_t)&__stack_size, // Stack size
(uint32_t)&__opmap_val, // Bitmap of available operations - 0 = everything there
&FlashDevice, // Flash Device configuration
ServiceMessages, // Service mailbox flash operation message
0 // Reserved
};
MemoryDevice有一個成員是ServiceMessages()函數,這個函數可以說是算法最靈魂的部分了,它才是MCUXpresso IDE調試器調用Flash擦寫API的真正入口,調試器通過傳入msg參數(所謂Mailbox結構)讓算法來執行具體Flash操作並得到執行結果。這種特殊的設計可能也是MCXPpresso IDE算法僅能在CMSIS-DAP類型仿真器下使用的原因吧。
至此,MCUXpresso IDE開發環境下i.MXRT的串行NOR Flash下載算法設計痞子衡便介紹完畢了,掌聲在哪里~~~
歡迎訂閱
文章會同時發布到我的 博客園主頁、CSDN主頁、知乎主頁、微信公眾號 平台上。
微信搜索"痞子衡嵌入式"或者掃描下面二維碼,就可以在手機上第一時間看了哦。