从0到1教你制作网络数字变化时钟

发布者:upsilon30最新更新时间:2024-07-08 来源: elecfans关键字:Bootloader  OTA升级 手机看文章 扫描二维码
随时随地手机看文章

提前声明:本项目是基于芯片之家的[开源]从0到1教你制作网络数字变化时钟的项目代码进行修改,增加Bootloader和OTA升级的。


一、前期准备

硬件准备:

1. 一块LED电子数字时钟屏

2. 一根microusb线(安卓线)

3. 一个下载器(ST-Link或者Jlink 等)

软件准备:

4. MDK5软件

5. RT-Thread的ENV工具

6. LED电子时钟屏源项目工程代码

7. RT-Thread OTA打包工具

8. WebServer工具


等待airkiss配网


airkiss配网成功


正确显示日期和时间

二、主要说明

在本次操作中的LED电子数字时钟屏采用的主控芯片是STM32F401RCT6,FLASH为256K,焊接了一个外置SPI接口的 flash芯片;在添加bootloader功能前需要设计分区,对于分区操作有一定的要求说明,暂且不细说,参考RT-Thread官网的说明如下,可以对Boot有一定的了解。

img

img

功能说明

Bootloader 的主要功能是更新 app 分区中的固件

分区表介绍

通用 Bootloader 中的分区表包含如下三个分区:

通用 Bootloader 中的分区表包含如下三个分区:

升级固件功能

当系统需要升级固件时,Bootloader 将从 download 分区将固件搬运到 app 分区,主要功能流程如下所示:

Bootloader 启动时检查 download 分区和 app 分区中的固件版本。

如果两个固件版本相同,则跳转到 app 分区,Bootloader 运行结束。

固件版本不同则将 download 分区中的固件搬运到 app 分区。

在搬运的过程中 Bootloader 可以对固件进行校验、解密、解压缩等操作。

搬运完毕后,删除 download 分区中存储的固件。

重启系统跳转到 app 分区中的固件运行,Bootloader 运行结束。

Bootloader 工作过程如下图所示:

恢复固件功能

当系统中的固件损坏,Bootloader 将从 factory 分区将固件搬运到 app 分区,主要功能流程如下所示:

Bootloader 启动时检查触发固件恢复的引脚是否为有效电平

如果有效电平持续超过 10S 则将 factory 分区中的固件搬运到 app 分区中。

如果有效电平没有持续超过 10S 则继续进行 2.2 小节中介绍的启动步骤。

在搬运的过程中 Bootloader 可以对固件进行校验、解密、解压缩等操作。

搬运完毕后,保持 factory 分区中的固件不变。

重启系统跳转到 app 分区中的固件运行,Bootloader 运行结束。

以上资料来源:RT-Thread官方文档,详细可以参考:https://www.rt-thread.org/document/site/application-note/system/rtboot/an0028-rtboot/

三、操作流程

分区说明:基于使用的STM32F401RCT6的内部Flash为256K,开源LED电子时钟屏的源程序的固件大小为124k,在设计分区的时候一般APP和download区是采用1:1的方式,还有bootloader分区一般设计为16K到32K,显然这样256K的内部FLASH不能满足要求,所以需要使用外部FLASH,设计分区表为:内部flash的前32K为bootloader分区,剩余的内部FLASH (256-32 = 224)224K为APP分区,download分区设在外部flash区。

在设计好分区表后,需要在原项目代码中添加spi的驱动,烧录boot,修改分区表,修改连接地址,添加ota_downloader的功能组件。

1.在源程序项目代码中配置添加spi——flash驱动。

(1)在项目代码的目录下,通过ENV工具进入命令行,在命令行中输入menuconfig,如下图1所示:

图1 menuconfig配置界面

进入RT-Thread Components目录下的Device Drivers下选中Using generic GPIO device drivers和Using SPI Bus/Device device drivers 和Using Serial Flash Universal Driver 和Using auto probe flash JEDEC SFDP parameter 和Using defined support flash chip information tatble,如下图2所示:

img

添加配置后,返回到主界面,修改CS的引脚号为20.

图2 配置SPI驱动和GPIO驱动

保存并退出,在env命令行下输入scons --target=mdk5 重新编译生成工程。

