datasheet

STM32 YMODEM实现bootloader

2019-06-14来源: eefocus关键字:STM32  YMODEM  bootloader

这几天一直在尝试学STM32 bootloader,在网上查阅了一番,发现实现方法不计其数。于是自己有了想动手实现一番的欲望。


下面请听我细细道来,我选用的芯片是STM32F103ZE系类,该芯片是512k,每页是2k的。


接下来就是你要重点了:


其实bootloader说白了,就是在原有APP程序 再加上另一段程序---bootloader,这个bootloader可以对你flash进行擦写操作。


那么关于STM32具体实现BOOTLOADER步骤是怎么样的呢?


下面我就具体几个细节之处谈谈:


1,如何实现在APP程序跳转到BOOTLOADER程序.


2,既然APP程序可以跳转到bootloader,那么反之也是可以的。

 

//判断用户是否已经下载程序,因为正常情况下此地址是栈地址。

//若没有这一句的话,即使没有下载程序也会进入而导致跑飞。

if (((*(__IO uint32_t*)ApplicationAddress) & 0x2FFE0000 ) == 0x20000000)

{

    SerialPutString("Execute user Programrnn");

    //跳转至用户代码

    JumpAddress = *(__IO uint32_t*) (ApplicationAddress + 4);

    Jump_To_Application = (pFunction) JumpAddress;

 

    //初始化用户程序的堆栈指针

    __set_MSP(*(__IO uint32_t*) ApplicationAddress);

    Jump_To_Application();

}

else

{

    SerialPutString("no user Programrnn");

}


3,设计bootloader程序,采用YMODEM协议,一次数据1024字节、需要在keil进行设置ROM1,下载utilities也设置一下,然后download。


4,设计好bootloader程序并且用仿真器烧录到芯片之后,下面就开始设计APP程序,所需设置也是大同小异,只是将STARTADDRESS 设置成从 0800 0200 size只要不超过你整个flash剩下的区域即可


,还需要设置一点的是,产生bin文件,这里我教大家一个方法  @p.bin就是说项目名来作为bin文件名,axf也一样。假设我项目名是BOOT-Y,那么你生成的bin文件就是这个名字


5.,接下来用SECURECRT软件进行程序app的bin文件烧录,我boot程序里面有设计了一个按键,就是你是进入到boot程序还是app程序,当然你app程序如果没有的话,那么就需要在这里进行校验了。如果按键按住,然后复位,那么程序就进入到刚才的boot区域,这里是一个串口菜单,有一个函数捕获你的按键输入字符。


/*******************************************************************************

  * @函数名称 GetKey

  * @函数说明   通过超级中断回去键码

  * @输入参数   无

  * @输出参数   无

  * @返回参数   按下的键码

*******************************************************************************/

uint8_t GetKey(void)

{

    uint8_t key = 0;

 

 

    //等待按键按下

    while (1)

    {

        if (SerialKeyPressed((uint8_t*)&key)) break;

    }

    return key;

 

 

}



6、下面就是boot的串口菜单,你输入1,加载bin文件,点击transfer的send-ymodem,然后选择你的bin文件,接下来就是1024字节数据开始发送到串口缓存区,如果校验正确的话,那么就会写入到对应的flash当中。




7、看到没?成功了!


(7.1)、

忘记说了,APP程序里面需要在 在system_stm32f10x.c文件的128行处 #define VECT_TAB_OFFSET 0x2000 /*!< Vector Table base offset field.  将中断向量表的偏移量改成你APP程序flash地址偏移量, 这个非常关键,因为你BOOT的中断和APP中断不能是同一个! 否则会出事的!


关键字:STM32  YMODEM  bootloader

编辑:什么鱼 引用地址:http://www.eeworld.com.cn/mcu/ic464669.html
本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:基于Ymodem协议的STM32F407的串口IAP
下一篇:stm32 Bootloader设计(YModem协议)

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

学习STM32CubeMX与HAL库吐槽

最近因为一个小项目(智能穿戴),用到了STM32L0(低功耗 Cortex M0)系列的MCU,查了官网,居然没有提供固件库,只有HAL库,于是STM32CubeMX生成了HAL库的工程,学习HAL的使用:STM32CubeMX与HAL库的优点:1、降低了使用外设的门槛,所有时钟设置等一目了然。2、统一了代码的架构、风格,让源代码的可读性“保底线“提高。吐槽如下:1、工程的架构很死了,只能在框框条条里填写内容,这完全违背了C程序员们的习惯。例如,要自己加上OS,代码结构会很难看。2、但一但遇上了坑,就无法解决。3、依赖性更高了,而且这工具有BUG,例如:在生成代码时,终止STM32CubeMX,所有源代码会全部消失,自己写的代码
发表于 2019-06-18

