打印
[Cortex-M0技术交流]

IAP 的百度定义,总算对ISP ICP IAP有了些了解。

[复制链接]
2021|5
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
cgd|  楼主 | 2012-11-30 11:33 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
IAP是In Application Programming的首字母缩写,IAP是用户自己的程序在运行过程中对User Flash的部分区域进行烧写,目的是为了在产品发布后可以方便地通过预留的通信口对产品中的固件程序进行更新升级。 通常在用户需要实现IAP功能时,即用户程序运行中作自身的更新操作,需要在设计固件程序时编写两个项目代码,第一个项目程序不执行正常的功能操作,而只是通过某种通信管道(如USB、USART)接收程序或数据,执行对第二部分代码的更新;第二个项目代码才是真正的功能代码。这两部分项目代码都同时烧录在User Flash中,当芯片上电后,首先是第一个项目代码开始运行,它作如下操作:
  1)检查是否需要对第二部分代码进行更新
  2)如果不需要更新则转到4)
  3)执行更新操作
  4)跳转到第二部分代码执行
  第一部分代码必须通过其它手段,如JTAG或ISP烧入;第二部分代码可以使用第一部分代码IAP功能烧入,也可以和第一部分代码一道烧入,以后需要程序更新是再通过第一部分IAP代码更新。
  对于STM32来说,因为它的中断向量表位于程序存储器的最低地址区,为了使第一部分代码能够正确地响应中断,通常会安排第一部分代码处于Flash的开始区域,而第二部分代码紧随其后。
  在第二部分代码开始执行时,首先需要把CPU的中断向量表映像到自己的向量表,然后再执行其他的操作。
  如果IAP程序被破坏,产品必须返厂才能重新烧写程序,这是很麻烦并且非常耗费时间和金钱的。针对这样的需求,STM32在对Flash区域实行读保护的同时,自动地对用户Flash区的开始4页设置为写保护,这样可以有效地保证IAP程序(第一部分代码)区域不会被意外地破坏。
IAP与ISP的区别
  在线编程目前有两种实现方法:在系统编程(ISP)和在应用编程(IAP)。ISP一般是通过单片机专用的串行编程接口对单片机内部的Flash存储器进行编程,而IAP技术是从结构上将Flash存储器映射为两个存储体,当运行一个存储体上的用户程序时,可对另一个存储体重新编程,之后将控制从一个存储体转向另一个。ISP的实现一般需要很少的外部电路辅助实现,而IAP的实现更加灵活,通常可利用单片机的串行口接到计算机的RS232口,通过专门设计的固件程序来编程内部存储器。

相关帖子

沙发
autopccopy| | 2012-12-7 21:09 | 只看该作者
写得不错,顶!

使用特权

评论回复
板凳
dong_abc| | 2012-12-7 22:11 | 只看该作者
:victory: ,恭喜lz.

使用特权

评论回复
地板
缥缈九哥| | 2012-12-8 21:27 | 只看该作者
你功力又提升一层了。

使用特权

评论回复
5
江枫渔火| | 2012-12-11 16:22 | 只看该作者
ISP在系统编程,就是不需要取下芯片放进编程器编程,芯片已经在产品上用着了,也能通过串口或USB或其他口线下载程序入内。
IAP在应用编程,就是用户在自己的代码中也能够改写代码区域的代码。有芯片厂商提供的,也有自己编写的,都是基于“允许用户代码改写ROM区域”的前提下编写的。
ICP应该就是个工具吧

使用特权

评论回复
6
max_v| | 2013-11-26 20:42 | 只看该作者
了解了谢谢了

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

cgd
个人签名:

80

主题

7502

帖子

16

粉丝