再用mdk5打开编译的项目工程,编译烧录到板子上,在启动信息可以判断外置flash已经添加驱动了,如下图3所示:

图3 启动打印spi flash芯片信息

(2) 添加ota_downloader和FAL_Packages软件包还有SFUD的配置。

在env工具的命令行中,输入menuconfig 进入配置界面,进入RT-Thread online packages 目录下的Iot - internet of things 目录下选中[]ota_downloader,进入ota_downloader目录下选中[] Enable OTA downloader debug和[]Enable HTTP/HTTPS OTA(并且配置默认的URL为本机的ip地址的路径)和[] Enable Ymodem OTA,如下图4和图5所示

图 4 添加ota_downloader软件包

图5 配置ota_downloader软件包添加ymodem_ota和http_ota

通过ESC按键返回到RT-Thread online packages 目录下system packages目录下选中fal: Flash Abrstraction layer…,如下图6所示

图6 添加FAL 软件包

进入选中该项 fal目录下,选中FAL partition table config has defined on ‘fal_cfg,h’和FAL uses SFUD driver,并且修改name 为flash0 具体配置如下图7所示

图 7 配置fal 软件包

然后保存并退出。在ENV工具的命令行中输入 pkgs --update 软件更新的指令,等下载完成后,就可以输入:scons --target=mdk5 重新编译生成新的工程。

(3) 添加fal_cfg.h和fal_flash_stm32f4_port.c和更新SFUD的驱动文件

由于原项目代码版本的问题,需要在新版的RT-Thread的源代码中复制两个文件到现工程代码中。把fal_cfg.h和fal_flash_stm32f4_port.c这两个文件复制到现代码项目中的driver目录下,并且把这两个文件添加到项目工程中;更新SFUD的驱动文件,对比新版git库中rt-thread/components/drivers/spi/spi_flash_sfud.c和rt-thread/components/drivers/spi/spi_flash_sfud.h的文件,可以直接复制覆盖这两个文件的内容。

(4) 烧写boot.bin文件,boot.bin文件可以是烧录附件中的boot.bin文件,也可以是RT-Thread官网上通过网页生成的boot.bin,下面主要使用附件中的boot.bin文件的使用。烧录boot.bin文件主要使用ST-Link Utility工具。

步骤1:打开STM32 ST-LINK Utility工具,打开附件中的bootloader.bin文件,如下图8所示

图8 使用ST-Link Unitity 工具烧录boot.bin

然后,选择菜单栏上的烧录按钮,设置start address 为0x08000000为默认地址,然后选择start按钮,开始烧录,如下图9所示。

图 9 设置boot.bin的起始地址

烧录完成后,在串口中会打印boot的信息,如分区表的信息等,如下图10所示

图 10 烧录boot.bin后启动

由于APP固件的启动地址还没有修改,所以会提示找不到APP分区,到此bootloader已经成功启动了,下面开始APP固件的启动地址进行修改。

(5) APP固件分区的的启动地址修改

步骤1:在main.c中添加FAL 初始化代码和修改中断向量跳转地址,添加版本打印信息,具体操作如下图11所示。

图 11

步骤2:修改APP启动地址为0x08008000,如下图12所示。

图 12

步骤3 :添加屏蔽中断向量跳转到默认地址的语句,如下图13所示

图 13

(6)分区表fal_cfg.h的修改

步骤参考,如下图14所示:

图 14

到此为止,bootloader和ota升级功能已经添加完成,重新编译工程,下载到板子上即可看到程序正常运行。板子启动打印的信息如下图所示,验证了bootloader已经正常工作,而且成功跳转到了app固件分区中,如下图15所示。

图15

而且在程序的命令行中也看到了ymodem_ota和http_ota的指令,如下图16所示。

图 16

四、功能验证

1.ymodem_ota升级功能验证。

操作步骤:

(1)采用在项目代码目录下面的packagesota_downloader-latest oolsota_packager文件夹下双击运行rt_ota_packaging_tool.exe,如下图17所示

图 17

在软件中的配置如下图18所示,点击选择固件,指定项目工程代码编译生成的rtthread-stm32f4xx.bin文件,采用不加密不压缩的方法,固件分区名为”app”,固件版本为数字序号以区分不同的版本,然后点击开始打包,即可在固件目录下生成一个rbl后缀的文件。

