本文将详细记载怎么使用STM8S自带BootLoader实现程序更新。
准备工作:
1. ST支持文档 UM0560(说明BootLoader怎么用)
2. ST官方下载软件 STMFlashLoader Demo.exe
3. IAR Embedded Workbench 、ST Visual Programmer
4. 2块STM8S105K6,用来实现更新操作。
实践操作:
1. 使用STVP -> OPTION BYTE -> ROP ->Read Out Protection OFF
STVP -> OPTION BYTE -> BOOTLOADER ENABLE ->BootLoader Enable
本文只记载怎么使用BootLoader,如果读保护使能了,不在本文讨论范围(在UM0560中有提到怎么处理)。为什么这两个字节选项字要处理,在UM0560中有说明,不这样操作,不能进入BootLoader程序,MCU复位后检测到这个这两个选项字节不符,则跳转到用户应用程序区0x8000地址处。
补充说明:
使能BootLoader能够用库函数,写字节选项字。
FLASH_Unlock(FLASH_MEMTYPE_DATA); //解锁Flash
FLASH_ProgramOptionByte(0x487E, 0x55); //使能BootLoader
FLASH_Lock(FLASH_MEMTYPE_DATA); //上锁Flash这里写代码片
读保护不能用库函数写。
使用UART和PC通讯
PC端打开STMFlashLoader Demo.exe,连接好串口。
在MCU复位1S之内,点击Next.
如果不能进入上图界面,从3个方面检查:
1.第1步,两个字节选项字是不是已经配置好。
2.串口TX,RX是不是连接正确。
3.MCU供电是不是正常。
选择MCU密度容量,上面对应固件版本号1.3,是上位机从Boot区读出来的。点击Next。
下面进入erase,download,updata界面。擦除不多说,操作一下就明白什么意思。updata是指把MCU的程序读出来保存成文件。重点来说一下下载操作。
执行下载之前要执行标号1。这里的要点是标号2,不要加载HEX文件,如果加载了HEX文件则标号3不能操作,写入地址不可选。原因是HEX文件本身就包含了写入地址信息,所以不可改,在IAR中可编辑OPTION选择生成Bin文件。生成了Bin文件才可以选择下地址。
我这里选择的地址是0xA000,这个地址是开发者自己确定的,APP1.bin包含的是要更新的固件信息。也就是要复制到目标板从机的程序。
操作到这里,BootLoader就已经完成一半的任务了,下篇说主机MCU怎么和从机握手,然后主机更新从机的程序。
我自己在操作的时候想怎么把固件程序和应用程序分段放到主机的flash中,各种论坛救助,没有得到满意的回复。偶然加载了一次Bin文件,问题才解决,特意写下来,希望能帮助到有同样困惑的人。
上一篇:STM8L051F3 硬件I2C从机实例--新手导航
下一篇:ST硬件IIC上电检一直检测到忙状态
推荐阅读最新更新时间:2024-11-17 09:57
设计资源 培训 开发板 精华推荐
- 使用 Allegro MicroSystems 的 A8501 的参考设计
- FRDM-KL27Z: 面向Kinetis® KL17和KL27 MCU的Freedom®开发平台
- LT6604IUFF-10 双路匹配、5 阶、10MHz 低通滤波器的典型应用电路
- 2021电赛F题国二
- NCP380HMU10AGEVB,笔记本USB开关评估板
- 【立创开发板】聪明聪的智能小车
- LTC1164-5 低功率 8 阶引脚可选巴特沃斯或贝塞尔低通滤波器的典型应用
- 使用具有 PSM/PWM 控制和电源良好状态的处理器系统电源管理的 ADP5135 的典型应用
- 用于 LCD 显示器的 3-LED 通用 LED 驱动器
- AD5335 并行接口、四路电压输出、10 位 DAC 的典型应用