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设计(YModem协议) (转)
源:stm32 Bootloader设计(YModem协议) 相信很多人都希望,不开盖就可以对固件进行升级吧,就像手机那些.下文中的bootload就来实现这样的功能. 前段时间有项目关于Bootlo ...
- STM32 Bootloader基于ymodem传输协议串口IAP升级详解
硬件:stm32f103cbt6 软件:STM32F10x_StdPeriph_Lib_V3.5.0 文章目录 1 预备知识 2 Bootloader 2.1 启动流程 2.2 校验跳转地址是否有效 ...
- STM32 BootLoader升级固件
一.知识点 1.BootLoader就是单片机启动时候运行的一段小程序,这段程序负责单片机固件的更新,也就是单片机选择性的自己给自己下程序.可以更新,也可以不更新,更新的话,BootLoader更新完 ...
- stm32最简单的实现BootLoader
BootLoader大家应该都知道是干什么的,简单的来说就是程序开始运行前的一段程序. 在成熟的产品中,通常都是采用BootLoader方式来升级产品的程序.也就是IAP升级.在了解完基本的实现原理后 ...
- 【STM32系列汇总】小白博主的STM32实战快速进阶之路(持续更新)
我把之前在学习和工作中使用STM32进行嵌入式开发的经验和教程等相关整理到这里,方便查阅学习,如果能帮助到您,请帮忙点个赞: 本文的宗旨 STM32 只是一个硬件平台,同样地他可以换成MSP430,N ...
- STM32f4 ARM Bootloader
参考资料: 基于ARM 的嵌入式系统Bootloader 启动流程分析 Bootloader 详解 ( 代码环境 | ARM 启动流程 | uboot 工作流程 | 架构设计) Android系统启动 ...
- Ymodem协议(参考STM32)
相信很多人都希望,不开盖就可以对固件进行升级吧,就像手机那些.下文中的bootload就来实现这样的功能. 前段时间有项目关于Bootload设计.所以就仔细的去了研究了一翻.以前都是用的stm32官 ...
- 如何使用STM32F4的BootLoader和APP程序
源:如何使用STM32F4的BootLoader和APP程序 STM32 BootLoader升级固件
- stm32-arduino-f103
希望给工作中偶尔要用的一些辅助板卡(例如运行信息现场记录)找一个快速开发的手段,Arduino作为流行的开源嵌入硬件框架,组件丰富,资料众多,所以想以Arduino作为平台.但是Arduino板子基本 ...
随机推荐
- 【NOIP2007提高组】字符串展开
[题外话]这道题纯粹考验耐心,某些经常调程序调到摔键盘的人可以尝试 [题外话2]除了考耐心以外完全没有什么难点 [题外话3]也许会稍微恶心一点? [题外话4]其实我是在别人军训的时候滚来更博客的简直2 ...
- 谷歌浏览器js debug
- Linux 抓包命令
可使用如下命令,在Linux系统上进行抓包命令 tcpdump -n -i eth0 tcp port and host 192.168.9.45 -w ./filename.cap 说明: eth0 ...
- Docker私有仓库3
http://www.cnblogs.com/womars/p/5906435.html(上篇地址) 三.测试上两篇 #测试一下 [root@lh- data]# pwd /opt/data [roo ...
- Hihocoder 2月29日
时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定两个日期,计算这两个日期之间有多少个2月29日(包括起始日期). 只有闰年有2月29日,满足以下一个条件的年份为闰年 ...
- Gentoo安装详解(三)-- 配置系统
配置系统 系统信息: 文件系统信息: 创建/etc/fstab nano -w /etc/fstab 网络信息: Host name, Domainname, etc nano -w /etc/con ...
- OR查询
OR查询包含:$or和$in $or可以在多个键中查询任意给定的值:$in可以指定不同类型的条件和值. 查询MasertID小于3或者MasterSort等于3的文档: db.SysCore.find ...
- 动态封杀与解封IP
不论IIS6还是IIS7 都可以把需要封杀的IP加入封杀列表.但是需要注意的是我们代码写的是全部替换原先的数据.但是在IIS7下,执行的效果是原先的不替换,新加一批封杀 IP.当然IIS7下,如果新加 ...
- HIVE 简单总结
hive 1 table 查看 表show tables;查看表结构desc table_name; 2 database 默认 default 创建databasecreate database_n ...
- hdu 5524 二叉树找规律,二进制相关
input n 1<=n<=1e18 output 有n个结点的满二叉树有多少个不相同结点数的子树 做法:树有h=log2(n)层,最多有2h-2种(1除外),然后再n减去u重复的即可 # ...