Stm32 Bootloader整理

发布者:Dingsir1902最新更新时间:2017-02-05 来源: eefocus关键字:Stm32  Bootloader 手机看文章 扫描二维码
随时随地手机看文章

一.        基本概念

1.IAP

IAP是In Application Programming的首字母缩写,IAP是用户自己的程序在运行过程中对User Flash的部分区域进行烧写,目的是为了在产品发布后可以方便地通过预留的通信口对产品中的固件程序进行更新升级。

通常在用户需要实现IAP功能时,即用户程序运行中作自身的更新操作,需要在设计固件程序时编写两个项目代码,第一个项目程序不执行正常的功能操作,而只是通过某种通信管道(如USB、USART)接收程序或数据,执行对第二部分代码的更新;第二个项目代码才是真正的功能代码。

2.Bootloader

在上述IAP的概念中,bootloader就是其第一个项目程序。bootloader主要实现的功能:从串口、USB等媒介接收数据;存储和搬运数据;程序跳转等功能。

3.App程序

对IAP概念中,对第二个项目代码的一种称呼。

4.Ymodem

YModem协议是由XModem协议演变而来的,每包数据可以达到1024字节,是一个非常高效的文件传输协议。

Ymodem一帧数据的结构

第一字节

第二字节

第三字节

Data[0..128]/

Data[0..1027]

倒数第二字节

最后一个字节

SOH/STX

编号

编号反码

有效数据区

CRC校验高位

CRC校验低位

                      图1. Ymodem一帧数据的结构

解释:

第一字节:1.为SOH,有效数据包大小为128字节;

          2.为STX,有效数据包大小为1024字节。

第二字节:数据包的编号,第一帧数据,编号为00。

第三字节:数据包编号的反码,第一帧数据,为FF。

有效数据区:根据第一个字节的内容,有效数据区大小为128字节或1024字节。

倒数第二个字节:CRC校验高位。

最后一个字节:CRC校验低位。

注:参加CRC校验的只有有效数据区。

 

第一帧数据结构:

SOH 00 FF Foo.cNUL[123] CRC(high) CRC(low)

其中:Foo.c为传输文件的文件名;有效数据区的剩余字节用0补足。(就是’\0’).

在超级终端中,在文件名后,还有文件大小的信息。结构为:

SOH00FFFoo.c’\0’+文件字节数+’’+’0’…CRC(high) CRC(low),字节数后为空格。

第二帧,有效数据区内存放的是正式的数据。

 

Ymodem通信协议:略。

二.        Smt32-bootloader设计思路

本bootloader的主要作用是,通过串口进行程序的升级。

1.     Nand flash分区情况

                     图2. 自定义flash分区情况

2.     大致流程

板子开机后,由用户触发进入程序更新界面。

a.通过串口接收上位机发送的bin文件,并存储在分区C。

b.接收完bin文件后,将分区C中的bin文件搬运到分区B,并将搬运的状态保存在分区D。

c.bin文件全部搬运到分区B后,重置中断向量表,并实现程序跳转。

d.如果在步骤b,搬运代码的过程中,出现意外状况,导致搬运中断,则在下次开机后,会再次重新搬运,直到搬运成功。

三.        具体实现

3.1各类设置

1.定义芯片flash大小

方法a.在FlashàConfigure flash tools…àC/C++-àDefine中定义宏,

比如STM32F10X_HD(stm32单片机的内置flash为大容量)

方法b.在stm32f10x.h文件中,

#if !defined (STM32F10X_LD) && !defined (STM32F10X_LD_VL) && !defined (STM32F10X_MD) && !defined (STM32F10X_MD_VL) && !defined (STM32F10X_HD) && !defined (STM32F10X_HD_VL) && !defined (STM32F10X_XL) && !defined (STM32F10X_CL)

#define STM32F10X_HD/*!< STM32F10X_MD: STM32 Medium density devices */

#endif

设置红色的宏。

使用方法a和方法b都可以设置。选择不同的宏,则内嵌的nand flash的总大小及每页的大小是不一样的。并且对于内嵌的nand flash,其擦除是以页为单位的,而不是块。

                  图3. 片内flash大小与宏定义的关系

2.设置程序下载的地址

1.在FlashàConfigure flash tools…àTarget中,

设置IROM1的Start和Size。

2.system_stm32f10x.c文件中,

