0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

AT32讲堂003 | AT32 MCU如何使用USB HID进行IAP升级

雅特力 AT32 MCU 2022-04-24 14:36 次阅读

IAP在线升级原理概述

IAP(In Application Programming)即在应用编程,IAP是用户自己的程序在运行过程中对User Flash的部分区域进行烧写,目的是为了在产品发布后可以方便地通过预留的通信口对产品中的固件程序进行更新升级。通常实现IAP功能时,即用户程序运行中作自身的更新操作,需要在设计固件程序时编写两个项目代码,第一个项目程序不执行正常的功能操作,而只是通过某种通信方式(如USB、USART)接收程序或数据,执行对第二部分代码的更新;第二个项目代码才是真正的功能代码。这两部分项目代码都同时烧录在User Flash中,当芯片上电后,首先是第一个项目代码开始运行,它作如下操作:1. 检查是否需要对第二部分代码进行更新2. 如果不需要更新则转到43. 执行更新操作4. 跳转到第二部分代码执行

图1. IAP代码执行流程

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

在图上图所示流程中,AT32复位后,还是从0X08000004地址取出复位中断向量的地址,并跳转到复位中断服务程序,在运行完复位中断服务程序之后跳转到IAP的main函数,如图标号①所示。在执行完IAP以后(即将新的APP代码写入AT32的FLASH,灰底部分。新程序的复位中断向量起始地址为0X08000004+N+M),跳转至新写入程序的复位向量表,取出新程序的复位中断向量的地址,并跳转执行新程序的复位中断服务程序,随后跳转至新程序的main函数,如图标号②和③所示,同样main函数为一个死循环,并且注意到此时AT32的FLASH,在不同位置上,共有两个中断向量表。

在main函数执行过程中,如果CPU得到一个中断请求,PC指针仍强制跳转到地址0X08000004中断向量表处,而不是新程序的中断向量表,如图标号④所示;程序再根据我们设置的中断向量表偏移量,跳转到对应中断源新的中断服务程序中,如图标号⑤所示;在执行完中断服务程序后,程序返回main函数继续运行,如图标号⑥所示。

通过以上两个过程的分析,我们知道IAP程序必须满足两个要求:

1. 新程序必须在IAP程序之后的某个偏移量为x的地址开始2. 必须将新程序的中断向量表相应的移动,移动的偏移量为x


AT32 USB HID IAP快速使用方法

硬件资源

文档中是用AT-START-AT32F403A实验板的硬件条件为例,OTA demo源代码还包括AT32其他型号,用户只需编译对应型号工程烧录于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建立,若用户需要在其他编译环境上使用,请参考

AT32F403A_407_Firmware_Library_V2.x.x\project\at_start_f403a\templates中各种编译环境(例如IAR6/7/8,keil 4/5,eclipse_gcc)进行对应修改即可。

IAP Programmer使用

1. 打开bootloader源程序,编译后下载到实验板

2. 打开IAP Programmer.exe3. 如图,选择USB设备,使用的是HID设备,因此不需要驱动4. 选择APP下载地址(下载地址需要与IAP设置的下载地址相同)和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程序设置

地址分布

表1. 地址分布

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

Note:bootloader区域最后一个扇区,用于放置防掉电丢失的flag,用户修改bootloader时请勿操作该段地址。

bootloader project设置

1) Keil设置

图3. bootloader project中add1在Keil设置

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

2)bootloader源程序修改

hid_iap_user.h文件中

图4. bootloader project中add2在程序中设置

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

app设置

该demo提供了2个app程序供测试用,皆以add2(0x800 4000)为起始地址。app1 LED3闪烁,app2 LED4闪烁。以app LED3为例,设计步骤如下:

1.Keil工程设置

图5. app project中add2在Keil设置

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

2.app源程序设置

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

图6. app源程序设置

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

3. 编译生成bin文件

通过在User选项卡,设置编译后调用fromelf.exe,根据.axf文件生成.bin文件,用于IAP更新。

以上3个步骤,我们就可以得到一个.bin的APP程序,通过bootloader程序即可实现更新。

4. 开启debug app code功能

如果在设计app code过程中需要对app project进行单独调试,请按照以下操作。

● 下载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

注意:具体协议请参考AT32_HID_IAP_Protocol.pdf

USB HID IAP Protocol

本节描述USB HID升级协议,使用此协议与上位机进行通信,达到升级固件的目的。

命令列表

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

