STM32的BootLoader 从SD卡更新固件

本文详细介绍了如何为STM32 Cortex-M3单片机编写BootLoader,实现从SD卡更新固件。内容涵盖BootLoader的基本概念、中断向量表、栈指针、复位向量、Flash操作及文件系统的使用。通过理解M3内核启动过程,设置栈指针和重定位中断向量表,实现从SD卡读取bin文件并写入Flash,最后跳转到新程序执行。
摘要由CSDN通过智能技术生成
预备知识 我们这里是为ARM的Cortex-M3单片机写的BootLoader,需要了解一下M3内核的架构,并且要了解M3单片机是怎么启动的等等。这个方面的知识,可以参考《Cortex-M3权威指南》,这里的话我只是为了实现BootLoader简单介绍一下,大家有什么不清楚的请参考权威指南。并且这里是以STM32为例说明问题的,使用的开发环境是RVMDK(Keil)。
  这里参考的是《Cortex-M3权威指南》的3.8节,复位序列。
  M3单片机复位后,从0x00000000取栈指针(SP), 从0x00000004取复位向量(PC),有了栈指针和复位向量后,单片机就按照正常流程运行了,在BootLoader里面,我们更新完程序后需要做的步骤之一就是设置栈指针,跳转到复位向量。
  栈是一种数据结构,后进先出LIFO。借用百度百科的解释:栈由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。它使用的是一级缓存,他们通常都是被调用时处于存储空间中,调用完毕立即释放。
  复位向量是一个函数地址,在Cortex M3单片机里是复位函数的地址。也就是单片机启动后第一个执行的函数。
  这里参考《Cortex-M3权威指南》的7.3节,向量表。
  BootLoader是一个完整的程序,下载的新程序(以下称为App)也是一个完整的程序。都包含中断向量表,所以的话,我们是有两个中断向量表,相信因为有两个向量表,大家都知道我们应该需要对这两个向量表做点什么吧。
  的中断向量表 我们只看前16个向量,因为其余的向量属于外设使用,与Cortex M3内核无关。
  __Vectors DCD __initial_spTop ; Top of Stack
  DCD Reset_Handler ; Reset Handler
  DCD NMI_Handler ; NMI Handler
  DCD HardFault_Handler ; Hard Fault Handler
  DCD MemManage_Handler ; MPU Fault Handler
  DCD BusFault_Handler ; Bus Fault Handler
  DCD UsageFault_Handler ; Usage Fault Handler
  DCD 0 ; Reserved
  DCD 0 ; Reserved
  DCD 0 ; Reserved
  DCD 0 ; Reserved
  DCD SVC_Handler ; SVCall Handler
  DCD DebugMon_Handler ; Debug Monitor Handler
  DCD 0 ; Reserved
  DCD PendSV_Handler ; PendSV Handler
  DCD SysTick_Handler ; SysTick Handler
  __initial_spTop就是栈指针,Reset_Handler是复位向量。这里只显示了16个向量,CortexM3单片机的话总共有256个向量,也就是从栈指针的地址开始有1KB的区域属于中断向量表。
  单片机启动默认先运行BootLoader,所以默认的中断向量表位置是BootLoader的中断向量表。为了App可以正常运行,下载完App后,我们还需要把中断向量表重新定位到App程序那里。根据《Cortex M3权威指南》,介绍一下怎样重定位中断向量表。
  Cortex-M3单片机有一个管理中断向量表的寄存器,叫做向量表偏移量寄存器(VTOR)(地址:0xE000_ED08)。具体可以看看截图:
   pic
  STM332程序的起始地址一般在0x08000000。所以BootLoader程序是在0x08000000,不是在0x00000000是因为STM32的重映射技术(不符合Cortex-M3的设计,有点搞另类的感觉)。所以BootLoader的中断向量表在0x08000000那里。如果我们的App程序起始地址在0x08070000,并且App的中断向量表在起始地址,那么BootLoader程序下载App后,为了App程序能正确运行,开始App程序的运行后第一步,就要把中断向量表重定位到0x08070000那里。
  具体实现下面会再介绍,接下来介绍分散加载文件相关内容。
  这一节涉及的内容主要属于分散加载文件,大家具体上网了解,这里只是介绍了能够实现BootLoader的一小部分。
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 现代嵌入式系统大量使用SD卡存储数据,但在大量数据存储在SD卡上时,需要保证SD卡的文件系统稳定压缩。通常,我们使用Bootloader程序实现SD卡Firmware升级功能,该程序支持从SD卡获得启动信息,进而读取Firmware文件更新系统。在本文中,我们将详细介绍STM32F407 SD卡升级Bootloader程序下载。 1. 准备材料:  STM32F407核心板;  USB转串口模块;  SD卡 FAT32文件系统; 2. 确定SD卡Firmware文件格式: Firmware文件应该是整个程序代码和堆的BIN文件格式,用于升级整个系统软件。 3. 配置系统引导文件: 使用STMCubeMx或其他软件将Bootloader程序配置为系统引导文件,启动时首先加载它。 4. Bootloader程序下载准备工作: 在F407的SDIO1端口运行Bootloader程序,将Flash扇区1准备成一个Firmware更新的接收数据块。 5. SD卡下载: 从SD卡中打开Firmware文件夹查找Firmware更新程序(含APP压缩包在内),启动STM32F407 Bootloader程序从SD卡中读取整个文件,将文件传输至Flash扇区1。升级过程通常需要等待一段时间。 6. 启动更新程序: 在更新完成后重新启动针对新Firmware更新程序,观察系统是否正常运行,APP程序更新后的状态是否与预期一致。 7. 完整性检查: 确定存储在SD卡上的Firmware文件的大小以进行检查,确认每次更新时文件的大小以及完整性。此外,应检查当前正在运行的Firmware版本,以确认其是Firmware更新后的最新版本。 以上是关于STM32F407 SD卡升级Bootloader程序下载的详细步骤,需要工程师们按照步骤进行升级,以确保整个系统在Firmware更新后的可靠性,有效提升嵌入式系统的稳定性和确保可靠性,同时避免因硬件损坏或数据丢失而造成的混乱和损失。 ### 回答2: STM32F407是一款易于使用的高性能微控制器,可以进行SD卡升级Bootloader程序下载。在进行升级和下载之前,需要先下载相应的编译器和ST-Link工具。接下来,按照以下步骤进行操作: 1. 在SD卡中添加升级文件,如固件文件。 2. 在ST-Link工具中选择"Firmware Upgrade"选项,点击"Connect"按钮连接STM32F407芯片。 3. 确认芯片型号和FLASH大小并进行擦除。 4. 选择"Program and Verify"选项,并选择升级文件进行下载。 5. 点击"Start"按钮开始下载。 下载完成后,可以进行Bootloader程序的下载。首先需要建立一个新项目,将Bootloader程序添加进去,并进行编译。接下来,将STM32F407芯片连接到ST-Link工具中,选择"Connect"选项,然后点击"Program and Verify"选项进行下载。完成后,可以重启设备并测试Bootloader程序是否正常运行。 总的来说,STM32F407的SD卡升级Bootloader程序下载过程相对较为简单,只需要按照以上步骤进行操作即可。其中需要注意的是,在下载过程中不能中断电力供应,否则可能会导致芯片损坏。 ### 回答3: 在使用STM32F407微控制器的开发板进行SD卡升级时,需要先将Bootloader程序下载到板子中。Bootloader程序允许在初次启动时进行SD卡升级,这可以利用SD卡更新控制器的固件,使得系统更稳定、更可靠。 下载Bootloader程序的方法有很多种,可以通过ST-Link V2下载器,也可以通过串口下载程序。使用ST-Link V2下载器可以通过JTAG/SWD接口将Bootloader程序下载到系统中,需要注意的是,在下载时需要选择正确的程序烧录地址。 如果使用串口下载程序,则需要在Bootloader程序中添加一个串口下载器的协议,并将该程序编译到系统中。此时,我们需要将升级文件打包成一个.bin等二进制格式的文件,并通过串口将其发送给Bootloader程序进行升级,具体操作步骤可以参考相应的程序开发文档。 总结来说,SD卡升级Bootloader程序的下载主要有两种方式,一是通过ST-Link V2下载器进行下载,二是通过串口将程序编译到系统中并进行升级。在具体实现过程中,需要注意选择正确的烧录地址,并严格按照开发文档操作,确保升级过程顺利完成。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值