RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

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

3天內(nèi)不再提示

關于在線升級IAP的基礎知識

GReq_mcu168 ? 來源:CSDN技術社區(qū) ? 作者:IoT小胡 ? 2022-05-31 17:24 ? 次閱讀

簡介

本文主要講解在線升級IAP的基礎知識, 主要是針對IAP從原理分析,分區(qū)劃分, 到代碼編寫和實驗驗證等過程闡述這一過程. 幫助大家加深對在線升級的認識.

1. 在線升級知識

什么是BootLoader?

BootLoader可以理解成是引導程序, 它的作用是啟動正式的App應用程序. 換言之,BootLoader是一個程序, App也是一個程序, BootLoader程序是用于啟動App程序的.

STM32中的程序在哪兒?

正常情況下, 我們寫的程序都是放在STM32片內(nèi)Flash中(暫不考慮外擴Flash). 我們寫的代碼最終會變成二進制文件, 放進Flash中 感興趣的話可以在Keil>>>Debug>>>Memory中查看, 右邊Memory窗口存儲的就是代碼

e679dd4a-da5e-11ec-ba43-dac502259ad0.png

接下來就可以進入正題了.

進行分區(qū)

既然我們寫的程序都會變成二進制文件存放到Flash中, 那么我們就可以進一步對我們程序進行分區(qū). 我使用的是F103RB-NUCLEO開發(fā)板,他的Flash一共128頁, 每頁1K.見下圖:

e6a8a6ac-da5e-11ec-ba43-dac502259ad0.png

以它為例, 我將它分為三個區(qū).BootLoader區(qū)App1區(qū)、App2區(qū)(備份區(qū))具體劃分如下圖:

  • BootLoader區(qū)存放啟動代碼

  • App1區(qū)存放應用代碼

  • App2區(qū)存放暫存的升級代碼

e6e71e46-da5e-11ec-ba43-dac502259ad0.png

總體流程圖

  • 先執(zhí)行BootLoader程序, 先去檢查APP2區(qū)有沒有程序, 如果有就將App2區(qū)(備份區(qū))的程序拷貝到App1區(qū), 然后再跳轉(zhuǎn)去執(zhí)行App1的程序.

  • 然后執(zhí)行App1程序, 因為BootLoaderApp1這兩個程序的向量表不一樣, 所以跳轉(zhuǎn)到App1之后第一步是先去更改程序的向量表. 然后再去執(zhí)行其他的應用程序.

  • 在應用程序里面會加入程序升級的部分, 這部分主要工作是拿到升級程序, 然后將他們放到App2區(qū)(備份區(qū)), 以便下次啟動的時候通過BootLoader更新App1的程序. 流程圖如下圖所示:

e711da8c-da5e-11ec-ba43-dac502259ad0.png

2. BootLoader的編寫

本節(jié)主要講解在線升級(OTA)的BooLoader的編寫,我將以我例程的BootLoader為例, 講解BootLoader(文末會提供免費的代碼下載鏈接),其他的大體上原理都差不多。

流程圖分析

以我例程的BootLoader為例:

我將App2區(qū)的最后一個字節(jié)(0x0801FFFC)用來表示App2區(qū)是否有升級程序, STM32在擦除之后Flash的數(shù)據(jù)存放的都是0xFFFFFFFF, 如果有, 我們將這個地址存放0xAAAAAAAA. 具體的流程圖見下圖所示

e739b20a-da5e-11ec-ba43-dac502259ad0.png

程序編寫和分析

所需STM32的資源有:

  • 發(fā)送USART數(shù)據(jù)和printf重定向

  • Flash的讀寫

  • 程序跳轉(zhuǎn)指令,可以參考如下代碼:


		

