
IAP
这里先从上述提到的系列话题关联性最强的开始说起吧,IAP (In Application Programming, 应用内编程)顾名思义,这个意思是用户代码来擦除、编程闪存区域。不同的 MCU 闪存其实地址不同,如 LPC1778 闪存起始地址为 0x0, STM32 通常为 0x0800 0000.
IAP 通常被开发者用来作为远程升级的手段,典型的应用就是两段代码区,第一段用来每次上电检测是否需要更新第二段的程序,第二段才是真正的功能代码。
方法依赖
MCU 支持 IAP;
程序设计支持 IAP;
无其它工具依赖;
ISP
ISP (In System Programming, 系统内编程),其通常是运行厂家的 bootloader 来进入 ISP 模式或支持 ISP 协议通信,当处于 ISP 模式下时,用户可以通过软件(flashMagic 或 ISP programmer等)对闪存(此时闪存只是一块普通的存储空间)进行擦除或编程,不同的芯片厂家有的也会在官方提供自己的 ISP 编程工具。
进入 ISP 模式的方法
不同 MCU 的具体方式不同,比如 NXP 会单独留出一个 ISP 口,提示说明当这个引脚接地时,可通过串口进行 ISP 通信;ST 系列通过 BOOT0 BOOT1 来选择从那里启动程序,并说明可用的串口管脚。

图1 LPC17x ISP 功能说明

图2 STM32 程序启动方式选择
ISP,IAP 方式最本质的区别是一个是从厂家的 Bootloader 进行闪存编程,一个是通过我们这类的工程师开发的 Bootloader 进行闪存编程。
2、ISP是使用引导程序通过USB/UART等接口进行烧录的,首先就是需要有BoodLoad程序。最常见的烧录方式就是学习8051单片机时使用的STC-ISP烧录工具了。
ISP 并没有十分通用的协议,更重要的是想说明这种方式,甚至每个 MCU 的实现方法、支持操作也不完全相同,具有一定的私有性; 且需要借助一定的上位机及通信硬件接口来实现闪存编程。
3、IAP就是通过软件实现在线电擦除和编程的方法,没有使用任何工具,仅仅是通过软件的方法来更新Flash中的数据。
讲述一个案例,那就是通过4G模块来远程更新程序。将Flash分成两块区域,第一块为Boodload程序,第二块区域存放的是应用程序APP。4G模块和目标板通讯,通讯中包含是否更新的位,如果主板接收到需要更新的位,就往Flash中写入一个标志位,比如'P',之后程序跳到第一段程序Boodload程序中执行,首先判断Flash中的是否有更新程序的标志位'P',如果有则通过规定的协议进行更新应用程序中的程序,更新完毕后清除Flash中的更新标志位,跳转到应用程序中去执行。如果没有更新程序标志位‘P’,跳到应用程序执行。
IAP 则不需要借助外部工具,闪存编程通过 APP 区1 则能够进行(编程 APP 区2)
版权声明:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权、违法违规、事实不符,请将相关资料发送至xkadmin@xkablog.com进行投诉反馈,一经查实,立即处理!
转载请注明出处,原文链接:https://www.xkablog.com/bcyy/16165.html