[STM32]HAL库实现自己的BootLoader-BootLoader与OTA-STM32CUBEMX

devtools/2025/1/22 9:02:42/

目录

一、前言

二、BootLoader

三、BootLoader的实现

四、APP程序

五、效果展示

六、拓展


一、前言

        听到BootLoader大家一定很熟悉,在很多常见的系统中都会存在BootLoader。本文将介绍BootLoader的含义和简易实现,建议大家学习前掌握些原理基础。

二、BootLoader

        Boot系统即设备启动时优先运行的程序,可以帮助我们选择进入哪一个系统。在电脑中,Boot系统也是十分重要的,系统的基础功能和引导功能都是有Boot实现的。

        而Loader即载入系统,载入用户真正使用的系统。

        系统上电后,先进入Boot程序,由Boot程序决定进入系统,还是等待用户指令。以单片机为例,假设其Flash为20K,那么我可以将其分为两个区域,一个区域用于存储Boot程序,一个区域用于存储应用程序(APP),而Boot程序只烧写一次,用户烧录APP程序时,仅擦除APP区域。

        Boot程序作为独立的单片机程序,当然也可以完成擦除和写入Flash的功能,如果我们在Boot程序运行时,将APP对应的Flash信息发送给Boot程序,由Boot程序对Flash中的APP区的擦除和写入,那是不是同样能实现烧写程序的功能。

        如果将发送方式改为蓝牙、WIFI等无线形式,是不是就能对APP程序实现远程烧写。既然远程烧写能够实现,那么远程升级的功能应运而生,这就是OTA(On The Air)。

三、BootLoader的实现

        配置基础的STM32CUBEMX工程,此处选用芯片为STM32F103C8T6.

        此处我只配置了一个串口(波特率256000,自定),用于输出调试信息,并使能DMA和中断。

        打开项目工程。此处STM32F103C8T6的Flash为64K,其实地址为0x08000000,则Flash范围为0x0800 0000~0x0800 FFFF,此处我划Boot分区16K,APP分区48K,则Boot分区Flash范围为:0x0800 0000~0x0800 3FFF,Size = 0x4000。

        按照下图配置。

        如果你使用ST-Link或者其他烧写器的话,在Boot程序工程中要勾选全部擦除

        此时,我们让设备等待三秒,随后进入APP。

__asm void MSR_MSP(uint32_t addr)
{MSR MSP, r0BX r14;
}void App_Loading(void)
{APP_FUNC Jump;//定义一个函数指针printf("\n%x\n",(*(uint32_t *)APP_ADDR)&0x2FFFFFFF);// 栈顶地址是否合法if(((*(uint32_t *)APP_ADDR)&0x2FFFFFFF) < (0x20000000+0x400 * RAM_SIZE)){printf("Start To APP");//设置栈指针 MSR_MSP(APP_ADDR);// 获取复位地址Jump=(APP_FUNC)*(volatile uint32_t *)(APP_ADDR+4);	//设置栈指针__set_MSP(*(volatile uint32_t *)APP_ADDR);//关闭所有中断__set_PRIMASK(1);// 跳转至APP Jump();}else{printf("Address Not Found");}
}

        将程序烧写进单片机,Boot程序就已经下载完成了。

        注意,使用printf函数需要重写fputc并且勾选MicroLib。

#include "stdio.h"int fputc(int c, FILE* stream)
{uint8_t ch[]={c};HAL_UART_Transmit(&huart1,ch,1,0xffff);return c;
}

四、APP程序

        在自己定制的BootLoader中,APP的程序与日常使用的程序有些许不同,由于在BootLoader中我们更改了一些参数配置,为了能够顺利跳转到APP程序中。但这些配置需要恢复才能让APP程序正常运行。

        使用STM32CUBEMX生成一个LED闪烁的程序,使用Keil打开工程。

        先配置程序烧写区域,上述中Boot区域占16K,因此APP程序起始地址为0x0800 4000 ,APP程序48K,即Size = 0xC000。

        有ST-LINK的情况下,需要设置烧写模式为仅擦除训选择区域,防止擦除Boot程序。

        随后在main.c中main函数中添加这两条语句。

	//SCB ->VTOR = FLASH_BASE | OFFSET;SCB ->VTOR = FLASH_BASE | 0x4000;__set_PRIMASK(0);

