一. 背 景
嵌入式設備升級過程中會由于斷電、強行中斷等外部因素,導致新固件寫入Flash時不能完整寫入,使系統啟動時出現問題。或設備運行中,鏡像文件被意外損壞,導致系統癱瘓,設備無法運行。面對以上問題,可以使用雙鏡像機制(dual image),它保證至少有一個鏡像文件是可以啟動,并且在任何時候都能正常工作。如果發生意外,引導加載程序檢測并使用備用的鏡像文件。
二. 原 理
LPC5536 ROM支持內部Flash的雙鏡像引導(也支持FlexSPI外部Flash,原理相同),即在Flash可以放置兩個引導鏡像,ROM根據鏡像文件版本號決定啟動哪個鏡像,首先啟動最新版本號的鏡像,如果失敗,則啟動舊鏡像文件。
通電啟動時,ROM首先檢測CMPA中關于重定位鏡像文件的位置和大小,然后檢測兩個鏡像的版本號,所以在使用雙鏡像機制時,主要對鏡像文件重定位和版本號進行配置。
ROM從內部Flash啟動雙鏡像文件流程圖如下:
2.1 鏡像文件重定位
LPC5536內部Flash支持重映射,當設置重映射偏移量后,Flash AHB 總線將訪問偏移后的地址。例如,當偏移量設置為128K(0x20000),對0x0的訪問將被重新映射到地址0x20000。通過這個特性,ROM可以實現雙鏡像引導。下面是一個關于內部Flash存放兩個鏡像文件的簡圖。
第二個鏡像的偏移量和重映射大小由用戶在CMPA區域設置,讓ROM知道第二個鏡像的位置。
2.2 配置鏡像的版本
在頭文件偏移量為0x24處設置鏡像版本號,如下表格所示,第16位-31位設置鏡像文件版本號,第10位表示鏡像文件是否存在版本號,使用雙鏡像機制時,此位設置為1.
三. 應 用
3.1 配置CMPA
配置CMPA中數據值
修改cmpa.bin文件,通過blhost把修改后的bin文件寫入CMPA,以配置image1偏移量和重映射大小,流程如下:
a. 打開一個全0的cmpa.bin,修改0x3E23C處數據為0x20000,高位在右低位在左,如下:
b. 修改重映射大小。地址0x3E238處修改為0x1d800,如下:
c. 保存并重命名為cmpa_new.bin,另存為lhost_2.6.7lhost_2.6.7inwin
3.2 燒寫cmpa_new.bin
借助blhsot 工具燒寫,blhost 2.6.7是一個命令行調試工具,界面如下:
測試blhost與開發板通信是否正常:
其次,開發板J43上使用跳線帽連接3和4,使能ISP啟動;
然后,按下復位鍵,輸入連接測試命令blhost -pcom12 -- get-property 1
判斷是否正常通信,如連接成功會提示信息:
寫入修改好的bin文件數據到CMPA
通過使用blhost -pcom12 -- write-memory 0x3e200 cmpa_new.bin命令,寫入CMPA:
為確保正確寫入,查看設置之后CMPA數據
通過命令blhost -pcom12 -- read-memory 0x3e200 512查看設置后的CMPA數據:
3.2 雙鏡像版本設置
根據實驗效果,Image0的功能是LPC5536-evk開發板上紅燈閃爍,Image1功能是綠燈閃爍。
Image0 設置版本號為1,Image1 設置版本號為2:
打開紅燈閃爍的工程,修改頭文件偏移量0x24處為0x10400
打開綠燈閃爍的工程,修改頭文件偏移量0x24處為0x20400
3.3 分配Flash
LPC5536JBD100用戶可用的內部Flash共246K,所以Image0 分配到0x0-0x1FFFF地址范圍內,Image1分配到0x20000-0x3D7FF地址范圍內。如果使用MCUXpresso ID,設置如下:
工程->右鍵屬性->MCU settings,設置起始地址和大小,完成后點擊應用按鈕。
紅燈閃爍工程:
綠燈閃爍工程:
重現編譯工程。
3.4 功能測試
測試程序為兩個點燈程序,分別為紅燈閃爍和綠燈閃爍程序,紅燈閃爍為image0,版本號1,綠燈閃爍為image0,版本號2,所以測試結果如果綠燈閃爍,則成功。
下載程序
使用IDE中GUI Flash Tool,分別下載兩個鏡像文件到開發板中:
在“File to program”中選擇燒寫的文件,點擊run按鈕后,程序會下載到Flash:
下載完成后,點擊確定:
同樣的方式下載另外一個程序,注意在燒寫第二個程序時,不能勾選“masserase”,如果使用其它工具燒寫,也應關閉和”masserase”相同功能的選項,避免擦除第一個鏡像文件。
測試結果
下載程序后,復位,綠燈閃爍。
升級測試:將紅燈閃爍工程版本號修改為3,即修改0x10400為0x30400,重新燒寫鏡像文件,應該會看到紅燈閃爍。
四. 總結
雙鏡像機制為嵌入式設備的升級和啟動增加保險,應用過程中需要注意在CMPA區域設置鏡像偏移量、重映射大小和配置鏡像版本的方式,同時也需要注意兩個工程中Flash配置。
-
mcu
+關注
關注
146文章
17307瀏覽量
352187 -
嵌入式
+關注
關注
5089文章
19170瀏覽量
306805 -
FlaSh
+關注
關注
10文章
1641瀏覽量
148414 -
ROM
+關注
關注
4文章
575瀏覽量
85895 -
嵌入式設備
+關注
關注
0文章
110瀏覽量
16992
原文標題:MCU雙鏡像機制如何使能?
文章出處:【微信號:pzh_mcu,微信公眾號:痞子衡嵌入式】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論