#define VECT_TAB_OFFSET  0x00000设置中断向量表的偏移地址。(以flash的起始地址为基准)

    所以bootloader程序和app程序的这两个设置都是不一样的。

3.2程序跳转实现

typedef  void (*iapfun)(void);

iapfun  jump2app;

__asm void MSR_MSP(u32 addr)

{

    MSR MSP, r0                      //set Main Stack value

    BX r14

}

voidCloseIQHard(void)

{

         GPIO_DeInit(GPIOA);

         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, DISABLE);  //关使能PA端口时钟

         RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,DISABLE);     //关辅助时能时钟

         __disable_irq();   // 关闭总中断

         //关中断

}

void BootloaderJump2App(uint32_t appxaddr)

{   

         BSPClose();

         CloseIQHard();

    if(((*(vu32*)appxaddr)&0x2FFE0000)==0x20000000)//检查栈顶地址是否合法.

         {

                   jump2app = (iapfun)*(vu32*)(appxaddr+4);    //用户代码区第二个字为程序开始地址(复位地址)            

                   MSR_MSP(*(vu32*)appxaddr);//初始化APP堆栈指针(用户代码区的第一个字用于存放栈顶地址)

                   jump2app();                                                                                //跳转到APP.

         } 

}

在void BootloaderJump2App(uint32_t appxaddr),其中appxaddr为需要跳转到的flash地址。

因为在跳转程序中,将总中断关闭,所以在应用程序中,要将总中断打开。

3.3.程序流程

                  

                             图4.程序流程图

 注:串口下载的具体流程:

    串口接收文件使用Ymodem协议。使用串口中断接收。首先根据第一帧数据判断文件的大小,然后进行flash的擦陈。接收正式数据时,先接收一帧数据并校验,然后在将数据存储到flash中,再接收下一帧数据。

 

四.        注意事项

1.超级终端的使用

a.设置连接选项时,将校验选为“无”,否则可能会收不到数据。

2.串口连接

a.串口要接TX,RX,GND.


关键字:Stm32  Bootloader 引用地址:Stm32 Bootloader整理

上一篇:STM32F4_TIM基本延时(计数原理)
下一篇:STM32 IAP 固件升级设计/U盘升级固件

推荐阅读最新更新时间:2024-03-16 15:32

