更新历史
- 20220315
首次创建文档,就三种 flash 编程方式进行了简单的概念介绍与归类;- 20220319
增加 ISP IAP 的差异说明;
引言
这篇文章其实还是从“固件防复制” 这个功能衍生的总结知识点,由于涉及到了闪存中固件的读取限制,就相应的想到了 flash 中数据的编程方式,这里指的是外界烧录数据到 flash 中的宏观方式,并不是值得 flash 编程方法。
IAP
这里先从上述提到的系列话题关联性最强的开始说起吧,IAP (In Application Programming, 应用内编程)顾名思义,这个意思是用户代码来擦除、编程闪存区域。不同的 MCU 闪存其实地址不同,如 LPC1778 闪存起始地址为 0x0, STM32 通常为 0x0800 0000.
IAP 通常被开发者用来作为远程升级的手段,典型的应用就是两段代码区,第一段用来每次上电检测是否需要更新第二段的程序,第二段才是真正的功能代码。
方法依赖
- MCU 支持 IAP;
- 程序设计支持 IAP;
- 无其它工具依赖;
ISP
ISP (In System Programming, 系统内编