在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

詳解stm32在線IAP升級

jf_BxU6dNQb ? 來源:CSDN ? 作者:CSDN ? 2022-12-05 11:48 ? 次閱讀

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

1.在線升級知識

什么是BootLoader?

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

STM32中的程序在哪兒?

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

49d8a5c2-744e-11ed-8abf-dac502259ad0.png

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

進行分區

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

4a09bd4c-744e-11ed-8abf-dac502259ad0.png

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

  • BootLoader區存放啟動代碼
  • App1區存放應用代碼
  • App2區存放暫存的升級代碼

4a2a83d8-744e-11ed-8abf-dac502259ad0.png

總體流程圖

  • 先執行BootLoader程序, 先去檢查APP2區有沒有程序, 如果有就將App2區(備份區)的程序拷貝到App1區, 然后再跳轉去執行App1的程序.
  • 然后執行App1程序, 因為BootLoaderApp1這兩個程序的向量表不一樣, 所以跳轉到App1之后第一步是先去更改程序的向量表. 然后再去執行其他的應用程序.
  • 在應用程序里面會加入程序升級的部分, 這部分主要工作是拿到升級程序, 然后將他們放到App2區(備份區), 以便下次啟動的時候通過BootLoader更新App1的程序. 流程圖如下圖所示:

4a5a7e26-744e-11ed-8abf-dac502259ad0.png

2. BootLoader的編寫

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

流程圖分析

以我例程的BootLoader為例:

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

4a88aa94-744e-11ed-8abf-dac502259ad0.png

程序編寫和分析

所需STM32的資源有:

  • 發送USART數據和printf重定向
  • Flash的讀寫
  • 程序跳轉指令,可以參考如下代碼:
    /*采用匯編設置棧的值*/
    __asmvoidMSR_MSP(uint32_tulAddr)
    {
    MSRMSP,r0//設置MainStack的值
    BXr14
    }
    
    /*程序跳轉函數*/
    typedefvoid(*Jump_Fun)(void);
    voidIAP_ExecuteApp(uint32_tApp_Addr)
    {
    Jump_FunJumpToApp;
    
    if(((*(__IOuint32_t*)App_Addr)&0x2FFE0000)==0x20000000)//檢查棧頂地址是否合法.
    {
    JumpToApp=(Jump_Fun)*(__IOuint32_t*)(App_Addr+4);//用戶代碼區第二個字為程序開始地址(復位地址)
    MSR_MSP(*(__IOuint32_t*)App_Addr);//初始化APP堆棧指針(用戶代碼區的第一個字用于存放棧頂地址)
    JumpToApp();//跳轉到APP.
    }
    }
  • 在需要跳轉的地方執行這個函數就可以了IAP_ExecuteApp(Application_1_Addr);
  • 其他的代碼請參考BootLoader源代碼

3. APP的編寫

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

流程圖分析

以我例程的App1為例:

  • 先修改向量表, 因為本程序是由BootLoader跳轉過來的, 不修改向量表后面會出現問題;
  • 打印版本信息, 方便查看不同的App版本;
  • 本例程的升級程序采用串口的Ymoderm協議進行傳輸bin文件. 具體的流程圖見下圖所示:

4aa61cf0-744e-11ed-8abf-dac502259ad0.png

程序編寫和分析

所需STM32的資源有:

  • 發送USART數據和printf重定向
  • Flash的讀寫
  • 串口的DMA收發
  • YModem協議相關

Ymodem協議

  • 百度百科[Ymodem協議]
  • 具體流程可自行查找相關文檔, 這兒提供一個我找到的 XYmodem.pdf(文末和源碼一起提供).
  • Ymodem協議相關介紹可參考我的這篇教程 YModem介紹

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

代碼分析

  • 代碼大多數都是通過串口實現Ymodem協議的接收, 這兒就不詳細說明

  • 后面放了我的源代碼, 詳情請參考我的源代碼.

  • 主函數添加修改向量表的指令

