项目介绍. Y) Z7 D; T' U& e2 Z ! r/ H9 O8 I4 S3 R 在之前的例程和实践中,我们都是使用st-link调试下载的方式进行程序烧录。大家可能已经认识到这种烧录方式的弊端了。因为这种烧录方式首先必须要有以下几个工具或者软件:) u5 p- `& ]9 H* ?, B( x 1. 烧录工具(不能芯片支持的工具不一样,有ST-Link,JTAG等)* L, D) v: ^$ X( P- e 2. 已经安装了IDE(IAR或者SVD或者CCS等)或者与烧录工具匹配的烧录软件的电脑' U9 b1 E6 X7 } 3. 烧录前后需要物理上电掉电(不建议ST-Link进行热插拔),即开/关电源. ; Q, O- z3 @% ?$ a4 K6 z. } 也许大家会觉得,对于学习而言,这些都能忍受。但是如果真正做成产品,如果还是用这种方式进行升级,那代价就太大。举个例子吧,我之前的工作是开发和维护大功率的UPS(不间断电源),主要客户是一些大型企业,例如银行的数据中心,中国移动网络中心。UPS内部有许多ARM芯片,DSP芯片。这类应用场合,即便给程序升级,客户也不会让你断电的,而且因为安全性要求,一般MCU,DSP都是在产品内部,根本无法对外开放烧录盒的烧录接口。所以绝大部分嵌入式产品,都会开发Bootloader程序。7 C$ h2 d: a5 r9 Z2 N' M* k6 x d f% |* ]9 o+ i% L* A- {6 T3 ? 那么什么是Boot Loader呢?一般来说,嵌入式产品的软件都会分为两部分,第一部分为Bootloader,第二部分为主程序(Main APP),它们存放在flash的不同区域。Bootloader是上电或者复位以后先执行的,通过它,我们可以初始化硬件设备、建立内存空间的映射图,检测程序的完整性,判断是否需要从Bootloader跳转到APP或者更新APP。而主程序呢,则是真正用来实现产品面向客户的功能的。 通常呢,在Bootloader会实现一种或者一种以上的IAP方式,可能是UART,SPI,CAN或者Ethernet等。本次例程呢,就是设计一个Bootloader,允许用户用电脑的串口+超级终端实现烧录功能. 4 d: i! f. C! i# M& B 内容比较多,所以细节就不一一列出。详情请参见附件文档。 8 H4 v; A; e( c/ S/ W: p" B# X( Z! q+ T( o |
附件文档有一处笔误:Main APP中将“XLXWW”字符放入flash的0x9180地址中 改为Main APP中将“XLXWW”字符放入flash的0x9FF8地址中 |
项目正在用串口,上位ARM机有SD卡,想用SD卡的TXT文件,升级MCU, |
分享精神是伟大的,分享了我们就越强 |
写得不错,支持一个 |
wuwuwu |
好东西。先收藏了。刚开始学stm8…… |
谢谢楼主分享 |
感謝樓主分享! n* j: A& a: _6 [5 u5 D |
谢谢楼主分享 |
很好很好,学习学习 |
看得有点晕 |
下载看看来吧 |
好东西。先收藏了。 |
有没有代码分享下嗯 |