原创 关于“仿真时工作正常,程序固化后却不能运行?”的几种情况(转)

2007-5-21 19:42 3971 3 3 分类: MCU/ 嵌入式


关于仿真时工作正常,程序固化后却不能运行?的几种情况。 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />


 

 


 

 




 


出现这种情况有以下几种可能性:
1.用户板的程序块电路有问题:如PSEN不通或接错。地址线高位浮空等(我没遇到过这样的情况,但有文章有过这样的分析)。使用<?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" />89C51内部程序,EA未接高电平等。

2.用户板晶振电路有问题。用户板复位电路不正确。还要注意的是那2个电容,有次我拿错电容(473,结果拿万用表量电压晶振2边是2.5V,但拿示波器一看什么都没有。所以,测晶振2脚电压有时也未必完全准确。

4)堆栈溢出。8051系列的单片机,有的型号内部有256RAM,有的只有128RAM, 现在高级语言编译系统都默认是256RAM。如果您使用的是128RAM的型号的芯片, 就应注意堆栈是否会溢出,如果溢出程序就不能运行。如果这种情况,CPU换成带 256RAM的型号试试。 (这点是比较重要,和对于初学者容易忽略掉的)

3)用户系统内有需要复位的接口电路,8155,8255,8279,在它们还未完成 复位时,如果CPU就给它们写控制字,就会造成它们工作不正常。这种情况下,CPU 应确保在外设复位后再输出控制字。

5)程序片烧写不正确,这有以下几种情况: A。格式不对,或者是烧的内容不对 B。光写程序,未写芯片的设置字,PIC系列,LPC764,80C196的保留字等。这 些设置字中凡是需要用户写的应正确填写,不需要写的应写入“FF” 最好在烧写时看看烧写器读进来的BUFF,前面是不是02 00  开头。

6)检验程序片是否烧写正确的方法是,从一片烧好的芯片中读出机器码,并生成机器 码文件,然后让仿真器运行这个机器码文件。如果不能正确运行,应重新烧写程序片。

7)系统接线有错,造成固化后的程序,不在系统所要求的地址空间内,当然不能运行。 控制脚接,特别是80196系列芯片面,如果READY,NMI脚浮空,则也会出现固化后程 序不能运行的现象。  


(8)
、喂狗错误,仿真时不受影响(我用的是伟福的),烧完就老复位了;
(9)
、时序错误,仿真时由于延时歪打正着,动真格的是就不灵了,从而导致看门狗总是复位,或者是使程序停顿在了一个标志判断处。


(10)
上拉电阻

我遇到过这种情况,有的上拉电阻不加时在仿真器上可以正常运行,而固化后就不行或时行时不行。

(11)
复位时间短

仿真器上大多是手动复位,RC充电时间无关,而固化后运行,如果RC充电时间太短,就会复位不可靠甚至不能复位,因此计算复位脉冲宽度时要留有余量,这也是我的教训。

(12)
有时是因为外围硬件的设计不合理,

一般仿真器的I/O驱动能力都大于真正的CPU,在仿真器运行正常,正式烧写后,CPU未能可靠的驱动硬件。

(13)
芯片坏了

我最近就出现过,仿真器仿真时一切OK,固化后不行了,原来芯片坏了,一部分程序正常(显示,蜂鸣器),一部分怎么调都不行(串行通讯),换新片子就都OK,我使用的芯片是PHILIPSP89C51RC+,劝大家先考虑考虑这种情况省得折腾半天白费力!


 

文章评论0条评论)

登录后参与讨论
我要评论
0
3
关闭 站长推荐上一条 /2 下一条