4abcb91a-744e-11ed-8abf-dac502259ad0.png

  • 打印版本信息以及跳轉指令

4ae05e38-744e-11ed-8abf-dac502259ad0.png

  • YModem相關的文件接收部分

    /**
    *@bieafYModem升級
    *
    *@paramnone
    *@returnnone
    */
    voidymodem_fun(void)
    {
    inti;
    if(Get_state()==TO_START)
    {
    send_command(CCC);
    HAL_Delay(1000);
    }
    if(Rx_Flag)//Receiveflag
    {
    Rx_Flag=0;//cleanflag
    
    /*拷貝*/
    temp_len=Rx_Len;
    for(i=0;iswitch(temp_buf[0])
    {
    caseSOH:///<數據包開始
    {
    staticunsignedchardata_state=0;
    staticunsignedintapp2_size=0;
    if(Check_CRC(temp_buf,temp_len)==1)///
    {
    if((Get_state()==TO_START)&&(temp_buf[1]==0x00)&&(temp_buf[2]==(unsignedchar)(~temp_buf[1])))///
    {
    printf(">Receivestart...
    ");
    
    Set_state(TO_RECEIVE_DATA);
    data_state=0x01;
    send_command(ACK);
    send_command(CCC);
    
    /*擦除App2*/
    Erase_page(Application_2_Addr,40);
    }
    elseif((Get_state()==TO_RECEIVE_END)&&(temp_buf[1]==0x00)&&(temp_buf[2]==(unsignedchar)(~temp_buf[1])))///
    {
    printf(">Receiveend...
    ");
    
    Set_Update_Down();
    Set_state(TO_START);
    send_command(ACK);
    HAL_NVIC_SystemReset();
    }
    elseif((Get_state()==TO_RECEIVE_DATA)&&(temp_buf[1]==data_state)&&(temp_buf[2]==(unsignedchar)(~temp_buf[1])))///
    {
    printf(">Receivedatabag:%dbyte
    ",data_state*128);
    
    /*燒錄程序*/
    WriteFlash((Application_2_Addr+(data_state-1)*128),(uint32_t*)(&temp_buf[3]),32);
    data_state++;
    
    send_command(ACK);
    }
    }
    else
    {
    printf(">Notpasscrc
    ");
    }
    
    }break;
    caseEOT://數據包開始
    {
    if(Get_state()==TO_RECEIVE_DATA)
    {
    printf(">ReceiveEOT1...
    ");
    
    Set_state(TO_RECEIVE_EOT2);
    send_command(NACK);
    }
    elseif(Get_state()==TO_RECEIVE_EOT2)
    {
    printf(">ReceiveEOT2...
    ");
    
    Set_state(TO_RECEIVE_END);
    send_command(ACK);
    send_command(CCC);
    }
    else
    {
    printf(">ReceiveEOT,Buterror...
    ");
    }
    }break;
    }
    }
    }
  • 其中部分函數未在以上代碼中展現, 詳情請參看文末給出的源碼鏈接.

4. 整體測試

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

源代碼

BootLoader源代碼和App1源代碼可以在原作者的gitee獲?。?/span>

https://gitee.com/leafguo/leaf_notes/STM32CubeMX/STM32CubeMx_OTA

代碼的下載

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

4afd4c1e-744e-11ed-8abf-dac502259ad0.png

BootLoader的下載

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

4b142434-744e-11ed-8abf-dac502259ad0.png

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

4b4196ee-744e-11ed-8abf-dac502259ad0.png

App1的下載

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

4b5ced0e-744e-11ed-8abf-dac502259ad0.png

4b8628cc-744e-11ed-8abf-dac502259ad0.png

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

4baef716-744e-11ed-8abf-dac502259ad0.png

生成App2的.bin文件

  • Keil如何生成.bin文件, 請參考這篇博文 Keil如何生成.bin文件

https://blog.csdn.net/weixin_41294615/article/details/104656577

  • 修改代碼, 把版本號改為0.0.2, 并且編譯并且生成.bin文件

  • 生成好之后你會得到一個.bin結尾的文件, 這就是我們待會兒YModem要傳輸的文件

4bc00b64-744e-11ed-8abf-dac502259ad0.png

使用Xshell進行文件傳輸

  • 打開Xshell
  • 代碼中, 串口1進行調試信息的打印, 串口2進行YModem升級的
  • 所以使用Xshell打開串口2進行文件傳輸, 串口1則可以通過串口調試助手查看調試消息

    4beb8c3a-744e-11ed-8abf-dac502259ad0.png

  • 你會看到App的版本成功升級到0.0.2了.
  • 如果你到了這一步.
  • 那么恭喜你! 你已經能夠使用在線升級了!

5. 總結

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


審核編輯 :李倩


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

    關注

    2

    文章

    795

    瀏覽量

    41688
  • STM32
    +關注

    關注

    2270

    文章

    10910

    瀏覽量

    356579
  • IAP
    IAP
    +關注

    關注

    2

    文章

    164

    瀏覽量

    24315

原文標題:干貨 | 詳解 stm32 在線 IAP 升級

文章出處:【微信號:混說Linux,微信公眾號:混說Linux】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    STM32F103上位機升級,RS485升級、CAN升級

    STM32F103_IAP開發板,用STM32F103RCT6主控芯片,例程用標準庫開發。基本串口RS232\\RS485通信及CAN接口升級學習方案開發板。 升級方案分兩種:用外置F
    發表于 01-03 08:57

    使用CUBE IDE無法通過IAP跳轉APP進行軟件升級怎么解決?

    本人使用的是cubeide 1.7.0版本,單片機是STM32F407VET6.在這個IDE工具下,成功實現STM32F103RCT6單片機的升級,卻無法實現F407這款芯片的升級,我
    發表于 07-31 07:48

    芯海通用 MCU 應用筆記 :CS32F103 系列 MCU IAP 升級指南

    本應用筆記旨在幫助指導用戶針對芯海 CORTEX-M3 MCU CS32F103 系列單片機 IAP 應用的快速開發。本應用筆記實現了 CAN 和 USART 兩種接口方式來開發 IAP 應用,協議
    發表于 05-16 11:40

    芯海通用 MCU 應用筆記: CS32F03x IAP 升級

    本技術文檔旨在幫助客戶實現 IAP 升級提供一個參考方案和模板。本文檔提供基于 UART 升級的 MCU 參考代碼和 PC 端的升級工具軟件。適用 MCU 型號:CS32F030、CS
    發表于 05-16 10:55

    芯??萍纪ㄓ?MCU 應用筆記: EVB-CS32L015 開發板&amp;IAP 升級指導手冊

    本文檔描述了 CS32L015 開發板 V1.1 的硬件資源配置,Pack 包的安裝,IAP 升級流程介紹等,幫助用戶快速使用 CS32L015 開發板,評估 CS32L015 芯片的性能。*附件:CS32L015開發板使用-IAP
    發表于 05-16 10:43

    STM32F1 IAP操作讀保護選項字節設置,APP使用系統復位跳轉后無法運行IAP的原因?

    最近調試一個程序,是基于STM32F1做的IAP,升級前后需要修改選項字節,FLASH_EraseOptionBytes函數內OB->RDP=RDP_Key語句實現讀保護的解除,如果我
    發表于 05-13 08:09

    通過iap的方式對stm32f405進行升級,usb dfu數據傳輸出錯的原因?

    想通過iap的方式對stm32f405進行升級,用usb傳輸 dfu格式; 在數據傳輸過程中,發現源文件和傳到設備上的數據匹配不起來,有人遇到過嗎??求助!?。?! 是usb dfu傳輸協議的問題嗎?誰有usb dfu格式
    發表于 04-28 08:56

    做usb dfu進行iap升級,固件下載完成后,校驗不過,very失敗的原因?

    最近在做usb dfu進行iap升級,固件下載完成后,校驗不過,very失敗,有人遇到過嗎??? 比如在0x08020240位置,提示: File byte is 0x5c Read byte
    發表于 04-24 07:35

    調試FreeRTOS程序,通過IAP升級后程序跑飛的原因?

    最近調試FreeRTOS程序,發現直接用IAR下載APP后程序運行正常,但是通過IAP升級后卻發現程序跑飛(因為是IAP升級,無法調試App程序,所以跳轉后具體在哪跑飛不得而知)。
    發表于 04-08 06:25

    CKS32F4xx系列產品的串口IAP功能詳解

    IAP(In Application Programming)即在應用編程,IAP是用戶自己的程序在運行過程中對User Flash的部分區域進行燒寫,目的是為了在產品發布后可以方便地通過預留的通信口對產品中的固件程序進行更新升級
    發表于 04-05 15:11 ?573次閱讀
    CKS32F4xx系列產品的串口<b class='flag-5'>IAP</b>功能<b class='flag-5'>詳解</b>

    stm32f1使用IAP升級后STemwin顯示圖片速度變慢的原因?

    我使用STM32F103VET6進行IAP升級。 現在將512K的flash劃分為以下四個區域: 0x8000000——0x800B400的45K為bootloader區,存放IAP
    發表于 03-29 08:08

    stm32H747雙核的IAP升級要怎么做?

    H747雙核我看有2個Hex文件,生成的Bin文件也有2個。Bootloader要怎么處理呢?也是2個Bootloader程序嗎?那我要IAP升級程序的話要怎么處理了?
    發表于 03-28 08:50

    使用STM32CubeIDE無法通過IAP跳轉APP進行軟件升級的原因?

    使用CUBE IDE無法通過IAP跳轉APP進行軟件升級 本人使用的是cubeide 1.7.0版本,單片機是STM32F407VET6.在這個IDE工具下,成功實現STM32
    發表于 03-28 06:47

    STM32 IAP升級,KEIL如何一份代碼運行于兩個APP區?

    我的想法是一個IAP+APP1+APP2。上電運行IAP。會檢測當前有效APP,跳轉有效APP運行。在APP運行期間,收到升級指令,直接dowm固件,到另外一個APP區,下載會對固件進行安全
    發表于 03-26 07:20

    IAP在線升級,當STM32f107識別U盤時,U盤使用多次后識別過程會變得很慢為什么呢?

    本人在做IAP在線升級,當STM32f107芯片識別U盤時候,U盤使用多次后,識別過程會變得很慢,這是為什么呢?是U盤老化還是芯片原因呢?
    發表于 03-21 07:03
    主站蜘蛛池模板: 77成人| www.亚洲视频.com| 四虎午夜剧场| 午夜高清| 午夜毛片不卡高清免费| 美女视频网站色软件免费视频| 色视频在线免费观看| 日韩午夜片| 毛片新网址| 俺去啦五月| 天天操天天摸天天干| 国产精品午夜剧场| 色综合色狠狠天天综合色hd| 欧美在线成人午夜影视| 亚洲午夜日韩高清一区| 天天爱天天做天天爽| 国产精品1区2区3区在线播放| 手机看片免费福利| 夜夜夜夜曰天天天天拍国产| 午夜视频免费国产在线| 日本黄色小说视频| 欧美极品另类| 午夜aa| 热re久久精品国产99热| 亚洲国产精品综合久久久| 免费看色视频| 婷婷丁香色综合狠狠色| 亚洲视频欧美视频| 日本黄色录像视频| 国产人免费人成免费视频| 五月天伦理| 最近在线观看免费完整视频| 亚洲天堂视频在线观看免费| 狼狼鲁狼狼色| 最好看的2019中文字幕免费高清| 天堂免费在线视频| 深爱婷婷激情网| 九色综合久久综合欧美97| 午夜免费剧场| 欧美日穴| 香港三级理论在线观看网站|