STM32中断优先级库的使用方式
为什么中断要有优先级 何为占先式优先级(pre-emption priority) 高占先式优先级的中断事件会打断当前的主程序/中断程序运行 抢断式优先响应,俗称中断嵌套。 何为副优先级(subpriority) 在占先式优先级相同的情况下,高副优先级的中断优先被响应; 在占先式优先级相同的情况下,如果有低副优先级中断正在执行, 高副优先级的中断要等待已被响应的低副优先级中断执行结束后才 能得到响应 非抢断式响应(不能嵌套)。 判断中断是否会被响应的依据 首先是占先式优先级,其次是副优先级; 占先式优先级决定是否会有中断嵌套; Reset、NMI、Hard Fault 优先级为负(高于普通中断优先级)且不可调整。
[单片机]
STM32仿真器运行正常,脱离仿真器后无法运行
调试STM32的程序时,发现程序在仿真器环境下运行一切OK,但是固化程序后,程序在完成初始化后就不运行了。 参照网上一些朋友说的检查复位电路、晶振电路、boot0和boot1管脚电平等等都是正常的。 最后发现是由于调试信息引起的:在程序仿真过程中,使用了printf对数据进行打印调试信息,程序运行到printf函数后就不运行了,将调试信息删除后,程序运行正常。 希望对大家能有帮助。
[单片机]
STM32学习探究:流水灯的实现
流水灯的实现 这里我们使用 stm32mini 开发板实现外接流水灯,这里我采用了三个灯(说明问题就可以了)。外接的引脚分别为PA2,PB8,PC13三个引脚,在连接的时候,采用灯的正极接GPIO引脚,负极接GND(这是一种合理的方式)。 注意:虽然接VCC也可以发光,但是这样不是合理的连接方式,而且,发光的情况刚好与接GND的情况相反。 参考的相关资料如下: 时钟使能: 端口配置: 端口输出: 具体实现的代码如下: //led.h文件 #ifndef __LED_H #define __LED_H #include sys.h //LED端口定义 #define LED0 PAout(
[单片机]
<font color='red'>STM32</font>学习探究:流水灯的实现
stm32 灵活静态存储控制器(FSMC)(NORFLASH\PSRAM)
Flexible static memory controller(FSMC) 今天在处理TFT彩屏的时候突然发现有人用FSMC控制器来处理,然后就认真的研究了下FSMC; 可见他分为4个块,三个类型,我们可以根据自己的需要来选择;这次我就直说FSMC 的Block 1; 首先,基地址BASE_ADDR = 6000 0000;至于片选,datasheet上也说了,我们可以通过控制HADDR(27,26)来选择操作; 然后还有今天一直困扰我的问题,我要选择A16,我用的是16位数据,他的数据地址为6000 0000 + 2^16*2 = 6002 0000;我一直都在疑惑:明明是A16,为什么是第17位被置1,后来
[单片机]
<font color='red'>stm32</font> 灵活静态存储控制器(FSMC)(NORFLASH\PSRAM)
9、STM32的PWM的原理与使用(内附代码)
1、PWM是什么? 是脉冲宽度调制,简称脉宽调制。利用微处理器数字输出对模拟电路进行控制的一种有效的技术,就是对脉冲宽度的控制。 这里说的脉冲,就是我们产生的方波。方波就是N个这样的周期连续的产生。 一个周期内高电平持续的时间就是脉冲宽度(脉宽),而PWM(脉冲宽度调制)就是控制一个周期内的高电平的持续时间。 2、简单的PWM的原理示意图 CNT:是当前值寄存器,计数寄存器。 ARR:是自动重载寄存器(初始化设定)。 CCRx:比较值寄存器(TIM_SetCompare1()设定修改占空比)。 假定定时器工作在向上计数PWM模式下: 当CNT CCRx时,引脚输出0,当CNT =CCRx时,引脚
[单片机]
9、<font color='red'>STM32</font>的PWM的原理与使用(内附代码)
【MCP3208/MCP3204】STM32多通道AD采集
芯片简介 MCP3208/MCP3204是一种片外12位精度的AD采集芯片,前者是8通道,后者是4通道,其他的都一样。找不到该芯片的中文手册的点这里。 引脚定义 时序 结合手册5.0章节的说明看时序图。 电平状态稳定时间 可以看到,最短稳定时间的最长的为500ns(0.5us),均小于1us,只要在程序中保证引脚的电平稳定时间至少超过1us即可。 控制位 第一个CS拉低且Din拉高的信号为起始位。紧跟着其实位的是Single/Diff位、以及D0 D1 D2位。 起始位后的第四个时钟周期的上升沿开始采样,在第五个时钟周期的下降沿采样结束。 如果设备上电的时候CS引脚是低电平,需要拉高再拉低
[单片机]
【MCP3208/MCP3204】<font color='red'>STM32</font>多通道AD采集
STM32之bit band 操作理解
Cortex-M3 支持了位操作后,可以使用普通的加载/存储指令来对单一的比特进行读写。   在 CM3 支持的位带中,有两个区中实现了位带。   其中一个是 SRAM 区的最低 1MB 范围, 0x20000000 ‐ 0x200FFFFF(SRAM 区中的最低 1MB);   第二个则是片内外设区的最低 1MB范围, 0x40000000 ‐ 0x400FFFFF(片上外设区中的最低 1MB)。   这两个区中的地址除了可以像普通的 RAM 一样使用外,它们还都有自己的“位带别名区”,位带别名区把每个比特膨胀成一个 32 位的字。当你通过位带别名区访问这些字时,就可以达到访问原始比特的目的。   CM3 使用如下术语来表示
[单片机]
STM32低功耗唤醒方式
MCU进入低功耗之后,以极低的功耗维持着系统“活着”,但是醒过来是需要一定条件的,比如定个“闹钟”,按键“按一下”等,目前常用的“正常的”唤醒方式有以下几种: 1、RTC定时唤醒; 2、外部中断唤醒(按键或者通讯唤醒); 3、特殊唤醒引脚唤醒(某些引脚具有专门的唤醒功能)。 下面,我们再来看一看如何通过RTC和外部中断唤醒MCU。 1、RTC定时唤醒 依然是从手册中我们可以看到,所有的RTC时间都可以把MCU从低功耗模式中唤醒: 介绍使用RTC的定时功能实现,定时1S唤醒一次,使用cubemx进行对RTC进行配置: 生成代码的时候,勾选这个选项,可以把不用的引脚配置为模拟输入模式,降低功耗: RTC的配置如图,使能RTC,
[单片机]
<font color='red'>STM32</font>低功耗唤醒方式
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved