加入星計劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴散
  • 作品版權(quán)保護
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入
  • 正文
    • 一、地址范圍設定
    • 二、測試地址范圍
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請入駐 產(chǎn)業(yè)圖譜

自制JLink下載算法時如何設置作用地址范圍?

09/16 09:55
610
閱讀需 7 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點資訊討論

大家好,我是痞子衡,是正經(jīng)搞技術(shù)的痞子。今天痞子衡給大家分享的是JLink命令行以及JFlash對于下載算法的作用地址范圍認定。

最近痞子衡在給一個 RT1170 客戶定制一個 Infineon MirrorBit 類型 64MB Flash 的 SEGGER 下載算法,做完之后在 JFlash 下測試小數(shù)據(jù)下載沒有問題,但是大數(shù)據(jù)下載就報了地址范圍不適用的錯誤,所以今天我們就來深挖一下自制下載算法時作用地址設定問題:

    Note: 本文所測試 JLink 版本為 V7.94f

一、地址范圍設定

關(guān)于 SEGGER 下載算法制作,痞子衡之前寫過兩篇文章:《串行NOR Flash下載算法(MDK工具篇) 一文講得是如何制作 FLM 算法文件(MDK 算法與 SEGGER 算法是通用的),《串行NOR Flash下載算法(J-Link工具篇)》 一文講得是配套 XML 文件寫法。

XML 文件里的 BaseAddr 和 MaxSize 參數(shù)設定的地址范圍主要用于選定適用的 FLM 算法文件(即 Loader),而生成 FLM 算法文件源工程里的 FlashDev.c 文件里的 FLASH_BASE_ADDRESS 和 FLASH_BASE_SIZE 參數(shù)則是算法在運行過程中用于判斷的有效下載數(shù)據(jù)地址范圍。

    Note:關(guān)于 XML 添加方法詳見痞子衡舊文 《從JLink V7.62開始優(yōu)化了手動增加新MCU型號支持方法》

二、測試地址范圍

有了以上理論基礎,現(xiàn)在我們測試一下地址范圍設定對下載的影響。我們基于恩智浦 MIMXRT1170-EVKB 評估板,選用一顆 64MB NOR Flash 連在 FlexSPI1 外設上(AHB 映射起始地址為 0x3000_0000,F(xiàn)LM 下載算法里 FLASH_BASE_ADDRESS 固定設為 0x3000_0000)。

2.1 JLink命令行下測試

先在 JLink 命令行下用 LoadFile 命令做測試,該命令支持所有主流格式的程序文件。為了方便設定下載起始地址,我們就用 .bin 格式做測試。

命令格式 LoadFile <FileName>, [<Addr> (.bin only)].
命令解釋 Load data file into target memory. Supported ext.: *.bin, *.mot, *.hex, *.srec, *.elf, *.out, *.axf

如果 XML, FLM, LoadFile 地址范圍都設定無誤,命令執(zhí)行時后臺會彈出下載進度條窗口,表明 FLM 算法被成功調(diào)用且在正常擦寫 Flash。

現(xiàn)在我們嘗試設定不同地址范圍(下表里設定的非 0x3000_0000 - 0x33FF_FFFF 有效 64MB Flash 空間范圍之外的測試地址需要是真正的無效存儲空間地址,不能是 MCU 片內(nèi)的 SRAM 映射地址),做更多測試,結(jié)果如下:

上述測試結(jié)果表明,僅當程序下載地址在 XML 和 FLM 共同指向的范圍內(nèi),且屬于有效的 Flash 空間時,下載才正常進行。此外,表格最后一項測試表明,即使超出實際連接的 Flash 最大空間,下載也沒有報錯,這是因為 MCU 發(fā)送給 Flash 操作命令地址溢出了,地址溢出部分被 Flash 自動忽略了。

    Note:要實現(xiàn)表格最后一項測試效果,在制作 FLM 下載算法時,配置 MCU 存儲接口外設(對于 i.MXRT1170 來說是 FlexSPI)的 AHB 空間必須與 FlashDev.c 里設定一致,且這個空間不超過芯片系統(tǒng)分配給外設的最大 AHB 空間。

2.2 JFlash下測試

再在 JFlash 界面下做測試,打開軟件,創(chuàng)建工程時 Target Device 需要設定為 XML 文件 ChipInfo 中 Name,這樣可指定使用自制 FLM 文件。這里也可以看到界面里 Flash banks 自動就識別到了 XML 所設定的地址范圍。

    Note1:JFlash 認定的起始地址一定是 XML 中 BaseAddr。Note2:當 XML 中 BaseAddr 與 FLM 中 FLASH_BASE_ADDRESS 一致時,JFlash 認定的空間長度由 XML 中 MaxSize 和 FLM 中 FLASH_BASE_SIZE 共同決定,兩者取其小。Note3:當 XML 中 BaseAddr 與 FLM 中 FLASH_BASE_ADDRESS 不一致時,JFlash 認定的空間長度由 XML 中 MaxSize 決定。

JFlash 下測試結(jié)果本質(zhì)上其實和 JLink 命令下行為一致,我們可以理解為 JFlash 底層調(diào)用得就是 JLink 命令實現(xiàn),只不過界面里做了更多檢查與附加功能。且上述 Note 表明 JFlash 在加載算法時對地址空間長度做了預處理,所以當程序下載地址超出 JFlash 認定范圍時,JFlash 會彈框提示:

至此,JLink命令行以及JFlash對于下載算法的作用地址范圍認定痞子衡便介紹完畢了,掌聲在哪里~~~

相關(guān)推薦

電子產(chǎn)業(yè)圖譜

碩士畢業(yè)于蘇州大學電子信息學院,目前就職于恩智浦(NXP)半導體MCU系統(tǒng)部門,擔任嵌入式系統(tǒng)應用工程師。痞子衡會定期分享嵌入式相關(guān)文章