痞子衡嵌入式:JLink命令行以及JFlash對(duì)于下載算法的作用地址范圍認(rèn)定
大家好,我是痞子衡,是正經(jīng)搞技術(shù)的痞子。今天痞子衡給大家分享的是JLink命令行以及JFlash對(duì)于下載算法的作用地址范圍認(rèn)定。
最近痞子衡在給一個(gè) RT1170 客戶定制一個(gè) Infineon MirrorBit 類(lèi)型 64MB Flash 的 SEGGER 下載算法,做完之后在 JFlash 下測(cè)試小數(shù)據(jù)下載沒(méi)有問(wèn)題,但是大數(shù)據(jù)下載就報(bào)了地址范圍不適用的錯(cuò)誤,所以今天我們就來(lái)深挖一下自制下載算法時(shí)作用地址設(shè)定問(wèn)題:
- Note: 本文所測(cè)試 JLink 版本為 V7.94f
一、地址范圍設(shè)定
關(guān)于 SEGGER 下載算法制作,痞子衡之前寫(xiě)過(guò)兩篇文章:《串行NOR Flash下載算法(MDK工具篇) 一文講得是如何制作 FLM 算法文件(MDK 算法與 SEGGER 算法是通用的),《串行NOR Flash下載算法(J-Link工具篇)》 一文講得是配套 XML 文件寫(xiě)法。
XML 文件里的 BaseAddr 和 MaxSize 參數(shù)設(shè)定的地址范圍主要用于選定適用的 FLM 算法文件(即 Loader),而生成 FLM 算法文件源工程里的 FlashDev.c 文件里的 FLASH_BASE_ADDRESS 和 FLASH_BASE_SIZE 參數(shù)則是算法在運(yùn)行過(guò)程中用于判斷的有效下載數(shù)據(jù)地址范圍。
- Note:關(guān)于 XML 添加方法詳見(jiàn)痞子衡舊文 《從JLink V7.62開(kāi)始優(yōu)化了手動(dòng)增加新MCU型號(hào)支持方法》
二、測(cè)試地址范圍
有了以上理論基礎(chǔ),現(xiàn)在我們測(cè)試一下地址范圍設(shè)定對(duì)下載的影響。我們基于恩智浦 MIMXRT1170-EVKB 評(píng)估板,選用一顆 64MB NOR Flash 連在 FlexSPI1 外設(shè)上(AHB 映射起始地址為 0x3000_0000,F(xiàn)LM 下載算法里 FLASH_BASE_ADDRESS 固定設(shè)為 0x3000_0000)。
2.1 JLink命令行下測(cè)試
先在 JLink 命令行下用 LoadFile 命令做測(cè)試,該命令支持所有主流格式的程序文件。為了方便設(shè)定下載起始地址,我們就用 .bin 格式做測(cè)試。
命令格式 LoadFile <FileName>, [<Addr> (.bin only)].
命令解釋 Load data file into target memory. Supported ext.: *.bin, *.mot, *.hex, *.srec, *.elf, *.out, *.axf
如果 XML, FLM, LoadFile 地址范圍都設(shè)定無(wú)誤,命令執(zhí)行時(shí)后臺(tái)會(huì)彈出下載進(jìn)度條窗口,表明 FLM 算法被成功調(diào)用且在正常擦寫(xiě) Flash。
現(xiàn)在我們嘗試設(shè)定不同地址范圍(下表里設(shè)定的非 0x3000_0000 - 0x33FF_FFFF 有效 64MB Flash 空間范圍之外的測(cè)試地址需要是真正的無(wú)效存儲(chǔ)空間地址,不能是 MCU 片內(nèi)的 SRAM 映射地址),做更多測(cè)試,結(jié)果如下:
| XML范圍設(shè)定 | FLM范圍設(shè)定 | LoadFile地址 | 測(cè)試結(jié)果 |
|---|---|---|---|
| 0x3000_0000 - 0x33FF_FFFF | 設(shè)定范圍內(nèi) | 正常下載 | |
| 設(shè)定范圍外 | Writing target memory failed. | ||
| 0x4000_0000 - 0x43FF_FFFF | 0x3000_0000 - 0x33FF_FFFF | XML范圍內(nèi) | Writing target memory failed. |
| FLM范圍內(nèi) | Writing target memory failed. | ||
| 0x3000_0000 - 0x37FF_FFFF | 0x3000_0000 - 0x33FF_FFFF | XML且FLM范圍內(nèi) | 正常下載 |
| XML范圍內(nèi)但FLM范圍外 | Writing target memory failed. | ||
| 0x3000_0000 - 0x33FF_FFFF | 0x3000_0000 - 0x31FF_FFFF | XML且FLM范圍內(nèi) | 正常下載 |
| XML范圍內(nèi)但FLM范圍外 | Writing target memory failed. | ||
| 0x3000_0000 - 0x31FF_FFFF | 0x3000_0000 - 0x33FF_FFFF | XML且FLM范圍內(nèi) | 正常下載 |
| XML范圍外但FLM范圍內(nèi) | Writing target memory failed. | ||
| 0x3000_0000 - 0x37FF_FFFF | 0x3000_0000 - 0x33FF_FFFF內(nèi) | 正常下載 | |
| 0x3400_0000 - 0x37FF_FFFF內(nèi) | 實(shí)際下載到Addr-0x4000000處 | ||
上述測(cè)試結(jié)果表明,僅當(dāng)程序下載地址在 XML 和 FLM 共同指向的范圍內(nèi),且屬于有效的 Flash 空間時(shí),下載才正常進(jìn)行。此外,表格最后一項(xiàng)測(cè)試表明,即使超出實(shí)際連接的 Flash 最大空間,下載也沒(méi)有報(bào)錯(cuò),這是因?yàn)?MCU 發(fā)送給 Flash 操作命令地址溢出了,地址溢出部分被 Flash 自動(dòng)忽略了。
- Note:要實(shí)現(xiàn)表格最后一項(xiàng)測(cè)試效果,在制作 FLM 下載算法時(shí),配置 MCU 存儲(chǔ)接口外設(shè)(對(duì)于 i.MXRT1170 來(lái)說(shuō)是 FlexSPI)的 AHB 空間必須與 FlashDev.c 里設(shè)定一致,且這個(gè)空間不超過(guò)芯片系統(tǒng)分配給外設(shè)的最大 AHB 空間。
2.2 JFlash下測(cè)試
再在 JFlash 界面下做測(cè)試,打開(kāi)軟件,創(chuàng)建工程時(shí) Target Device 需要設(shè)定為 XML 文件 ChipInfo 中 Name,這樣可指定使用自制 FLM 文件。這里也可以看到界面里 Flash banks 自動(dòng)就識(shí)別到了 XML 所設(shè)定的地址范圍。
- Note1:JFlash 認(rèn)定的起始地址一定是 XML 中 BaseAddr。
- Note2:當(dāng) XML 中 BaseAddr 與 FLM 中 FLASH_BASE_ADDRESS 一致時(shí),JFlash 認(rèn)定的空間長(zhǎng)度由 XML 中 MaxSize 和 FLM 中 FLASH_BASE_SIZE 共同決定,兩者取其小。
- Note3:當(dāng) XML 中 BaseAddr 與 FLM 中 FLASH_BASE_ADDRESS 不一致時(shí),JFlash 認(rèn)定的空間長(zhǎng)度由 XML 中 MaxSize 決定。
JFlash 下測(cè)試結(jié)果本質(zhì)上其實(shí)和 JLink 命令下行為一致,我們可以理解為 JFlash 底層調(diào)用得就是 JLink 命令實(shí)現(xiàn),只不過(guò)界面里做了更多檢查與附加功能。且上述 Note 表明 JFlash 在加載算法時(shí)對(duì)地址空間長(zhǎng)度做了預(yù)處理,所以當(dāng)程序下載地址超出 JFlash 認(rèn)定范圍時(shí),JFlash 會(huì)彈框提示:
至此,JLink命令行以及JFlash對(duì)于下載算法的作用地址范圍認(rèn)定痞子衡便介紹完畢了,掌聲在哪里~~~
歡迎訂閱
文章會(huì)同時(shí)發(fā)布到我的 博客園主頁(yè)、CSDN主頁(yè)、知乎主頁(yè)、微信公眾號(hào) 平臺(tái)上。
微信搜索"痞子衡嵌入式"或者掃描下面二維碼,就可以在手機(jī)上第一時(shí)間看了哦。

最后歡迎關(guān)注痞子衡個(gè)人微信公眾號(hào)【痞子衡嵌入式】,一個(gè)專(zhuān)注嵌入式技術(shù)的公眾號(hào),跟著痞子衡一起玩轉(zhuǎn)嵌入式。
衡杰(痞子衡),目前就職于恩智浦(NXP)半導(dǎo)體MCU系統(tǒng)應(yīng)用部門(mén),擔(dān)任高級(jí)嵌入式系統(tǒng)應(yīng)用工程師。
專(zhuān)欄內(nèi)所有文章的轉(zhuǎn)載請(qǐng)注明出處:http://www.rzrgm.cn/henjay724/
與痞子衡進(jìn)一步交流或咨詢業(yè)務(wù)合作請(qǐng)發(fā)郵件至 hengjie1989@foxmail.com
可以關(guān)注痞子衡的Github主頁(yè) https://github.com/JayHeng,有很多好玩的嵌入式項(xiàng)目。
關(guān)于專(zhuān)欄文章有任何疑問(wèn)請(qǐng)直接在博客下面留言,痞子衡會(huì)及時(shí)回復(fù)免費(fèi)(劃重點(diǎn))答疑。
痞子衡郵箱已被私信擠爆,技術(shù)問(wèn)題不推薦私信,堅(jiān)持私信請(qǐng)先掃碼付款(5元起步)再發(fā)。
浙公網(wǎng)安備 33010602011771號(hào)