图 18

打包生成的rbl文件,如下图19所示。

图 19

(2)在板子的串口终端中输入:ymodem_ota 命令,如下图20所示

图 20

然后,利用串口终端的Ymodem传输工具发送,方法为在Xshell串口终端中,鼠标右键选择传输,再选择YMODEM,再选择YMODEM发送,指定发送的rbl文件即可。

接下来就会自动进入下载程序到板子上进行升级,部分过程图如下图21所示。

img

img

img

图 21

到此,ymodem_ota升级完成,重启后会进入等待配网界面,airkiss配网完成后就可以显示正确的日期时间。

2.http_ota升级功能验证。

操作步骤:

(1)把板子和pc连接在同一个局域网,在给电子时钟airkiss配网的时候配置和pc同一个局域网即可。

(2)在PC上搭建web_server服务器,这里使用MyWebServer V3.6.21 Unicode工具,打开该软件,设置服务器的根目录,然后启动。点击浏览按钮指定rbl文件的路径目录,然后点击启动,如下图22所示。

图22

在板子的串口终端中的命令行操作,输入http_ota url 指定rbl的地址 的命令,就会进入下载个更新app固件,如下图23所示,

图 23

固件下载完成后,开始更新app固件,如下图24所示。

图 24

到此,让电子时钟跑起BootLoader和支持OTA升级的功能就完成了。


关键字:Bootloader  OTA升级 引用地址:从0到1教你制作网络数字变化时钟

上一篇:基于ESP8266 WIFI网络控制和机智云的智能家居管控
下一篇:基于MPU6050的老年人跌倒监测系统设计

推荐阅读最新更新时间:2024-11-21 07:45

