LPC1768进行IAP编程时,SelSector准备扇区时就死在那里了,请问该怎么解决

LPC1768进行IAP编程时,SelSector准备扇区时就死在那里了,请问该怎么解决,第1张

近期 我也遇到了类似的问题,

不过我用的是LPC2214芯片,解决办法应该类似,

在调用IAP程序之前,要保证所有的中断是关闭状态,然绝唯后

uint8 a[10]

uchar i

for(i=0i<10i++)

{

a[i]=0x0B

}

SelSector(START_SECTOR,END_SECTOR)

//选择扇区 将要保存的数据放在,第十扇区,

EraseSector(START_SECTOR,END_SECTOR)

//擦除扇区

BlankCHK(START_SECTOR,END_SECTOR)

//型宏亮查空扇区

SelSector(START_SECTOR,END_SECTOR)

//选择扇区 将要保存的数据放在,第十扇区,

RamToFlash(START_ADDR,(uint32)p_Config_Init,BYTE_NUM_1)

SelSector(START_SECTOR,END_SECTOR)

//选择扇区 将要保存卜宽的数据放在,第十扇区,

RamToFlash(BAK_ONE_START_ADDR,(uint32)p_Config_Bak,BYTE_NUM_1)

前面定义一个数组并进行初始化没有什么实质意义,但是却能够使程序正常运行,我想应该是在 *** 作时RAM地址出现冲突,以至于使SelSector(START_SECTOR,END_SECTOR)会进入“取指令中断错误”。加上前面对数组定义可能会对RAM地址有所影响,从而使对IAP的 *** 作能够正常进行。

我所用的是LPC2214,可能和你的问题不太一样,试试吧!

ISP:

用写入器将code烧入,不过,芯片可以在目标板上,不用取出来,在设计目标板的时候就将接口设计在上面,所以叫"在系统编程",即不用脱离系统

IAP:

在应用编程,有芯片本身(或通过外围的芯片)可以通过一系列 *** 作将code写入,比如一款支持Iap的单片机,内分3个程序区,1作引导程序区,2作运行程序区,3作下载区,芯片通过串口接收到下载命令,进入引导区运行引导程序,在引导程序下将new code内容下载到下载区,下载完毕并校验通过后再将下载区内容复制到2区,运行复位程序,则Iap完成

应用场合:

1,ISP 程序升级需要到现场解决,不过好一点的是不必拆机器了

2,IAP 如果有网管系统的话,用网管下载一切搞定,人不用跑来跑去,

这可能是他们的优点或应用吧

在线编程目前有两种实现方法:在系统编程(ISP)和在应用编程(IAP)。ISP一般是通过单片机专用的串行编程接口对单片机内部的Flash存储器进行编程,而IAP技术是从结构上将Flash存储器映射为两个存储体,当运行一个存储体上的用户程序时,可对另一个存储体重新编程,之后将控制从一个存储体转向另一个。ISP的实现一般需要很少的外部电路辅助实现,而IAP的实现更加灵活,通常可利用单片机的串行口接到计算机的RS232口,通过专门设计的固件程序来编程内部存储器。 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代码,才是最终目标。

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

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


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12377179.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存