0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何快速将BootLoader与APP固件合并

Q4MP_gh_c472c21 来源:CSDN博客 作者:Acuity. 2021-09-24 14:19 次阅读

1、前言嵌入式固件一般分为BootLoader和App,BootLoader用于启动校验、App升级、App版本回滚等功能,BootLoader在cpu上电第一阶段中运行,之后跳转至App地址执行应用程序。

因此,在发布固件的时候,会存在BootLoader固件和App固件;此时我们期望是将BootLoader固件和App固件合并成为一个固件,这样在量产时只需烧录一次即可。

2、传统方式一些传统的方法都是“土办法”,没什么毛病,但比较繁琐。项目种类增加,或者版本发布频繁时更加体现出繁琐性,且易出错,操作稍微失误可能导致固件不完整;烧录不完整的固件,机子变“砖头”。

烧录两次,分别烧录BootLoader和App固件

烧录固件到芯片后,再从芯片读取固件,另存为hex文件

手动复制、合并固件

BootLoader支持App固件传输功能的,只烧录BootLoader,后期再升级App

3、高效方式我们目标是通过自动化脚本合并生成一个发布固件,提高效率和确保固件的完整性。

3.1 合并文件

Linux下的脚本我们用得很多,其实Windows的脚本也非常优秀,利用Windows的脚本可以快速实现增、删、查、改文件。常用Windows脚本命令如下。

合并两个文件:copy /b

重命名文件:ren 《source_file》 《dect_file》

删除文件:del

很显然,我们利用其合并命令,只需一条指令即可将BootLoader和App文件合并。

假设当前目录存在Boot.bin和App.bin文件,合并后文件命名为Firmware.bin。

copy /b .Boot.bin + .App.bin Firmware.bin

注:Windows的目录路径为反斜杠,与Linux不同。

❞3.2 bin转hex

我们知道,二进制(bin)文件是不存在地址信息的,cpu上电执行并不一定是从地址0开始执行代码,如STM32芯片起始执行地址为0x8000000。

因此不能通过串口工具烧录bin文件,只能通过J-link或者ST-link烧录,并且在烧录前指定存储起始地址。因此,将bin文件转换为hex文件是有必要的。

「bin转hex方式:」

使用jflash工具,把合并后的bin文件,使用jflash打开,另存为hex格式文件

将bin文件烧录置芯片,读取出来,另存为hex文件

自己动手写一个bin转hex工具

借助第三方bin转hex工具前两者太繁琐,效率低下;第三个比较灵活,但需要花点时间;如果使用优秀的现成工具是最快捷的办法。推荐使用“srec_cat.exe”工具,可以结合Windows脚本一起使用。

3.2.1 srec_cat工具

srec_cat一个功能非常强大的文件合并、转换工具,支持功能众多,包括:

文件合并

文件分割

bin转hex

hex转bin

数据填充

CRC校验

此外,还存在srec的系列工具,文件比较工具 srec_cmp.exe和文件信息查看工具 srec_info.exe,可以从文章后面官方网站下载使用。

「文件合并」

命令格式:

srec_cat.exe 《源文件0》 《文件类型》 《源文件1》 《文件类型》 《目标文件》 《文件类型》

例子:

srec_cat.exe source0.bin -Binary source1.bin -Binary -o merge.bin -Binary

srec_cat.exe source0.hex -Intel source1.hex -Intel -o merge.hex -Intel

如果BootLoader和App生产的文件为hex格式,可以直接使用该命令合并为一个hex文件,注意地址的连续性。

「bin转hex」

命令格式:srec_cat.exe 《bin源文件》 《-Binary》 《-offset》 《偏移地址》 《-Output》 《hex目标文件》 《-Intel》

例子:

将Boot.bin和App.bin合并的Firmware.bin转换为hex格式文件。

srec_cat.exe Firmware.bin -Binary -offset 0x8000000 -o Firmware.hex -Intel

0x8000000,是STM32的起始执行地址。

更多的srec应用和工具下载详见官方网站:

http://srecord.sourceforge.net/download.html

❞3.3 完整示例

第一步,在需要生成固件目录新建一个txt文件。

第二步,键入如下内容(Boot固件和App固件可以指定目录)。

copy /b .Boot.bin + .App.bin Firmware.bin

srec_cat.exe Firmware.bin -Binary -offset 0x8000000 -o Firmware.hex -Intel

del Firmware.bin

第三步,重命名txt文件为“.bat”后缀文件,即是Windows可执行脚本的文件类型。

第四步,双击运行脚本,即可生成目标文件。

出现任何目标文件生成失败的情况,检查相关源文件是否存在,路径是否正确。

3.4 举一反三

以此类比,存在多个App文件的情况,可以通过该方式分别进行合并出一个固件。另外,实际项目中,经常会使用内部flash空闲扇区保存一些设备参数信息,如校准系数、设备地址、序列号等信息。

我们可以将参数信息保存为一个bin文件,通过该方式和固件合并,这样量产时将参数和固件一并写入,提高生产效率!