1/*采用匯編設置棧的值*/ 2__asmvoidMSR_MSP(uint32_tulAddr) 3{ 4MSRMSP,r0//設置MainStack的值 5BXr14 6} 7 8 9/*程序跳轉(zhuǎn)函數(shù)*/ 10typedefvoid(*Jump_Fun)(void); 11voidIAP_ExecuteApp(uint32_tApp_Addr) 12{ 13Jump_FunJumpToApp; 14 15if(((*(__IOuint32_t*)App_Addr)&0x2FFE0000)==0x20000000)//檢查棧頂?shù)刂肥欠窈戏? 16{ 17JumpToApp=(Jump_Fun)*(__IOuint32_t*)(App_Addr+4);//用戶代碼區(qū)第二個字為程序開始地址(復位地址) 18MSR_MSP(*(__IOuint32_t*)App_Addr);//初始化APP堆棧指針(用戶代碼區(qū)的第一個字用于存放棧頂?shù)刂? 19JumpToApp();//跳轉(zhuǎn)到APP. 20} 21}

  • 在需要跳轉(zhuǎn)的地方執(zhí)行這個函數(shù)就可以了IAP_ExecuteApp(Application_1_Addr);

  • 其他的代碼請參考BootLoader源代碼

3. APP的編寫

本節(jié)主要講解在線升級(OTA)的App1的編寫以及整個流程的說明,我將以我例程的App為例, 采用Ymodem協(xié)議進行串口傳輸,講解App的編寫(后面會提供免費的代碼下載鏈接), 其他的協(xié)議原理大體上都差不多, 都是通過某種協(xié)議拿到升級的代碼。

流程圖分析

以我例程的App1為例:

  • 先修改向量表, 因為本程序是由BootLoader跳轉(zhuǎn)過來的, 不修改向量表后面會出現(xiàn)問題;

  • 打印版本信息, 方便查看不同的App版本;

  • 本例程的升級程序采用串口的Ymoderm協(xié)議進行傳輸bin文件. 具體的流程圖見下圖所示:

e763f696-da5e-11ec-ba43-dac502259ad0.png

程序編寫和分析

所需STM32的資源有:

  • 發(fā)送USART數(shù)據(jù)和printf重定向

  • Flash的讀寫

  • 串口的DMA收發(fā)

  • YModem協(xié)議相關

Ymodem協(xié)議

  • 百度百科[Ymodem協(xié)議]

  • 具體流程可自行查找相關文檔, 這兒提供一個我找到的 XYmodem.pdf(文末和源碼一起提供).

  • Ymodem協(xié)議相關介紹可參考我的這篇教程 YModem介紹

(https://blog.csdn.net/weixin_41294615/article/details/104652105).

代碼分析

  • 代碼大多數(shù)都是通過串口實現(xiàn)Ymodem協(xié)議的接收, 這兒就不詳細說明
  • 后面放了我的源代碼, 詳情請參考我的源代碼.
  • 主函數(shù)添加修改向量表的指令

e7ce9c80-da5e-11ec-ba43-dac502259ad0.png

  • 打印版本信息以及跳轉(zhuǎn)指令

e81ded62-da5e-11ec-ba43-dac502259ad0.png

  • YModem相關的文件接收部分

		1/**  2*@bieafYModem升級  3*  4*@paramnone  5*@returnnone  6*/  7voidymodem_fun(void)  8{  9inti; 10if(Get_state()==TO_START) 11{ 12send_command(CCC); 13HAL_Delay(1000); 14} 15if(Rx_Flag)//Receiveflag 16{ 17Rx_Flag=0;//cleanflag 18 19/*拷貝*/ 20temp_len=Rx_Len; 21for(i=0;i22{ 23temp_buf[i]=Rx_Buf[i]; 24} 25 26switch(temp_buf[0]) 27{ 28caseSOH:///<數(shù)據(jù)包開始 29{ 30staticunsignedchardata_state=0; 31staticunsignedintapp2_size=0; 32if(Check_CRC(temp_buf,temp_len)==1)/// 33{ 34if((Get_state()==TO_START)&&(temp_buf[1]==0x00)&&(temp_buf[2]==(unsignedchar)(~temp_buf[1])))/// 35{ 36printf(">Receivestart... "); 37 38Set_state(TO_RECEIVE_DATA); 39data_state=0x01; 40send_command(ACK); 41send_command(CCC); 42 43/*擦除App2*/ 44Erase_page(Application_2_Addr,40); 45} 46elseif((Get_state()==TO_RECEIVE_END)&&(temp_buf[1]==0x00)&&(temp_buf[2]==(unsignedchar)(~temp_buf[1])))/// 47{ 48printf(">Receiveend... "); 49 50Set_Update_Down(); 51Set_state(TO_START); 52send_command(ACK); 53HAL_NVIC_SystemReset(); 54} 55elseif((Get_state()==TO_RECEIVE_DATA)&&(temp_buf[1]==data_state)&&(temp_buf[2]==(unsignedchar)(~temp_buf[1])))/// 56{ 57printf(">Receivedatabag:%dbyte ",data_state*128); 58 59/*燒錄程序*/ 60WriteFlash((Application_2_Addr+(data_state-1)*128),(uint32_t*)(&temp_buf[3]),32); 61data_state++; 62 63send_command(ACK); 64} 65} 66else 67{ 68printf(">Notpasscrc "); 69} 70 71}break; 72caseEOT://數(shù)據(jù)包開始 73{ 74if(Get_state()==TO_RECEIVE_DATA) 75{ 76printf(">ReceiveEOT1... "); 77 78Set_state(TO_RECEIVE_EOT2); 79send_command(NACK); 80} 81elseif(Get_state()==TO_RECEIVE_EOT2) 82{ 83printf(">ReceiveEOT2... "); 84 85Set_state(TO_RECEIVE_END); 86send_command(ACK); 87send_command(CCC); 88} 89else 90{ 91printf(">ReceiveEOT,Buterror... "); 92} 93}break; 94} 95} 96}
  • 其中部分函數(shù)未在以上代碼中展現(xiàn), 詳情請參看文末給出的源碼鏈接.

4. 整體測試

本節(jié)主要對前三節(jié)的教程做測試驗證BootLoader+App的升級功能。

源代碼

BootLoader源代碼和App1源代碼可以在原作者的gitee獲?。?/span>https://gitee.com/leafguo/leaf_notes/STM32CubeMX/STM32CubeMx_OTA

代碼的下載

  • 由下圖可知兩份代碼的下載區(qū)域是不一樣的,所以他們「下載的區(qū)域也不一樣」

e6e71e46-da5e-11ec-ba43-dac502259ad0.png

BootLoader的下載

  • BootLoader的代碼默認是最開始的所以不需要特別設置代碼的下載位置
  • 按照下圖, 修改擦除方式為Erase Sectors, 大小限制在0X5000(20K)

e869658a-da5e-11ec-ba43-dac502259ad0.png

  • 燒錄代碼
  • 運行, 通過串口1打印輸出, 會看到以下打印消息
  • 說明BootLoader已經(jīng)成功運行

e8abead6-da5e-11ec-ba43-dac502259ad0.png

App1的下載

  • App1稍微復雜一點, 需要將代碼的起始位置設置為0x08005000
  • 同時也要修改擦除方式為Erase Sectors, 見下圖

e9139fc8-da5e-11ec-ba43-dac502259ad0.png

e975bc76-da5e-11ec-ba43-dac502259ad0.png

  • 燒錄代碼
  • 運行, 通過串口1打印輸出, 會看到以下打印消息
  • 說明BootLoader已經(jīng)成功跳轉(zhuǎn)到版本號為0.0.1的App1

e99d5308-da5e-11ec-ba43-dac502259ad0.png

生成App2的.bin文件

  • Keil如何生成.bin文件, 請參考這篇博文 Keil如何生成.bin文件
https://blog.csdn.net/weixin_41294615/article/details/104656577
  • 修改代碼, 把版本號改為0.0.2, 并且編譯并且生成.bin文件
  • 生成好之后你會得到一個.bin結尾的文件, 這就是我們待會兒YModem要傳輸?shù)奈募?/span>

e9b84ce4-da5e-11ec-ba43-dac502259ad0.png

使用Xshell進行文件傳輸

  • 打開Xshell
  • 代碼中, 串口1進行調(diào)試信息的打印, 串口2進行YModem升級的
  • 所以使用Xshell打開串口2進行文件傳輸, 串口1則可以通過串口調(diào)試助手查看調(diào)試消息
  • 你會看到App的版本成功升級到0.0.2了.
  • 如果你到了這一步.
  • 那么恭喜你! 你已經(jīng)能夠使用在線升級了!

5. 總結

通過本幾節(jié)的教程, 想必你已經(jīng)會使用在線升級了, 只要原理知道了其他的問題都可以迎刃而解了, 除了使用YModem協(xié)議傳輸.bin文件, 你還可以通過藍牙, WIFI,等其他協(xié)議傳輸, 只要能夠?qū)?bin文件傳輸過去, 那其他的部分原理都差不多。

原文標題:詳解STM32在線IAP升級

文章出處:【微信公眾號:硬件攻城獅】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

審核編輯:湯梓紅
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • STM32
    +關注

    關注

    2270

    文章

    10895

    瀏覽量

    355725
  • IAP
    IAP
    +關注

    關注

    2

    文章

    163

    瀏覽量

    24279
  • 在線升級
    +關注

    關注

    0

    文章

    8

    瀏覽量

    5975

原文標題:詳解STM32在線IAP升級

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關推薦

    STM32 IAP在線升級

    STM32很強大的一個功能是支持IAP在線升級,IAP(In-Application Programming),即在“應用程序中編程 ",通俗的來將是程序自己可以往程序存儲器里寫數(shù)據(jù)或
    發(fā)表于 03-09 15:56

    介紹關于編程的基礎知識

    關注、星標公眾號,不錯過精彩內(nèi)容作者:strongerHuang對于軟件工程師來說,代碼升級(或程序更新)算是必備基礎知識。下面將介紹關于編程的基礎知識,以及結合STM32官方提供的D
    發(fā)表于 07-27 08:13

    IAP在線升級

    flash。IAP在線升級的確是個好東西,對于那些已經(jīng)安裝好的設備來說,真是一大利器。IAP的核心理論其實比較簡單:總共有兩個程序,一個叫bootloader,一個叫app。其中bo
    發(fā)表于 08-06 07:07

    IAP在線升級是什么

    IAP在線升級是什么?怎樣去設計應用程序?
    發(fā)表于 10-19 09:27

    如何去實現(xiàn)stm32的IAP在線升級

    如何去實現(xiàn)stm32的IAP在線升級呢?需要注意哪些事情呢?
    發(fā)表于 11-29 07:35

    如何實現(xiàn)STM32的在線升級IAP功能?

    如何實現(xiàn)STM32的在線升級IAP功能?
    發(fā)表于 11-30 06:22

    串口藍牙IAP在線升級的相關資料推薦

    串口藍牙IAP在線升級轉(zhuǎn)載:https://www.it610.com/article/1279095852547194880.htm(https://www.it610.com/article
    發(fā)表于 12-10 06:55

    IAP在線升級相關資料分享

    最近做了一個工程需要用到IAP在線升級這個功能,當時在學的時候,了解到IAP的功能當時就覺得很雞肋,明明有燒寫器干嘛那么費事,現(xiàn)在覺得當時確實淺薄了,
    發(fā)表于 12-13 08:01

    STM32 IAP在線升級詳解

    背景知識一、stm32的內(nèi)存映射參考博文:STM32 IAP 在線升級詳解操作前我們先來說一下內(nèi)存映射:下圖在stm32f100芯片手冊的29頁,我們只截取關鍵部分注意: 根據(jù)啟動方式
    發(fā)表于 02-21 06:10

    STM8在線升級關于IAP與APP互相跳轉(zhuǎn)的實現(xiàn)

    詳細介紹STM8中,實現(xiàn)在線升級時,IAP與APP互相跳轉(zhuǎn)的過程。
    發(fā)表于 05-04 16:10 ?33次下載

    ARM在線升級的應用IAP代碼

    ARM嵌入式應用程序架構設計實例精講--ARM在線升級的應用IAP代碼
    發(fā)表于 07-08 11:08 ?6次下載

    ARM在線升級的應用IAP代碼

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

    STM32三種啟動模式以及IAP在線升級

    stm32 iap在線升級
    發(fā)表于 01-13 14:28 ?16次下載

    51單片機IAP在線升級

    51單片機IAP在線升級愛矽半導體E85F3325單片機IAP在線升級教程,此處可查看更新及de
    發(fā)表于 11-11 19:21 ?16次下載
    51單片機<b class='flag-5'>IAP</b><b class='flag-5'>在線</b><b class='flag-5'>升級</b>

    AT32 MCU如何使用IAP通過USART實現(xiàn)對固件的在線升級更新

    AT32 MCU如何使用IAP通過USART實現(xiàn)對固件的在線升級更新
    的頭像 發(fā)表于 09-19 16:51 ?2279次閱讀
    AT32 MCU如何使用<b class='flag-5'>IAP</b>通過USART實現(xiàn)對固件的<b class='flag-5'>在線</b><b class='flag-5'>升級</b>更新
    RM新时代网站-首页