<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

STM32單片機實現固件在線升級(IAP)

撞上電子 ? 2023-12-16 08:00 ? 次閱讀


1,固件升級方案綜述

單片機的固件升級方式有很多種。1、ICP:簡單說就是在單片機開發時使用燒錄器升級程序,比如使用J-Link燒錄單片機程序。2、ISP:在單片機內部實現了基于通信接口(如串口、I2C、SPI等等)的FLASH引導程序,配合廠家提供的燒錄軟件工具或自行開發的軟件實現程序燒錄。3、IAP:是指單片機程序開發好之后在運行過程中由外部用戶發起的在線升級,這種升級方式一般由用戶自行設計升級方案,方案靈活性和自由度較高,在智能家居、汽車電子、物聯網設備中常用的OTA即空中下載技術原理也與之類似。

2,劃分FALSH存儲區域

STM32系列單片機中,程序存儲在內部FLASH中,按照不同的單片機型號FLASH大小有所不同,有64KB、128KB、512KB等等。以STM32F407VET6系列單片機為例,內置FLASH大小為512KB,存儲地址為0x08000000-0x0807FFFF。單片機每次程序復位時從0x08000000的位置開始執行主程序,如果不做IAP則這512KB空間都可以用來存儲用戶編寫的APP程序。

若要實現IAP功能則必須將FLASH空間劃分為幾個部分,每部分都存儲一個可以獨立運行的程序文件(可以理解為幾個獨立的單片機工程):

1、引導程序,每次復位時程序默認執行此程序,在接下來的執行過程中可以跳轉到用戶編寫的程序,因此這部分程序是固化在以0x08000000為起始的區域中。在引導程序中可以對電路系統作出一些自檢和初始化檢查的工作,因此該程序又稱為bootloader或boot程序,需要注意的是在設計bootloader時要提前規定好程序空間的大小,比如規定程序存儲區域為0x08000000-0x8007FFF,則bootlader程序存儲空間為32KB,編寫boot程序時要注意這一點

2、用戶需要升級的新程序,這部分包含了用戶的業務代碼,復雜的運算邏輯和算法實現均在這一部分完成,稱為APP程序,該部分程序一般存儲在bootloader區域之后的FLASH中。用一個不是特別恰當的例子類比bootloader和APP:bootloader相當于電腦組裝時的BIOS,APP則相當于操作系統,電腦開機時首先運行BIOS,完成后跳轉運行到操作系統。

3、升級之前的老版APP備份。這部分相當于電腦系統更新前對老系統的備份,一旦在升級過程中發生錯誤需要還原到備份系統,防止系統升級失敗成磚。同樣的APP與APP備份將剩余的FLASH平分,以上述booloader為例,APP程序及其備份所占區域為:(512-32)/2=240KB,因此編寫的APP程序編譯后的占用的FLASH空間不得超過240KB,這一點可以通過查驗.map文件確認,對于不同FLASH大小的芯片可以類比以上計算方法確認自己的程序大小上限(在此插入一句,改變編譯器的優化等級可以改變最后的程序大小,但是高的優化等級對程序編寫規范要求更高,因此優化等級應該在一開始設計APP之前就確定好,中途變更會帶來不可預測的問題)。

以STM32F407VET6單片機為例劃分后的FALSH存儲框圖如下所示:

2fd4bc9e-9ba6-11ee-9788-92fbcf53809c.jpg

3,BOOTLADER設計

根據上面的描述,bootloader主要有完成以下功能:

1、系統自檢

2、實現APP程序跳轉

3、升級過程中接收APP文件并存儲到對應的FLASH區域

功能1、3對于不同的系統要求不同,自檢的內容以及實現文件傳輸的物理層接口和鏈路協議不同,不在此過多描述。下面主要給出APP跳轉的部分代碼:

#define APP_ADDR 0x08008000 //應用程序起始地址 typedef void (*pFunction)(void); //重定義pFunction為void(*)(void)函數指針類型void jump(void){ uint32_t APP_ADDR_Buff=0; //緩存APP地址數值 uint32_t APP_ADDR_Value=0; //APP地址的內容 uint32_t Jump_ADDR; //跳轉的目標地址 pFunction Jump_APP; //跳轉的目標函數指針 APP_ADDR_Buff = APPLICATION_ADDRESS; //用戶程序的首地址 APP_ADDR_Value = (*(volatile uint32_t*)APP_ADDR_Buff);//取出首地址里面的值 if (( APP_ADDR_Value & 0x2FFE0000 ) == 0x20000000) //判斷APP首地址里面存的棧頂地址值是否合法 { DISABLE_INTERRUPTS(); //關總中斷,使用不同的庫寫法不同,不可直接復制 RCC_DeInit();//將外設RCC寄存器重設為缺省值,使用不同的庫寫法不同,不可直接復制 Jump_ADDR = *(volatile uint32_t*)(APP_ADDR_Buff + 4);//APP起始地址第二個字為程序開始地址(新程序復位地址) //指針函數指向用戶程序地址,也就是PC指針goto到用戶程序起始地址 Jump_APP = (pFunction)Jump_ADDR; //取出程序地址給指針函數 __set_MSP(*(volatile uint32_t*)APP_ADDR_Buff); //初始化APP的堆棧指針 Jump_APP(); //執行指針函數,實現程序跳轉 } else { ErrorHandle(); //拋出異常 }}int main(void){
SystemInit();//系統時鐘初始化 SYSInit(); //系統初始化 delay_ms(200); if(ReadProgramAPPFlag()) //如果需要更新APP { APP_FlashWrite(); //接收APP文件數據,并將APP程序存儲到指定位置 if(APP_Check()) //APP文件校驗通過,將新的APP程序更新到備份區域 APP_Backup(); else //否則恢復備份區 APP_Restore(); ResetProgramAPPFlag(); //對完成升級的標志復位 } jump(); //正常情況下運行到這一步時APP區域已經正確寫入程序文件 while(1); }