STM32CubeMx(Keil5)开发之路——1配置第一个项目

运行环境Windows10STM32CubeMX___Version 5.0.0Keil5(MDK5)___Version 5.15简介本例程主要搭建第一个项目,并且完成最基本的项目所需配置,后续的教程都基于这篇教程。STM32CubeMx配置新建项目搜索自己芯片的型号点击选择封装形式选择外部晶振可以根据需求调节各个总线的时钟频率(就具体情况而定)DEBUG选项选择"Serial Wire"(4线烧录,CLK,DIO,VCC,GND)你会看到芯片引脚会占用这几个引脚,就是烧录用的CLK和DIO点击"Project Manager"修改项目名称修改项目保存路径选择编写工具(我使用Keil5
发表于 2019-06-18
STM32CubeMx(Keil5)开发之路——1配置第一个项目

STM32CubeMX(Keil5)开发之路——9设置微秒级别的延时

运行环境Windows10STM32CubeMX___Version 5.0.0Keil5(MDK5)___Version 5.15简介本例程主要讲解如何对芯片内的Flash进行读写,用芯片内部Flash可以对一些需要断电保存的数据进行保存,无需加外部得存储芯片,本例程采用的是STM32F103ZET6,512K大小的Flash。STM32CubeMx基本配置基础配置过程请参考 STM32CubeMx(Keil5)开发之路—配置第一个项目printf重定向例程请参考 STM32CubeMx(Keil5)开发之路——3发送USART数据和printf重定向STM32CubeMx PWM配置1——点击TIM3进行设置2——选择
发表于 2019-06-18
STM32CubeMX(Keil5)开发之路——9设置微秒级别的延时

STM32CubeMX(Keil5)开发之路——7输出PWM

运行环境Windows10STM32CubeMX___Version 5.0.0Keil5(MDK5)___Version 5.15简介本例程主要讲解如何设置PWM这只输出4路PWM信号STM32CubeMx基本配置基础配置过程请参考 STM32CubeMx(Keil5)开发之路—配置第一个项目STM32CubeMx PWM配置1——点击TIM2进行设置2——4个Channel都选择 “PWM Generation CHx” 选项3——预分频值填72-1即714——自动重装载值设置为100-1也就是995——会看到相应的输出管脚PA0——PA3就是PWM的输出管脚讲解:PWM波的频率=时钟频率/(预分频+1)/(自动重装载值
发表于 2019-06-18
STM32CubeMX(Keil5)开发之路——7输出PWM

关于STM32像EPROM一样可以单字节写内部Flash的理解

都有说STM32的内部Flash可以像EPROM一样操作,单个字节单个字节的写入。根据本人的拙见,其实也就仅仅是“像”而已。原因有以下几点:1.首先Flash这种东西,其写入数据的原理是便是将1变成0,所以你的某地址Flash一旦已经写过数据而且不为0,则当你再次需要向该地址写数据时,必须要先擦除,即把该地址先全部变成1,否则你将数据写入该地址后,基本上该地址里面的值已经不是你写入的值了。2.STM32对内部Flash有页(1k或者2K)擦除指令,也就是STM32不能单独对某一个或者某几个字节进行擦除。而擦除操作并不需要大量内存。3.如果要像EPROM一样操作Flash,其原理是先把该一页里面的数据全部读到一个buf里面,如果
发表于 2019-06-18

STM32的ISP升级详解

最近在做一个给STM32用ISP升级的项目,接触到STM32厂家烧录的Bootloader工作流程,具体官方文档稍后上传供大家参考,也可去ST官网下载文档。接下来针对文档中部分内容分析其工作过程:一、要进入该模式,需把STM32硬件上的BOOT0引脚拉高(置1),BOOT1拉低(置0),对此部分不明白的可以查阅STM32BOOT引脚的资料(网上一搜一大堆),不过多阐述。两个引脚配置好对STM32复位,其在4个时钟周期内会自动检测BOOT引脚相应的配置情况,进入相应模式(原厂Bootloader模式)下工作,此时已经到达此次旅行的起点——USART Bootloader 模式此处要特别注意的是硬件上一定要用原厂规定的串口才能完成
发表于 2019-06-18
STM32的ISP升级详解

小广播

何立民专栏

单片机及嵌入式宝典

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

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2019 EEWORLD.com.cn, Inc. All rights reserved