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

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

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

AT32講堂003 | AT32 MCU如何使用USB HID進行IAP升級

雅特力 AT32 MCU ? 2022-04-24 14:36 ? 次閱讀

IAP在線升級原理概述

IAP(In Application Programming)即在應(yīng)用編程,IAP是用戶自己的程序在運行過程中對User Flash的部分區(qū)域進行燒寫,目的是為了在產(chǎn)品發(fā)布后可以方便地通過預(yù)留的通信口對產(chǎn)品中的固件程序進行更新升級。通常實現(xiàn)IAP功能時,即用戶程序運行中作自身的更新操作,需要在設(shè)計固件程序時編寫兩個項目代碼,第一個項目程序不執(zhí)行正常的功能操作,而只是通過某種通信方式(如USB、USART)接收程序或數(shù)據(jù),執(zhí)行對第二部分代碼的更新;第二個項目代碼才是真正的功能代碼。這兩部分項目代碼都同時燒錄在User Flash中,當芯片上電后,首先是第一個項目代碼開始運行,它作如下操作:1. 檢查是否需要對第二部分代碼進行更新2. 如果不需要更新則轉(zhuǎn)到43. 執(zhí)行更新操作4. 跳轉(zhuǎn)到第二部分代碼執(zhí)行

圖1. IAP代碼執(zhí)行流程

f4951b36-c264-11ec-82f6-dac502259ad0.png

在圖上圖所示流程中,AT32復(fù)位后,還是從0X08000004地址取出復(fù)位中斷向量的地址,并跳轉(zhuǎn)到復(fù)位中斷服務(wù)程序,在運行完復(fù)位中斷服務(wù)程序之后跳轉(zhuǎn)到IAP的main函數(shù),如圖標號①所示。在執(zhí)行完IAP以后(即將新的APP代碼寫入AT32的FLASH,灰底部分。新程序的復(fù)位中斷向量起始地址為0X08000004+N+M),跳轉(zhuǎn)至新寫入程序的復(fù)位向量表,取出新程序的復(fù)位中斷向量的地址,并跳轉(zhuǎn)執(zhí)行新程序的復(fù)位中斷服務(wù)程序,隨后跳轉(zhuǎn)至新程序的main函數(shù),如圖標號②和③所示,同樣main函數(shù)為一個死循環(huán),并且注意到此時AT32的FLASH,在不同位置上,共有兩個中斷向量表。

在main函數(shù)執(zhí)行過程中,如果CPU得到一個中斷請求,PC指針仍強制跳轉(zhuǎn)到地址0X08000004中斷向量表處,而不是新程序的中斷向量表,如圖標號④所示;程序再根據(jù)我們設(shè)置的中斷向量表偏移量,跳轉(zhuǎn)到對應(yīng)中斷源新的中斷服務(wù)程序中,如圖標號⑤所示;在執(zhí)行完中斷服務(wù)程序后,程序返回main函數(shù)繼續(xù)運行,如圖標號⑥所示。

通過以上兩個過程的分析,我們知道IAP程序必須滿足兩個要求:

1. 新程序必須在IAP程序之后的某個偏移量為x的地址開始2. 必須將新程序的中斷向量表相應(yīng)的移動,移動的偏移量為x


AT32 USB HID IAP快速使用方法

硬件資源

文檔中是用AT-START-AT32F403A實驗板的硬件條件為例,OTA demo源代碼還包括AT32其他型號,用戶只需編譯對應(yīng)型號工程燒錄于AT-START實驗板運行即可。1) 指示燈LED2/LED3/LED42) USART1(PA9/PA10)3) AT-START實驗板

軟件資源

1. APP_Release

● IAP_Programmer.exe PC機tool

2. SourceCode

● bootloader,IAP源程序,運行LE2閃爍

● app_led3_toggle,app1 LED3閃爍源程序

● app_led4_toggle,app2 LED4閃爍源程序

注:工程基于keil v5和IAR8.2建立,若用戶需要在其他編譯環(huán)境上使用,請參考

AT32F403A_407_Firmware_Library_V2.x.x\project\at_start_f403a\templates中各種編譯環(huán)境(例如IAR6/7/8,keil 4/5,eclipse_gcc)進行對應(yīng)修改即可。

IAP Programmer使用

1. 打開bootloader源程序,編譯后下載到實驗板

