在实践中,单片机应用系统的抗干扰设计一般是通过硬件抗干扰设计和软件抗干扰设计两种途径来实现的。硬件如果设计得当,就可以将绝大部分干扰拒之门外,但仍然会有少量干扰,所以软件措施必不可少。由于软件措施是以占用CPU为代价的,如果没有硬件消除绝大部分干扰,CPU将疲于奔命,严重影响系统的工作效率和实时性。因此一个抗干扰性良好的单片机应用系统则是由硬件设计和软件开发相辅相成而构成。
1.硬件抗干扰设计
① 电源电路
单片机系统使用的电源,一般都是由电网的工频交流电源经降压、整流、滤波等环节后提供。由于电网的影响以及生产现场大容量电气设备的开停,会使交流电压中含有高频成分、浪涌电压、尖峰脉冲或者发生较大幅度的电压波动。这些因素都将导致干扰通过电源途径影响系统的正常工作。电源做得好,整个电路的抗干扰工作就完成了一大半。许多单片机对电源噪声很敏感,因此,应采用抗干扰的开关电源或给单片机电源加滤波电路或稳压器,以减少电源噪声对单片机的干扰。电源线的布置除了要根据电流的大小,尽量加租导体宽度外,还要使电源线、地线的走向与数据传递的方向一致。这将有助于增强抗噪声的能力。每种型号的单片机都有一个稳定工作的电压范围,例如凌阳SPCE061A单片机工作电压为3.3V~5V ,超出这个范围将出现异常。
② 硬件复位电路
图1 采用MAX6827的复位电路
复位电路是最容易受干扰的(因为CPU 内部的复位电路的阻抗都比较高,为10~50kΩ) ,影响也是最大的。因此,必须采取抗干扰措施。图1是采用MAX6827的复位及“看门狗”电路图。该电路具有较强的抗干扰能力,由于没有复位电容,不易引入干扰。
③ 注意印制电路板的布线
印刷电路板是单片机系统中器件、信号线、电源线的高密度集合体,印刷电路板设计的好坏对系统的抗干扰能力影响很大。故在印刷电路板设计不单是器件、线路的简单布局安排,还必须符合抗干扰设计原则。合理设计系统电路板,能有效地切断干扰的传播途径和抑制干扰源,同时还可以提高敏感元件(如单片机、数字IC、A/ D、D/ A 等容易被干扰的对象) 的抗干扰能力。主要采取:
[1] 电路板合理分区,如强、弱信号,数字、模拟信号分区。尽可能使干扰源(如电机,继电器) 远离敏感元件。大功率器件尽量布置在电路板的边缘。
[2] 布线时尽量减少回路环的面积,以降低感应噪声;电源线和地线要尽量粗,除减小压降外,更重要的是降低耦合噪声;连接线避免90度的折线,以减少高频噪声发射。
[3] 不用的单片机管脚,特别是中断的入口,不要悬空,一般要通过上拉电阻接电源。
[4] 电路板上每个IC 要并接一个0.01μF~0.1μF高频电容,以减少IC对电源的影响。
[5] 注意晶振布线。晶振与单片机引脚尽量靠近,用地线把时钟区隔离(圈) 起来,晶振外壳接地并固定。此措施可解决许多疑难问题。
[6] 用地线把数字区与模拟区隔离,数字地与模拟地要分离,最后接于电源地一点汇集,呈“星形”状。
在单片机应用系统中,接地是抑制干扰的重要方法。接地是否正确,接地是否牢固,将直接影响到系统的正常工作。如能将接地和屏蔽正确结合起来使用,可以解决大多数的干扰问题。
为了防止系统内部地线干扰,在设计印刷电路板时可采取如下措施:接地线尽量加粗。若接地线很细,接地电位则随着电流的变化而变化,致使计算机的定时信号电平不稳,抗噪声性能变差。因此要根据通过电流的大小决定地线的宽度,应在可能的情况下,尽量将接地线条加粗、加宽,最好不小于3mm,使它能通过3倍于印刷电路板上的允许电流。对于多级电路,设计时要考虑各级动态电流,注意接地阻抗相互耦合的影响,工作频率低于1MHz 时采用一点接地,工作频率较高时采取多点接地。
2.软件抗干扰设计
在单片机应用系统中,尽管采取了硬件抗干扰措施,但由于干扰信号产生的原因十分复杂,且有很大的随机性,因此在采取硬件抗干扰措施的基础上,采取软件措施加以补充。现简要介绍如下几种软件抗干扰措施。
① 设立软件陷阱(Trap)
单片机受到干扰时,程序计数器PC值最容易受影响,PC值的改变是随机的,完全可以造成CPU离开正确的指令顺序去执行一些无定义地址中的内容,或进入数据区,把数据当作操作码来控制,使整个工作紊乱,系统失控。这种情况对系统来说,比某个数据出错造成的危害要严重得多。后者只涉及某个功能不能实现或者产生偏差,而前者则会使整个系统造成瘫痪。造成程序失控的原因并非程序设计本身的问题,而是由于外部的干扰或单片机内部硬件瞬间故障,使得程序计数器(PC)偏离了原定的值。例如,当执行完一条指令时,程序计数器PC应加数值1,但由于某种原因,使PC实际加2,这样,程序就会把操作数和操作码混淆起来,造成后面一系列的错误。
为了防止上述情况的发生,在软件设计时,可以采用设立软件陷阱的方法加以克服。其具体做法是,在ROM或RAM中,每隔一些指令(如十条或二十条),把连续的几个单元置成“00”(空操作)。这样,当出现程序失控时只要失控的单片机进入这众多的软件陷阱中任何一个,都会被捕获,连续进行几个空操作。执行这些空操作后,程序自动恢复正常,继续执行后面的程序。这种方法虽浪费一些内存单元,但可以保证程序不会跑飞。这种方法对用户是不透明的,亦即用户根本感觉不到程序是否发生错误操作。
② 开辟多个存储区抗干扰
为了防止RAM出错,丢失最重要的数据,对于重要的输入输出数据开辟2~3个存储区同时保存。存取数据时,采取比较表决法,以使数据去伪存真。
③ 时间监视器
时间监视器(Watch-Dog Timer),也称“看门狗”技术,用于设立软件陷阱失效的情况下,让系统从故障中恢复过来。因为因干扰而失控的程序不一定都会掉到陷阱中去,比如程序的死循环就是如此。所谓死循环,就是由于某种原因使程序陷入某个应用程序或中断服务子程序中做无休止的循环。这样,CPU及其他系统资源被其占用而别的任务程序都无法执行。也就是说,死循环使程序失去正常控制,但它不会使程序控制转入陷阱区,因而软件陷阱无法捕捉它。
时间监视器由两个计数器组成,计数器靠系统时钟(或分频后的脉冲信号)进行计数。当计数器记满时,将由计数器产生一个复位信号,强迫系统复位,使系统重新执行程序。在正常情况下,每隔一定的时间(根据系统应用程序执行的长短来确定),程序使计数器清零。这样,计数器就不会记满,因而不会产生复位。
图2 SPCE061A 看门狗结构与时序
例如,凌阳单片机SPCE061A的WatchDog的清除时间周期为0.75s。因为WatchDog的溢出复位信号WatchDog_Reset是由4Hz时基信号经4分频之后产生的,即每4个4Hz时基信号(1s)将会产生一个WatchDog_Reset信号。而清除WatchDog的WatchDog_Clear信号却可以发生在4Hz信号(0.25s)之间的任意一个时刻点上。假如WatchDog_Clear信号发生在4Hz信号尾端的0.01s即第0.25s时刻,此时虽然WatchDog被清除掉,但由于它发生在4Hz信号之后,再经3个4Hz信号即0.75s,如果一直没有WatchDog_Clear信号,便会产生出一个WatchDog_Reset信号。如图2所示,如果程序运行不正常,例如陷入死循环等,计数器将记满而产生溢出此溢出信号用来产生复位信号,使程序重新开始启动。在编程中,我们只需将0X0001H写入P_WatchDog_Clear单元即可完成清除WatchDog操作,如果在0.75秒内没有将0X0001H写入P_WatchDog_Clear单元,则CPU将进行系统复位操作,即平常我们说的重启系统。看门狗经常用于延时程序中,如
void Delay()
{
unsigned int j;
for(j=0x7fff;j>0;j--);
*P_Watchdog_Clear = 0x0001;//清看门狗
}
④ 加入空操作NOP
在ROM或RAM的若干区域内,存放若干个空操作组,空操作的个数等于所选CPU芯片最长指令节数。空操作指令NOP除了占用一个存储单元和执行时间外,对CPU的工作状态没有影响。如有选择地在程序某地方插进1~2个NOP指令,也能使PC中的内容得到调整,使程序在受到干扰后回到正确的顺序。插入的位置要在程序调试过程中摸索、分析和实验。一般来说,在对外设端口的操作指令、多字节指令、转移指令、堆栈操作指令前插入NOP指令会得到好的效果。此外,还可以在空操作组之后,再增加处理跑飞的程序,而且让CPU在执行正常程序时,不执行这些指令组。只有当跑飞时才有可能遇到这些指令组。例如:
NOP
NOP
NOP
LJMP FF
FF:ACALL FLY
MOV A,FLG
CJNE A,#11H,RSM
……
⑤ 分段式软件抗干扰
某些时候,控制系统要顺序执行几个不同的主循环通道以完成不同的功能。这时可在不同主环路内编制抗干扰判别及自恢复功能。这样做可以避免不必要的重复执行,以保证顺序的完整性。
⑥ 数字滤波
数字滤波是通过程序设计对单片机数据采集部分输入的信号进行加工处理,以达到抗干扰的目的。当干扰叠加输入通道的模拟信号时,使数据采集误差加大,特别当输入通道模拟信号较弱时,此现象更加严重。为了消除数据采集的误差,常用算术平均法、比较取舍法、一阶滞后滤波法和中值法,可根据信号和干扰的规律,采用最优的设计方法。
不同的单片机应用系统都有自己的系统要求和特点,在硬件和软件抗干扰设计上也各有自己的特色。软件抗干扰技术作为硬件抗干扰的补充,以其灵活性、实用性和可靠性在单片机应用系统抗干扰方面起着举足轻重的作用。在工程实践中通常都是几种抗干扰技术并用,互相补充,才能取得良好的抗干扰效果。我们在设计单片机应用系统时,要仔细分析干扰源,软硬件抗干扰技术相结合,完善系统监控程序,则可以保证系统准确、可靠地运行。