系统编程(ISP)与应用编程(IAP)的区别!

                      系统编程(ISP)与应用编程(IAP)的区别!

1.定义

(1)系统编程(ISP)

ISP在系统编程是指电路板上的空白器件可以编程写人最终用户代码,而不需要从电路板上取下器件。已经编程的器件也可以用ISP方式擦除或再编程。
 

(2)应用编程(IAP)

IAP在应用编程,是指MCU可以在系统中  001000在获取新代码并对自己重新编程.即可用程序来改变程序。ISP和IAP技术是未来仪器仪表的发展方向。  

 

2.系统编程(ISP)与应用编程(IAP)的工作原理

(1)系统编程(ISP)

ISP的实现相对要简单一些,一般通用做法是:内部的存储器可以由上位机的软件通过串口来进行改写。对于单片机来讲,可以通过SPI或其他的串行接口接收上位机传来的数据并写人存储器中。所以,即使我们将芯片焊接在电路板上,只要留出和上位机接口的这个串口,就可以实现芯片内部存储器的改写,而无须再取下芯片。ISP用写入器将code烧入,芯片可以在目标板上,不用取出来,在设计目标板的时候就将接口设计在上面,所以叫"在系统编程",即不用脱离系统。一般通用做法是内部的存储器可以由上位机的软件通过串口来进行改写。ISP 程序升级需要到现场解决,不过好一点的是不必拆机器了

(2)应用编程(IAP)

IAP的实现相对要复杂-些,在实现IAP功能时,单片机内部一定要有两块存储区,一般一块被称为BOOT区,另外一块被称为存储区。单片机上电运行在BOOT区,如果满足外部改写程序的条件,则对存储区的程序进行改写操作:如果不满足外部改写程序的条件,则程序指针跳到存储区开始执行放在存储区的程序,这样便实现了IAP功能。IAP 如果有网管系统的话,用网管下载一切搞定,人不用跑来跑去

 

3.ISP和IAP在单片机中的应用 

(1)传统编程方法的不足


  在一般的单片机的实验或开发时,编程器是必不可少的装置。仿真、调试完的程序需要借助编程器烧到单片机内部或外接的程序存储器中。普通的编程器价格从几百元到几千元不等,对于一般的单片机用户来说还是一笔不小的开支。另外,在开发过程中,程序每改动一次就要拔下电路板上的芯片编程后再插上,这样不但麻烦也很容易对芯片和电路板造成损伤,另外在程序需要升级做改动时,必须将设备返厂或是技术人员到现场操作,既不方便也造成成本浪费。 

(2)ISP和IAP的优点


  ISP技术的优势是不需要编程器就可以进行单片机的实验和开发,单片机芯片可以直接焊接到电路板上,调试结束即成成品,免去了调试时由于频繁地插入取出芯片对芯片和电路板带来的不便。
IAP技术是从结构上将Flash存储器映射为两个存储体,当运行一个存储体上的用户程序时,可对另一个存储体重新编程,之后将程序从一个存储体转向另一个。 
  ISP的实现一般需要很少的外部电路辅助实现,而IAP的实现更加灵活,通常可利用单片机的串行口接到计算机的RS232口,通过专门设计的固件程序来编程内部存储器,可以通过现有的INTERNET或其它通讯方式很方便地实现远程升级和维护。
 

4.ISP和IAP相同点与不同点

相同点


   ISP和IAP很相似,都是不需要把芯片从板子上拔出来,就达到了通过PC-MCU的编程接口(JTAG、串口、双绞线、SPI等)搞定新版本的升级目的。MCU内部都是首先执行一段独立的Boot代码(这段Boot代码一般是出厂预置,或使用编程器烧录的,通常只有1k或4k,SST通常是占用一块独立的Block,Philips通常是让BootROM地址与其他Flash重叠,以达到隐藏的效果),Boot负责控制擦除程序存储器及给程序存储器编程的代码(或是处理器外部提供的执行代码),然后通过某种与PC计算机的通信方式(如,ether网口),将用户指定的某个在PC上编译完成的MCU可运行的二进制代码文件编程入MCU内的程序存储器。

不同点


ISP和IAP最大的不同是:由谁来触发。 

ISP有4种触发方式:

1、由外部硬件电路:如VDD保持高电平,给RST连续3个脉冲;

2、检测状态位:如ISPEN,为0时PC指针从0000H开始执行;为1时,通过“引导向量”计算出“ISP代码”的位置。每次复位后都会检测该状态位;

3、中止控制符信号触发芯片复位:中止控制符信号就是指在异步串行口的接收脚上出现长达一帧长度的低电平,这里一帧的长度与异步串行口的工作模式有关。

4、直接调用ISP:用户程序也可以调用,但是很危险。

  4种方式的目的是相同的——进入ISP子程序,比如Philips出厂的ISP子程序在1E00H-1FFFH,只要能引导PC指针指向1E00H就可以了。而进入ISP代码的目的是:进入BootROM。

  IAP的触发比较简单一些,没有外部触发。通过一些指示位(SST为SC0/SC1、SFCF[1,0];Philips为一段IAP子程序,保存在FF00H~FFFFH地址空间中),达到引导到BootROM的目的。

       殊途同归,ISP、IAP所进入的BootROM里面驻留的Boot代码,才是最终目标。

5、并行编程模式。不需要BootROM,直接设置芯片的多个引脚来让芯片识别命令(如:擦除、写入、验证等),从P口传地址、数据,就可以写入Flash。

  用LPC2000的IAP,你自己分配好FLASH空间,指定一个BLOCK用来存放你的数据,然后通过IAP进行写操作。每次开机后,从这个BLOCK读你的数据。
 

你可能感兴趣的:(嵌入式)