五、效果展示

        将单片机程序烧写进板子后,打开串口助手,并观察效果。

        观察到单片机顺利进入APP程序,并且实现了交替闪烁。

六、拓展

        大家可以添加菜单模式,比如通过串口收到某个指令随后进入菜单模式,实现擦除或者其他操作。我实现了一小部分,大家可以看看。源码不需要积分。

        本文仅帮助快速实现BootLoader,具体原理讲解将在另一篇博文进行。

        BootLoader源工程:BootLoader

        APP源工程:简易APP配套BootLoader


http://www.ppmy.cn/devtools/90763.html

相关文章

Elastic 利用由 Search AI 提供支持的自动导入功能加速 SIEM 数据导入

作者&#xff1a;来自 Elastic Jamie Hynds, Mark Settle Elastic 正在通过自动导入功能自动完成 SIEM 数据导入&#xff0c;从而加速采用 AI 驱动的安全分析。这项新功能&#xff08;安全分析或 SIEM 解决方案中独一无二的功能&#xff09;可自动开发自定义数据集成。Elastic …

nginx负载聚能

一、负载均衡 早期的网站流量和业务功能都比较简单&#xff0c;单台服务器足以满足基本的需求&#xff0c; 但是随着互联网的发展&#xff0c;业务流量越来越大并且业务逻辑也跟着越来越复 杂&#xff0c;单台服务器的性能及单点故障问题就凸显出来了&#xff0c;因此需要多台服…

在stm32f103vc板上的复位按键,如何用c程序模拟按下操作

在STM32F103VC或其他STM32微控制器上&#xff0c;直接通过C程序模拟复位按键的按下操作实际上是不可能的&#xff0c;因为复位按键通常直接连接到微控制器的复位引脚&#xff08;NRST&#xff09;&#xff0c;而这个引脚是硬件级的&#xff0c;不直接受软件控制。复位引脚用于将…

细说文件操作

你好&#xff01;感谢支持孔乙己的新作&#xff0c;本文就文件操作与大家分享我的思路。 希望能大佬们多多纠正及支持 &#xff01;&#xff01;&#xff01; 个人主页&#xff1a;爱摸鱼的孔乙己-CSDN博客 目录 1.什么是文件 1.1.程序设计文件 1.1.1.程序文件 1.1.2.数据文…

一、安装go环境以及编译输出HelloWorld

目前的热门技术方向从分布式微服务开始转向云原生而云原生方向需要掌握GO语言&#xff0c;基于此决定利用平时的时间来完成GO语言的学习。 安装&#xff08;基于mac m1&#xff09; &#xff08;翻看了网上很多的资料&#xff0c;发现很多人记录的有很多问题&#xff0c;一个…

图论-最小生成树

Prim算法 算法描述 dist[i]<-- for(i 0;i<n;i) t<--找到集合外最近的点 用t更新其他点到集合的距离&#xff08;这个集合就是已经确定的最小生成树的点和边&#xff09; st[t] true; dist[i] <-- 无穷 这一步是初始化所有节点到集合的最小距离为无穷大。dist[i] 表…

Harbor 仓库一键安装

文章目录 一、场景说明二、脚本职责三、参数说明四、操作示例五、注意事项 一、场景说明 本自动化脚本旨在为提高研发、测试、运维快速部署应用环境而编写。 脚本遵循拿来即用的原则快速完成 CentOS 系统各应用环境部署工作。 统一研发、测试、生产环境的部署模式、部署结构、…

Python 如何进行Web抓取(BeautifulSoup, Scrapy)

Web抓取&#xff08;Web Scraping&#xff09;是一种从网站提取数据的技术。Python有许多用于Web抓取的库&#xff0c;其中最常用的是BeautifulSoup和Scrapy。 BeautifulSoup BeautifulSoup是一个用于解析HTML和XML文档的Python库&#xff0c;适合处理简单的Web抓取任务。它将…