2. 打開IAP Programmer.exe3. 如圖,選擇USB設(shè)備,使用的是HID設(shè)備,因此不需要驅(qū)動4. 選擇APP下載地址(下載地址需要與IAP設(shè)置的下載地址相同)和bin文檔,選擇是否需要CRC校驗,點擊Download下載5. 觀察LED2/3/4閃爍,LED2閃爍-bootloader工作,LED3閃爍-app1工作,LED4閃爍-app2工作6. 支持斷電保護,當程序沒有download成功時,下次啟動還在IAP模式

圖2. IAP demo上位機

f4a60d06-c264-11ec-82f6-dac502259ad0.jpg

AT32 USB HID IAP程序設(shè)置

地址分布

表1. 地址分布

f4ba3f92-c264-11ec-82f6-dac502259ad0.jpg

Note:bootloader區(qū)域最后一個扇區(qū),用于放置防掉電丟失的flag,用戶修改bootloader時請勿操作該段地址。

bootloader project設(shè)置

1) Keil設(shè)置

圖3. bootloader project中add1在Keil設(shè)置

f4c98c36-c264-11ec-82f6-dac502259ad0.jpg

2)bootloader源程序修改

hid_iap_user.h文件中

圖4. bootloader project中add2在程序中設(shè)置

f4de31b8-c264-11ec-82f6-dac502259ad0.jpg

app設(shè)置

該demo提供了2個app程序供測試用,皆以add2(0x800 4000)為起始地址。app1 LED3閃爍,app2 LED4閃爍。以app LED3為例,設(shè)計步驟如下:

1.Keil工程設(shè)置

圖5. app project中add2在Keil設(shè)置

f4f00442-c264-11ec-82f6-dac502259ad0.jpg

2.app源程序設(shè)置

修改main.c中的中斷向量偏移

圖6. app源程序設(shè)置

f50604f4-c264-11ec-82f6-dac502259ad0.jpg

3. 編譯生成bin文件

通過在User選項卡,設(shè)置編譯后調(diào)用fromelf.exe,根據(jù).axf文件生成.bin文件,用于IAP更新。

以上3個步驟,我們就可以得到一個.bin的APP程序,通過bootloader程序即可實現(xiàn)更新。

4. 開啟debug app code功能

如果在設(shè)計app code過程中需要對app project進行單獨調(diào)試,請按照以下操作。

● 下載bootloader project

● 第一次使用debug功能需要IAP Programmer.exe成功下載一次app.(成功下載之后會寫flag,表示下次從app啟動。默認flag會從bootloader啟動)

● debug app project

IAP、APP與上位機通信流程

1. 上位機通信流程

圖7. 上位機通信流程

f51bdf04-c264-11ec-82f6-dac502259ad0.png

2. IAP端下位機通信流程

圖8. IAP端下位機通信流程

f5444476-c264-11ec-82f6-dac502259ad0.png

注意:具體協(xié)議請參考AT32_HID_IAP_Protocol.pdf

USB HID IAP Protocol

本節(jié)描述USB HID升級協(xié)議,使用此協(xié)議與上位機進行通信,達到升級固件的目的。

命令列表

f554885e-c264-11ec-82f6-dac502259ad0.jpg

注意1:HID MaxPacket=64Byte

注意2:每一個包的前面兩個Byte固定為命令

注意3:命令按照MSB,LSB的順序傳輸

ACK:0XFF00,NACK:0x00FF

命令詳解

1. 0x5AA0進入IAP模式

作為一個特定的命令,當用戶APP收到這個命令之后將進入IAP模式。實現(xiàn)方式為收到這個命令之后擦除flag然后reset

上位機:[0x5A,0xA0]

IAP設(shè)備響應(yīng):[0x5A,0XA0,ACK/NACK]

2. 0x5AA1開始下載

上位機:[0x5A,0xA1]

IAP設(shè)備響應(yīng):[0x5A,0xA1,ACK/NACK]

3. 0x5AA2設(shè)置下載地址

設(shè)置下載地址需按照1KB對齊,每下載1Kbyte數(shù)據(jù)之后,都需要重新設(shè)置下載地址。

上位機(命令+地址):[0x5A,0xA2,0x08,0x00,0x40,0x00]

IAP設(shè)備響應(yīng):[0x5A,0xA2,ACK/NACK]

4. 0x5AA3下載數(shù)據(jù)命令(1KB對齊多個包發(fā)送)

下載數(shù)據(jù)命令采用命令+長度+數(shù)據(jù)的格式進行發(fā)送,每包最大數(shù)據(jù)量為60Byte(64–命令–長度),當發(fā)送數(shù)據(jù)達到1KB時,上位機需要等待設(shè)備的ACK響應(yīng)。此時設(shè)備需將1KB的數(shù)據(jù)寫到FLASH。

