淺析STM32 Bootloader設計
不需要拆機就能對產(chǎn)品進(jìn)行固件升級是很多人想要的效果,不僅方便而且節省精力和成本。那么如何完成這項工作呢?接下來(lái)所介紹的Bootloader就可以完成這項工作,通過(guò)Bootloader引導程序完成固件的升級。下面來(lái)淺析STM32 Bootloader設計。
本文引用地址:http://dyxdggzs.com/article/174370.htm設計思想
由Bootloader負責檢測SD卡中是否有固件更新所需的BIN文件。如果檢測到所需要的BIN文件,則開(kāi)始復制文件更新固件。更新結束后跳轉到指定的地址開(kāi)始執行最新的程序??梢栽谡搲腁RM版塊找到liklon的帖子:兩份簡(jiǎn)單的 Bootloader 程序。鏈接為:http://forum.eepw.com.cn/thread/238997/1帖子里已經(jīng)共享了兩份簡(jiǎn)單的STM32 Bootloader程序,一份是利用znFAT進(jìn)行SD卡上文件操作,第二份是利用FATFS進(jìn)行文件操作。
知識要點(diǎn)
STM32內部FLASH的起始地址為0X08000000,Bootloader程序文件就從此地址開(kāi)始寫(xiě)入,存放APP程序的首地址設置在緊跟Bootloader之后。當程序開(kāi)始執行時(shí),首先運行的是Bootloader程序,此時(shí)Bootloader檢測SD卡中的BIN文件并將其復制到APP區域使固件得以更新,固件更新結束后還需要跳轉到APP程序開(kāi)始執行新的程序,完成這最后這一步要了解Cortex-M3的中斷向量表:

程序啟動(dòng)后,將首先從“中斷向量表”取出復位中斷向量執行復位中斷程序完成啟動(dòng),當復位中斷程序運行完成后才跳轉到main函數。由此可見(jiàn),在最后一步的設計中需要根據存放APP程序的起始地址以及中斷向量表來(lái)設置棧頂地址,并獲取復位中斷地址跳轉到復位中斷程序。接下來(lái)開(kāi)始分析程序設計步驟。
Bootloader程序設計
1.確定存放APP程序的首地址
#define FLASH_APP_ADDR 0x08010000 //應用程序起始地址(存放在FLASH)上一句代碼中是0X08010000可以看出,留給Bootloader程序的存儲空間大小為64K。存放APP程序的起始地址為0X08010000。
2.Bootloader檢測是否有BIN文件
gCheckFat = f_open(&FP_Struct,"/APP/LIKLON.BIN",FA_READ);//判讀gCheckFat確定上面的代碼是檢測是否存在liklon.bin這個(gè)文件存在,其中liklon.bin文件就是固件升級所需要的BIN文件。
3.復制文件到指定地址
上一步中如果gCheckFat為0則表示存在所需BIN文件,則可以執行這一步。f_read (&FP_Struct,ReadAppBuffer,512,(UINT *)&ReadNum); //讀取512個(gè)字節將512個(gè)字節轉換為256個(gè)16位的數據存放在ChangeBuffer數組中,準備寫(xiě)入FLASH。FlashWrite(FLASH_APP_ADDR + i * 512,ChangeBuffer,256); //向指定地址寫(xiě)入讀出數據向APP程序區寫(xiě)入512個(gè)字節的數據。按照這樣讀取寫(xiě)入,就可以完成對APP程序區的更新。
評論