其中ReadProgramDoneFlag()是判斷程序應該是先接收升級文件再跳轉還是直接跳轉的標志,在APP中如果有升級需求則對這個標志置位,在bootloader中完成文件接收之后對標志復位,需要注意的是這個標志位不是全局變量也不是局部變量,要保證程序跳轉,初始化堆棧之后這個標志的值不受影響,因此該標志變量最佳選擇是寫在外部EEPROM或內置FLASH中,讀寫標志的操作其實是對EEPROM或FLASH的讀寫。

4,編寫APP程序

APP程序中實現了用戶的業務代碼,和由APP跳轉回bootloader的邏輯,實際的操作還是對上文中程序存儲Flag的讀寫,這部分邏輯實現的流程圖如下圖所示:

2fe11638-9ba6-11ee-9788-92fbcf53809c.jpg

由于APP程序對應的是另外一個工程文件,因此在工程設置中要將FLASH的偏移地址向下移動,空出bootlader的區域,比如上文中bootloader區域是0x08000000-0x08008000,因此APP工程的FLASH起始地址是0x8008000,偏移量是0x8000,這一點非常重要。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 單片機
    +關注

    關注

    6007

    文章

    44035

    瀏覽量

    622202
  • STM32
    +關注

    關注

    2243

    文章

    10683

    瀏覽量

    349323
  • IAP
    IAP
    +關注

    關注

    2

    文章

    162

    瀏覽量

    24000
收藏 人收藏

    評論

    相關推薦

    關于程序在線升級

    想請教各位高手:1、是不是只有支持IAP功能的單片機才可以實現程序的在線升級???2、STM32
    發表于 05-12 14:37

    STM32 IAP在線升級

    STM32很強大的一個功能是支持IAP在線升級,IAP(In-Application Programming),即在“應用程序中編程 ",通
    發表于 03-09 15:56

    E85F3325單片機IAP在線升級教程

    51單片機IAP在線升級愛矽半導體E85F3325單片機IAP
    發表于 07-15 07:44

    如何用IAP功能實現單片機遠程升級

    工程師在做產品的時候有時候會有遠程對產品進行升級的需求。對于沒有開發過此功能的工程師會不知道從何下手,本文就以HC32L110為例介紹國產超低功耗華大單片機如何用IAP功能實現
    發表于 11-01 08:14

    如何去實現stm32IAP在線升級

    如何去實現stm32IAP在線升級呢?需要注意哪些事情呢?
    發表于 11-29 07:35

    如何實現STM32在線升級IAP功能?

    如何實現STM32在線升級IAP功能?
    發表于 11-30 06:22

    8051系列單片機固件升級iap聲明

    8051系列單片機固件升級iap聲明:#define UPGRADE_FLAG 0xaa //升級標志位#define APP_START_
    發表于 12-01 07:01

    STC51單片機實現IAP遠程升級過程分享

    參考STC15單片機功能和應用電路STC8A單片機功能和應用電路STC51單片機實現IAP遠程升級
    發表于 01-27 06:08

    如何去實現STM32在線升級IAP功能呢

    最近因項目需求要實現STM32在線升級IAP功能,先將這幾天的學習體會和IAP的具體
    發表于 02-21 06:26

    GD32單片機STM32遠程下載手機程序升級固件下載局域網網頁升級工具

    。 使用STM32固件服務器方式,很容易解決了,STM32系列單片機在線升級問題。該方式支持手
    發表于 11-10 15:03

    stm32單片機自我升級程序IAP

    stm32 單片機自我升級程序IAP,詳細的介紹,分析
    發表于 06-17 15:42 ?22次下載

    ARM在線升級的應用IAP代碼

    電子專業單片機相關知識學習教材資料——ARM在線升級的應用IAP代碼
    發表于 09-13 17:23 ?0次下載

    如何使用CPUID和AES算法實現STM32單片機固件升級

    針對STM32系統固件升級時使用同一個文件易被非法復制使用的缺陷,提出并實現了一種一個STM32芯片使用一個唯一
    發表于 11-19 15:14 ?35次下載
    如何使用CPUID和AES算法<b class='flag-5'>實現</b><b class='flag-5'>STM32</b><b class='flag-5'>單片機</b>的<b class='flag-5'>固件</b><b class='flag-5'>升級</b>

    STM32通過IAP實現固件升級的分析與示例

    大部分MCU都可以通過IAP對片內flash進行讀寫來實現固件升級。這里主要是STM32如何實現
    發表于 12-14 18:50 ?11次下載
    <b class='flag-5'>STM32</b>通過<b class='flag-5'>IAP</b><b class='flag-5'>實現</b><b class='flag-5'>固件</b><b class='flag-5'>升級</b>的分析與示例

    AT32 MCU如何使用IAP通過USART實現固件在線升級更新

    AT32 MCU如何使用IAP通過USART實現固件在線升級更新
    的頭像 發表于 09-19 16:51 ?1215次閱讀
    AT32 MCU如何使用<b class='flag-5'>IAP</b>通過USART<b class='flag-5'>實現</b>對<b class='flag-5'>固件</b>的<b class='flag-5'>在線</b><b class='flag-5'>升級</b>更新
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>