来源:https://acuity.blog.csdn.net/article/details/106724373

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    5068

    文章

    19019

    浏览量

    303292
  • APP
    APP
    +关注

    关注

    33

    文章

    1568

    浏览量

    72376

原文标题:一个高效的BootLoader与APP固件合并方法

文章出处:【微信号:gh_c472c2199c88,微信公众号:嵌入式微处理器】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    自定义RISC V的bootloader-v2

    在生成SoC时,会生成一个预定义bootloader .bin文件,用于指定soc的工程运行的地址,这包括在flash的存储地址 ,加载到外存中的运行地址及在外存中分配的存储空间的大小 。下面我们
    的头像 发表于 10-31 12:37 515次阅读
    自定义RISC V的<b class='flag-5'>bootloader</b>-v2

    GD32F427 bootloader添加rt-thread系统后,跳转到app没有执行main()函数是怎么回事?

    MCU:GD32F427 bootloader是自己写的 裸机使用没问题,可以正常转跳到APP上,执行main() 在APP上移植了rt-thread操作系统 启动的时候可以打印出logo,但是
    发表于 07-11 06:31

    使用TC387做bootloader,程序从bootloader跳转到APP运行43s后卡死,哪些原因导致的?

    已知APP程序和bootloader程序单独运行无异常,两个程序一模一样 修改lsl文件的内存地址后,在bootloader程序添加跳转语句,跳转到app程序执行43s后卡死,跳转前已
    发表于 07-04 07:37

    请问keil编写的BootLoader可以跳转到GCC编写的APP里吗?

    keil编写的BootLoader 可以跳转到 GCC编写的APP里吗?
    发表于 04-18 07:00

    bootloader开多线程做引导程序,跳app初始化后直接进hardfualt,为什么?

    如标题,想做一个远程升级的项目,bootloader引导区域和app都是开多线程跑的,就是自己写了个小的任务调度器,没什么功能主要是想让程序快速的响应,延时不会对其他程序造成堵塞,程序测试
    发表于 04-18 06:07

    APP程序中加入__set_FAULTMASK(1),通过bootloader下载后跳转APP会卡死的原因?

    为什么我在APP程序中加入__set_FAULTMASK(1);NVIC_SystemReset(); 生成BIN文件,然后通过bootloader下载后 跳转APP会卡死, 但是把
    发表于 04-07 07:40

    bootloader设置APP在0x08020000为开始地址,编译报错怎么解决?

    bootloader 想设置APP在0x08020000为开始地址,但是编译报错。同时如何在IDE中设置调试debug地址和相关设置,谢谢大师们解答
    发表于 03-13 06:43

    单片机的BootLoader高阶玩法

    经过串口传输最终由单片机接收到的固件数据是可能出现差错的,而有错误的固件冒然直接写入到APP区,是一定运行不起来的。
    发表于 03-08 13:58 653次阅读
    单片机的<b class='flag-5'>BootLoader</b>高阶玩法

    TC387无法从bootloader跳转到APP运行怎么解决?

    最近在开发TC387的bootloader软件,在使用__asm("ja (0xA0030000)")指令跳转到APP程序的入口地址时,程序会进入debug,此处
    发表于 03-06 06:38

    STM32案例:BootLoader是怎么跳到App

    BootLoader项目程序和App项目程序是分开的,所以需要分别搭建对应的项目工程文件,分开搭建文件是为了好配置,同时也是方便对项目进行管理。
    发表于 03-04 09:35 3891次阅读
    STM32案例:<b class='flag-5'>BootLoader</b>是怎么跳到<b class='flag-5'>App</b>

    rtthread用通用bootloader后,app的io口无法产生中断怎么解决?

    使用的stm32f412,用的rtthread自动生成的bootloader,跳转到app后,app正常运行,但是开启的io口中断,无法正常产生中断,去掉bootloader后,使用没
    发表于 02-26 07:01

    关于bootloader与bootloadable img合并的问题求解

    我们实现bootloader功能时, app0 当作bootloaderapp1 当作bootloadable image,我们想让app
    发表于 02-21 08:17

    请问如何一次同时烧录bootloader和application?

    我们的bootloader和bootloadable的例程产生的bootloader程序和application程序如何合并成一个hex,一次烧录到芯片内?有什么AN或工具么?
    发表于 02-21 07:24

    TC275从bootloader跳转到APP执行时,只要APP使能中断即进入异常是怎么回事?

    lsl文件配置的中断向量表在SRAM中的不同位置,在bootloader跳转到APP之前有关闭全局中断,单步调试能够发现已经在APP中运行,运行到使能全局中断的位置即进入异常。若APP
    发表于 01-25 06:01

    快速入门BlueNRG SDK固件开发流程

    本文档指导用户快速地对 BlueNRG SDK 有一个直观、清晰的认识,了解其软件架构,以便顺利地学会利用 SDK 开发自己的用户固件
    的头像 发表于 01-13 10:43 1875次阅读
    <b class='flag-5'>快速</b>入门BlueNRG SDK<b class='flag-5'>固件</b>开发流程