上位機(命令(2Byte)+長度(2Byte)+數(shù)據(jù)(nbyte)):[0x5A,0xA3,LEN1,LEN0,DATA0….DATAn]

收完1KB數(shù)據(jù)后IAP設(shè)備響應(yīng):[0x5A,0XA3,ACK/NACK]

5. 0x5AA4下載結(jié)束

上位機:[0x5A,0xA4]

IAP設(shè)備響應(yīng):[0x5A,0xA4,ACK/NACK]

6. 0x5AA5固件CRC校驗

上位機傳輸固件起始地址和固件大小/1KB(固件大小按1KB對齊,不足補0xFF),由IAP計算CRC之后返回給上位機。

上位機:[0x5A,0xA5,0x08,0x00,0x40,0x00,LEN1,LEN0]

IAP設(shè)備響應(yīng):[0x5A,0xA5,ACK/NACK,CRC3,CRC2,CRC1,CRC0]

7. 0x5AA6跳轉(zhuǎn)命令

跳轉(zhuǎn)命令將跳轉(zhuǎn)到用戶代碼進行運行

上位機:[0x5A,0xA6,0x08,0x00,0x40,0x00]

IAP設(shè)備響應(yīng):[0x5A,0xA6,ACK/NACK]

8. 0x5AA7獲取IAP設(shè)置的app地址

返回IAP設(shè)置的app地址

上位機:[0x5A,0xA7]

IAP設(shè)備響應(yīng):[0x5A,0xA7,ACK/NACK,0x08,0x00,0x40,0x00]

關(guān)于雅特力雅特力科技于2016年成立,是一家致力于推動全球市場32位微控制器創(chuàng)新趨勢的芯片(MCU)設(shè)計公司,專注于ARM Cortex-M4/M0+的32位微控制器研發(fā)與創(chuàng)新,全系列采用55nm先進工藝及ARM Cortex-M4高效能或M0+低功耗內(nèi)核,締造M4業(yè)界最高主頻288MHz運算效能,并支持工業(yè)級別芯片工作溫度范圍(-40°~105°)。雅特力目前已累積相當多元的終端產(chǎn)品成功案例:如微型打印機、掃地機、光流無人機、熱成像儀、激光雷達、工業(yè)縫紉機、伺服驅(qū)控、電競周邊市場、斷路器、ADAS、T-BOX、數(shù)字電源、電動工具等終端設(shè)備應(yīng)用,廣泛地覆蓋5G、物聯(lián)網(wǎng)、消費、商務(wù)及工控等領(lǐng)域。

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

    關(guān)注

    146

    文章

    17148

    瀏覽量

    351212