注意1:HID MaxPacket=64Byte

注意2:每一个包的前面两个Byte固定为命令

注意3:命令按照MSB,LSB的顺序传输

ACK:0XFF00,NACK:0x00FF

命令详解

1. 0x5AA0进入IAP模式

作为一个特定的命令,当用户APP收到这个命令之后将进入IAP模式。实现方式为收到这个命令之后擦除flag然后reset

上位机:[0x5A,0xA0]

IAP设备响应:[0x5A,0XA0,ACK/NACK]

2. 0x5AA1开始下载

上位机:[0x5A,0xA1]

IAP设备响应:[0x5A,0xA1,ACK/NACK]

3. 0x5AA2设置下载地址

设置下载地址需按照1KB对齐,每下载1Kbyte数据之后,都需要重新设置下载地址。

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

IAP设备响应:[0x5A,0xA2,ACK/NACK]

4. 0x5AA3下载数据命令(1KB对齐多个包发送)

下载数据命令采用命令+长度+数据的格式进行发送,每包最大数据量为60Byte(64–命令–长度),当发送数据达到1KB时,上位机需要等待设备的ACK响应。此时设备需将1KB的数据写到FLASH。

上位机(命令(2Byte)+长度(2Byte)+数据(nbyte)):[0x5A,0xA3,LEN1,LEN0,DATA0….DATAn]

收完1KB数据后IAP设备响应:[0x5A,0XA3,ACK/NACK]

5. 0x5AA4下载结束

上位机:[0x5A,0xA4]

IAP设备响应:[0x5A,0xA4,ACK/NACK]

6. 0x5AA5固件CRC校验

上位机传输固件起始地址和固件大小/1KB(固件大小按1KB对齐,不足补0xFF),由IAP计算CRC之后返回给上位机。

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

IAP设备响应:[0x5A,0xA5,ACK/NACK,CRC3,CRC2,CRC1,CRC0]

7. 0x5AA6跳转命令

跳转命令将跳转到用户代码进行运行

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

IAP设备响应:[0x5A,0xA6,ACK/NACK]

8. 0x5AA7获取IAP设置的app地址

返回IAP设置的app地址

上位机:[0x5A,0xA7]

IAP设备响应:[0x5A,0xA7,ACK/NACK,0x08,0x00,0x40,0x00]

关于雅特力雅特力科技于2016年成立,是一家致力于推动全球市场32位微控制器创新趋势的芯片(MCU)设计公司,专注于ARM Cortex-M4/M0+的32位微控制器研发与创新,全系列采用55nm先进工艺及ARM Cortex-M4高效能或M0+低功耗内核,缔造M4业界最高主频288MHz运算效能,并支持工业级别芯片工作温度范围(-40°~105°)。雅特力目前已累积相当多元的终端产品成功案例:如微型打印机、扫地机、光流无人机、热成像仪、激光雷达、工业缝纫机、伺服驱控、电竞周边市场、断路器、ADAS、T-BOX、数字电源、电动工具等终端设备应用,广泛地覆盖5G物联网、消费、商务及工控等领域。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • mcu
    mcu
    +关注

    关注

    146

    文章

    17173

    浏览量

    351656