移植嵌入式Linux到ARM处理器S3C2410:BootLoader
BootLoader指系统启动后,在操作系统内核运行之前运行的一段小程序。通过BootLoader,我们可以初始化硬件设备、建立内存空间的映射图,从而将系统的软硬件环境带到一个合适的状态,以便为最终调用操作系统内核准备好正确的环境。通常,BootLoader是严重地依赖于硬件而实现的,特别是在嵌入式世界。因此,在嵌入式世界里建立一个通用的 BootLoader 几乎是不可能的。尽管如此,我们仍然可以对BootLoader归纳出一些通用的概念来,以指导用户特定的BootLoader设计与实现。   BootLoader 的实现依赖于CPU的体系结构,因此大多数 BootLoader 都分为stage1 和stage2 两大部分。依赖
[单片机]
移植嵌入式Linux到ARM处理器S3C2410:<font color='red'>BootLoader</font>
ARM7TDMI-S在嵌入式系统中的Bootloader代码设计
摘要:ARM7TDMI-S是ARM公司设计的一款32位精简指令集处理器内核,LPC210x系列是飞利浦半导体公司生产的基于ARM7TDMI-S内核的芯片。在嵌入式系统设计中,针对嵌入式处理器和操作系统的Bootloader代码的设计是一个难点。本文根据用LPC2106进行嵌入式系统设计的实际经验,总结出基于ARM7TDMI-S内核的嵌入式处理器芯片的Bootloader代码设计的一般流程;给出LPC2106芯片在基于μC/OS-II操作系统的嵌入式应用中,BootLoader程序的详细设计流程及其中的一些关键技术和代码。 关键词:ARM7TDMI-S嵌入式系统 BootLoader代码 LPC2106 μC/OS-II 引言
[嵌入式]
Bootloader升级方式一————擦、写flash在RAM中运行
在汽车ECU软件运行中,软件代码运行安全性是第一,在代码中尽可能的不要固化有flash_erase、flash_write操作存在,主要是防止当出现异常情况时,程序跑飞,误调用erase、write对flash操作,使得原软件受到破坏,以致ECU不能正常工作。 Bootloader也称为启动引导加载程序,这段程序是硬件设备在上电复位之后执行的第一段软件代码。 方式一、为了实现在线更新功能,Bootloader程序需要对flash进行操作。一般情况下,我们将FLASH操作程序作为Bootloader组件的一部分固化在存储器中,在需要执行flash擦除或烧写操作时,先将该部分代码复制到RAM中,再做调用。操作代码的复制工作也可
[单片机]
<font color='red'>Bootloader</font><font color='red'>升级</font>方式一————擦、写flash在RAM中运行
STM32启用Bootloader支持配置
1. 程序设置 在进入main()函数后的第一行增加FLASH偏移地址设置,如图: 2. 工程设置 Bootloader的占用空间为0x4000, 则将Start的值设置为0x8004000,将Size的值设置为:原来大小-0x4000,以STM32F103C8为例,其内存大小为0x10000,设置后为0x10000-0x4000=0xC000。 设置前: 设置后:
[单片机]
STM32启用<font color='red'>Bootloader</font>支持配置
STM32学习笔记之简易Bootloader串口升级设计
概念简介 在学习制作串口升级 Bootloader 之前,我们先了解一下STM32的 IAP (In Application Programming)即在应用编程,IAP是用户自己的程序在运行过程中对 User Flash 的部分区域进行烧写,目的是为了在产品发布后可以方便地通过预留的通信口对产品中的固件程序进行更新升级. 设计这样的功能需要有两个项目代码: Bootloader 程序: 该部分代码用于实现通过某种通信方式(如 USB,USART)接收程序或数据,执行对第二部分代码的更新,通常存储于 Flash 的起始地址(0x08000000); App 程序: 该部分代码是产品实现业务逻辑正常运行的代码,该部分
[单片机]
STM32学习笔记之简易<font color='red'>Bootloader</font>串口<font color='red'>升级</font>设计
如何使用STM32通用BootloaderOTA更加Easy
随着物联网时代到来,越来越多的智能设备拥有了在线升级的能力,无论是系统更新,产品功能迭代还是漏洞修复都能在第一时间抵达用户手中的智能设备。 在线升级功能需要使用 OTA (Over-the-Air) 技术 ,OTA 技术简单地说就是通过网络来升级手中的智能设备,进而使用设备最新版本的功能。而 OTA 技术中必不可少的一环就是通过 Bootloader 来管理、升级设备固件。 由于 OTA 功能由多种复杂技术组成,因此添加 OTA 功能有一定的技术门槛。很多开发者遇到莫名其妙的问题,进而导致 OTA 升级失败,常见问题如下: 升级过程缺少专业的安全机制 APP 无法正常启动 程序莫名跑飞,出现 hardfault 固件搬运失
[单片机]
如何使用STM32通用<font color='red'>Bootloader</font>让<font color='red'>OTA</font>更加Easy
MIUI 6正式版已OTA推送 小米3/4可升级
     作为被小米公司誉为迄今为止最好的MIUI,MIUI 6于今年8月16日正式发布。扁平化的UI设计与超多项人性化功能的加入令无数米粉都在期待正式版MIUI 6的亮相。经过数十天的艰苦等待,MIUI 6稳定版已经开始陆续向小米3和小米4的用户推送了。 被小米公司誉为迄今为止最好的MIUI   升级MIUI 6的方法很简单,目前小米3和小米4的用户可以通过手机内的OTA方式进行升级,或者在PC端安装小米手机助手连接手机进行升级。另外,红米Note 4G的稳定版应该会在下个月月初提供稳定版的升级,相关用户还需耐心等待一番。 目前,小米3与小米4的用户可升级稳定版MIUI 6   相信用不了多久,全线热门的小米产品都
[手机便携]
第28章 STM32F429的系统bootloader基础知识
28.1 初学者重要提示 本章主要为大家介绍系统bootloader的理论知识,下个章节为大家实战。 更多系统bootloader的基础知识看本帖的AN2606应用笔记:http://www.armbbs.cn/forum.php?mod=viewthread&tid=96573 28.2 系统bootLoader基础知识 STM32的系统存储区自带bootloader,此程序是ST在芯片出厂时烧录进去的,主要用于将用户应用程序下载到芯片内部Flash。支持USB,SPI,I2C,CAN,UART等接口方式下载。如果大家的应用程序打算采用这种接口方式进行升级,可以考虑采用系统bootloader,简单易用,无需用户自己写b
[单片机]
第28章 STM32F429的系统<font color='red'>bootloader</font>基础知识
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

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

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

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