收藏 人收藏

    評論

    相關(guān)推薦

    STM32轉(zhuǎn)AT32代碼轉(zhuǎn)換

    1.引言在嵌入式開發(fā)中,我們經(jīng)常會遇到更換單片機芯片的事情,若芯片是同一廠家的還好說,若是不同廠家的則需要重新寫,重新調(diào),重新去學(xué)習(xí)其底層驅(qū)動程序,比較費時費力。如:ST32轉(zhuǎn)AT32、ST32轉(zhuǎn)
    的頭像 發(fā)表于 09-28 08:09 ?335次閱讀
    STM32轉(zhuǎn)<b class='flag-5'>AT32</b>代碼轉(zhuǎn)換

    AT32講堂088 | 雅特力AT32F402/F405時鐘配置

    簡介時鐘是芯片正確高效運行的基礎(chǔ),正確的時鐘配置是芯片能正確運行的必要條件,其重要性不言而喻。AT32各系列產(chǎn)品的時鐘配置部分可能存在細微的差異和需要注意的事項,本文檔就著重針對各系列的情況來詳細
    的頭像 發(fā)表于 09-15 08:08 ?494次閱讀
    <b class='flag-5'>AT32</b><b class='flag-5'>講堂</b>088 | 雅特力AT32F402/F405時鐘配置

    AT32講堂087 | 雅特力AT32 IDE快速入門指南

    新建項目新項目向?qū)T32ID提供支持雅特力MCU的C語言項目模板,方便用戶快速創(chuàng)建項目。菜單欄【File】>【New】>【CProject】。新建項目向?qū)У膶υ捒驅(qū)⒊霈F(xiàn)。在對
    的頭像 發(fā)表于 09-15 08:08 ?455次閱讀
    <b class='flag-5'>AT32</b><b class='flag-5'>講堂</b>087 | 雅特力<b class='flag-5'>AT32</b> IDE快速入門指南

    雅特力AT32 MCU的隨機數(shù)生成

    概述產(chǎn)品和生態(tài)系統(tǒng)安全性的需求比以往任何時候都更加重要。真隨機數(shù)是所有安全系統(tǒng)的核心,其質(zhì)量會影響設(shè)計的安全性。因此在沒有內(nèi)置硬件TRNG的AT32的微控制器系列中,如何提高隨機數(shù)的有效,來符合
    的頭像 發(fā)表于 08-30 12:26 ?572次閱讀
    雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b>的隨機數(shù)生成

    AT32講堂085 | 雅特力AT32 MCU HICK時鐘校準

    簡介AT32系列MCU內(nèi)部都有提供適合運行的內(nèi)部高速時鐘(HICK),其本質(zhì)就是內(nèi)置于芯片的RC振蕩器。在25℃下,其典型值頻率8MHz的精度由工廠校準到±1%,在-40到105℃,該內(nèi)部高速時鐘
    的頭像 發(fā)表于 08-30 12:26 ?628次閱讀
    <b class='flag-5'>AT32</b><b class='flag-5'>講堂</b>085 | 雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b> HICK時鐘校準

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

    問題出現(xiàn)在哪,我嘗試使用KEIL進行軟件編譯,下載,在這個工具下F407也能實現(xiàn)IAP升級。 以下是我的IAP具體代碼 int main(void) { HAL_Init();//
    發(fā)表于 07-31 07:48

    【GD32F303紅楓派開發(fā)板使用手冊】第二十九講 USB-IAP升級實驗

    USB IAP升級本例程中使用的是Custom HID中的IAP設(shè)備類,其設(shè)備類協(xié)議的實現(xiàn)與HID
    的頭像 發(fā)表于 07-04 09:54 ?630次閱讀
    【GD32F303紅楓派開發(fā)板使用手冊】第二十九講 <b class='flag-5'>USB-IAP</b><b class='flag-5'>升級</b>實驗

    如何在雅特力AT32 MCU上創(chuàng)建IAP應(yīng)用程序

    概述AT32CANIAP快速使用方法使用CAN進行IAP升級,此示例使用PC上位軟件(IAP_Programmer.exe)通過一個USB轉(zhuǎn)
    的頭像 發(fā)表于 05-20 08:15 ?1129次閱讀
    如何在雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b>上創(chuàng)建<b class='flag-5'>IAP</b>應(yīng)用程序

    芯海通用 MCU 應(yīng)用筆記 :CS32F103 系列 MCU IAP 升級指南

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

    芯海通用 MCU 應(yīng)用筆記: CS32F03x IAP 升級

    本技術(shù)文檔旨在幫助客戶實現(xiàn) IAP 升級提供一個參考方案和模板。本文檔提供基于 UART 升級MCU 參考代碼和 PC 端的升級工具軟件
    發(fā)表于 05-16 10:55

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

    想通過iap的方式對stm32f405進行升級,用usb傳輸 dfu格式; 在數(shù)據(jù)傳輸過程中,發(fā)現(xiàn)源文件和傳到設(shè)備上的數(shù)據(jù)匹配不起來,有人遇到過嗎??求助?。。?! 是
    發(fā)表于 04-28 08:56

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

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

    雅特力AT32 MCU與SEGGER攜手合作,開發(fā)量產(chǎn)事半功倍

    近日,雅特力與SEGGER共同宣布J-Link仿真調(diào)試器與Flasher在線燒錄器全面支持AT32 MCU產(chǎn)品,SEGGER工具鏈的加持使AT32 MCU開發(fā)如虎添翼。 雅特力自201
    的頭像 發(fā)表于 02-23 10:27 ?421次閱讀

    AT32 定時器配置中pr和div的作用

    AT32定時器是51系列單片機中的一種定時器,可以實現(xiàn)多種定時功能。在AT32定時器中,pr和div是兩個相關(guān)的參數(shù),用于配置定時器的工作參數(shù)。 首先,需要了解pr和div分別代表什么含義。pr
    的頭像 發(fā)表于 01-08 10:12 ?1312次閱讀

    雅特力AT32 MCU HOGP開發(fā)指南

    HOGP概述HOGP(HIDoverGATT)是由BluetoothSIG維護的藍牙配置文件規(guī)范,通過低功耗藍牙實現(xiàn)HID的配置文件并作為與計算器之間的接口,消除HID中對電線或物理連接的需求
    的頭像 發(fā)表于 12-30 08:14 ?663次閱讀
    雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b> HOGP開發(fā)指南