收藏 人收藏

    评论

    相关推荐

    STM32转AT32代码转换

    1.引言在嵌入式开发中,我们经常会遇到更换单片机芯片的事情,若芯片是同一厂家的还好说,若是不同厂家的则需要重新写,重新调,重新去学习其底层驱动程序,比较费时费力。如:ST32转AT32、ST32转
    的头像 发表于 09-28 08:09 346次阅读
    STM32转<b class='flag-5'>AT32</b>代码转换

    AT32讲堂088 | 雅特力AT32F402/F405时钟配置

    简介时钟是芯片正确高效运行的基础,正确的时钟配置是芯片能正确运行的必要条件,其重要性不言而喻。AT32各系列产品的时钟配置部分可能存在细微的差异和需要注意的事项,本文档就着重针对各系列的情况来详细
    的头像 发表于 09-15 08:08 539次阅读
    <b class='flag-5'>AT32</b><b class='flag-5'>讲堂</b>088 | 雅特力AT32F402/F405时钟配置

    AT32讲堂087 | 雅特力AT32 IDE快速入门指南

    新建项目新项目向导AT32ID提供支持雅特力MCU的C语言项目模板,方便用户快速创建项目。菜单栏【File】>【New】>【CProject】。新建项目向导的对话框将出现。在对
    的头像 发表于 09-15 08:08 483次阅读
    <b class='flag-5'>AT32</b><b class='flag-5'>讲堂</b>087 | 雅特力<b class='flag-5'>AT32</b> IDE快速入门指南

    MSP430™ USB HID Windows API编程人员指南

    电子发烧友网站提供《MSP430™ USB HID Windows API编程人员指南.pdf》资料免费下载
    发表于 09-05 09:40 0次下载
    MSP430™ <b class='flag-5'>USB</b> <b class='flag-5'>HID</b> Windows API编程人员指南

    雅特力AT32 MCU的随机数生成

    概述产品和生态系统安全性的需求比以往任何时候都更加重要。真随机数是所有安全系统的核心,其质量会影响设计的安全性。因此在没有内置硬件TRNG的AT32的微控制器系列中,如何提高随机数的有效,来符合
    的头像 发表于 08-30 12:26 627次阅读
    雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b>的随机数生成

    AT32讲堂085 | 雅特力AT32 MCU HICK时钟校准

    简介AT32系列MCU内部都有提供适合运行的内部高速时钟(HICK),其本质就是内置于芯片的RC振荡器。在25℃下,其典型值频率8MHz的精度由工厂校准到±1%,在-40到105℃,该内部高速时钟
    的头像 发表于 08-30 12:26 661次阅读
    <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跳转APP进行软件升级怎么解决?

    问题出现在哪,我尝试使用KEIL进行软件编译,下载,在这个工具下F407也能实现IAP升级。 以下是我的IAP具体代码 int main(void) { HAL_Init();//
    发表于 07-31 07:48

    【GD32F303红枫派开发板使用手册】第二十九讲 USB-IAP升级实验

    USB IAP升级本例程中使用的是Custom HID中的IAP设备类,其设备类协议的实现与HID
    的头像 发表于 07-04 09:54 663次阅读
    【GD32F303红枫派开发板使用手册】第二十九讲 <b class='flag-5'>USB-IAP</b><b class='flag-5'>升级</b>实验

    如何在雅特力AT32 MCU上创建IAP应用程序

    概述AT32CANIAP快速使用方法使用CAN进行IAP升级,此示例使用PC上位软件(IAP_Programmer.exe)通过一个USB
    的头像 发表于 05-20 08:15 1161次阅读
    如何在雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b>上创建<b class='flag-5'>IAP</b>应用程序

    芯海通用 MCU 应用笔记 :CS32F103 系列 MCU IAP 升级指南

    本应用笔记旨在帮助指导用户针对芯海 CORTEX-M3 MCU CS32F103 系列单片机 IAP 应用的快速开发。本应用笔记实现了 CAN 和 USART 两种接口方式来开发 IAP 应用,协议
    发表于 05-16 11:40

    芯海通用 MCU 应用笔记: CS32F03x IAP 升级

    本技术文档旨在帮助客户实现 IAP 升级提供一个参考方案和模板。本文档提供基于 UART 升级MCU 参考代码和 PC 端的升级工具软件
    发表于 05-16 10:55

    通过iap的方式对stm32f405进行升级usb dfu数据传输出错的原因?

    想通过iap的方式对stm32f405进行升级,用usb传输 dfu格式; 在数据传输过程中,发现源文件和传到设备上的数据匹配不起来,有人遇到过吗??求助!!!! 是
    发表于 04-28 08:56

    usb dfu进行iap升级,固件下载完成后,校验不过,very失败的原因?

    最近在做usb dfu进行iap升级,固件下载完成后,校验不过,very失败,有人遇到过吗??? 比如在0x08020240位置,提示: File byte is 0x5c Re
    发表于 04-24 07:35

    ST-usb-host-hid库如何解决usb扫码枪这类的usb-hid-keyboard设备?

    用cube生成的usb-host-hid调试扫码枪的时候只能支持小部分的usb扫码枪,有好几种扫码枪的现象是:枚举成功了,但是在获取设备信息:USBH_HID
    发表于 04-17 06:49

    雅特力AT32 MCU与SEGGER携手合作,开发量产事半功倍

    近日,雅特力与SEGGER共同宣布J-Link仿真调试器与Flasher在线烧录器全面支持AT32 MCU产品,SEGGER工具链的加持使AT32 MCU开发如虎添翼。 雅特力自201
    的头像 发表于 02-23 10:27 436次阅读