打印
[疑难问答]

单片机系统抗干扰,软件 VS 硬件哪个重要?

[复制链接]
2891|79
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
alvpeg|  楼主 | 2024-10-29 22:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
在提高硬件系统抗干扰能力的同时,软件抗干扰以其设计灵活、节省硬件资源、可靠性好越来越受到重视。下面以MCS-51单片机系统为例,对微机系统软件抗干扰方法进行研究。



1、软件抗干扰方法的研究
在工程实践中,软件抗干扰研究的内容主要是:一、消除模拟输入信号的噪声(如数字滤波技术);二、程序运行混乱时使程序重入正轨的方法。本文针对后者提出了几种有效的软件抗干扰方法。



(1) 指令冗余
CPU取指令过程是先取操作码,再取操作数。当PC受干扰出现错误,程序便脱离正常轨道“乱飞”,当乱飞到某双字节指令,若取指令时刻落在操作数上,误将操作数当作操作码,程序将出错。若“飞”到了三字节指令,出错机率更大。

在关键地方人为插入一些单字节指令,或将有效单字节指令重写称为指令冗余。通常是在双字节指令和三字节指令后插入两个字节以上的NOP。这样即使乱飞程序飞到操作数上,由于空操作指令NOP的存在,避免了后面的指令被当作操作数执行,程序自动纳入正轨。


此外,对系统流向起重要作用的指令如RET、RETI、LCALL、LJMP、JC等指令之前插入两条NOP,也可将乱飞程序纳入正轨,确保这些重要指令的执行。

(2) 拦截技术

所谓拦截,是指将乱飞的程序引向指定位置,再进行出错处理。通常用软件陷阱来拦截乱飞的程序。因此先要合理设计陷阱,其次要将陷阱安排在适当的位置。

软件陷阱的设计
当乱飞程序进入非程序区,冗余指令便无法起作用。通过软件陷阱,拦截乱飞程序,将其引向指定位置,再进行出错处理。软件陷阱是指用来将捕获的乱飞程序引向复位入口地址0000H的指令。通常在EPROM中非程序区填入以下指令作为软件陷阱:

NOPNOPLJMP 0000H其机器码为0000020000。

陷阱的安排
通常在程序中未使用的EPROM空间填0000020000。最后一条应填入020000,当乱飞程序落到此区,即可自动入轨。在用户程序区各模块之间的空余单元也可填入陷阱指令。当使用的中断因干扰而开放时,在对应的中断服务程序中设置软件陷阱,能及时捕获错误的中断。如某应用系统虽未用到外部中断 1,外部中断1的中断服务程序可为如下形式:



NOPNOPRETI返回指令可用“RETI”,也可用“LJMP0000H”。如果故障诊断程序与系统自恢复程序的设计可靠、完善,用“LJMP0000H”作返回指令可直接进入故障诊断程序,尽早地处理故障并恢复程序的运行。考虑到程序存贮器的容量,软件陷阱一般1K空间有2-3个就可以进行有效拦截。



(3)软件“看门狗”技术
若失控的程序进入“死循环”,通常采用“看门狗”技术使程序脱离“死循环”。通过不断检测程序循环运行时间,若发现程序循环时间超过最大循环运行时间,则认为系统陷入“死循环”,需进行出错处理。


“看门狗”技术可由硬件实现,也可由软件实现。在工业应用中,严重的干扰有时会破坏中断方式控制字,关闭中断。则系统无法定时“喂狗”,硬件看门狗电路失效。而软件看门狗可有效地解决这类问题。



笔者在实际应用中,采用环形中断监视系统。用定时器T0监视定时器T1,用定时器T1监视主程序,主程序监视定时器T0。采用这种环形结构的软件“看门狗”具有良好的抗干扰性能,大大提高了系统可靠性。



对于需经常使用T1定时器进行串口通讯的测控系统,则定时器T1不能进行中断,可改由串口中断进行监控(如果用的是MCS-52系列单片机,也可用T2代替T1进行监视)。这种软件“看门狗”监视原理是:在主程序、T0中断服务程序、T1中断服务程序中各设一运行观测变量,假设为MWatch、T0Watch、T1Watch,主程序每循环一次,MWatch加1,同样T0、T1中断服务程序执行一次,T0Watch、

T1Watch加1。在T0中断服务程序中通过检测T1Watch的变化情况判定T1运行是否正常,在T1中断服务程序中检测 MWatch的变化情况判定主程序是否正常运行,在主程序中通过检测T0Watch的变化情况判别T0是否正常工作。若检测到某观测变量变化不正常,比如应当加1而未加1,则转到出错处理程序作排除故障处理。当然,对主程序最大循环周期、定时器T0和T1定时周期应予以全盘合理考虑。限于篇幅不赘述。



2、系统故障处理、自恢复程序的设计
单片机系统因干扰复位或掉电后复位均属非正常复位,应进行故障诊断并能自动恢复非正常复位前的状态。



(1)非正常复位的识别
程序的执行总是从0000H开始,导致程序从0000H开始执行有四种可能:一、系统开机上电复位;二、软件故障复位;三、看门狗超时未喂狗硬件复位;四、任务正在执行中掉电后来电复位。四种情况中除第一种情况外均属非正常复位,需加以识别。



硬件复位与软件复位的识别
此处硬件复位指开机复位与看门狗复位,硬件复位对寄存器有影响,如复位后PC=0000H,SP=07H,PSW=00H等。而软件复位则对SP、 SPW无影响。故对于微机测控系统,当程序正常运行时,将SP设置地址大于07H,或者将PSW的第5位用户标志位在系统正常运行时设为1,那么系统复位时只需检测PSW.5标志位或SP值便可判此是否硬件复位。


由于硬件复位时片内RAM状态是随机的,而软件复位片内RAM则可保持复位前状态,因此可选取片内某一个或两个单元作为上电标志。设40H用来做上电标志,上电标志字为78H,若系统复位后40H单元内容不等于78H,则认为是硬件复位,否则认为是软件复位,转向出错处理。若用两个单元作上电标志,则这种判别方法的可靠性更高。



开机复位与看门狗故障复位的识别
开机复位与看门狗故障复位因同属硬件复位,所以要想予以正确识别,一般要借助非易失性RAM或者EEROM。当系统正常运行时,设置一可掉电保护的观测单元。当系统正常运行时,在定时喂狗的中断服务程序中使该观测单元保持正常值(设为AAH),而在主程中将该单元清零,因观测单元掉电可保护,则开机时通过检测该单元是否为正常值可判断是否看门狗复位。



正常开机复位与非正常开机复位的识别
识别测控系统中因意外情况如系统掉电等情况引起的开机复位与正常开机复位,对于过程控制系统尤为重要。如某以时间为控制标准的测控系统,完成一次测控任务需1小时。在已执行测控50分钟的情况下,系统电压异常引起复位,此时若系统复位后又从头开始进行测控则会造成不必要的时间消耗。



因此可通过一监测单元对当前系统的运行状态、系统时间予以监控,将控制过程分解为若干步或若干时间段,每执行完一步或每运行一个时间段则对监测单元置为关机允许值,不同的任务或任务的不同阶段有不同的值,若系统正在进行测控任务或正在执某时间段,则将监测单元置为非正常关机值。那么系统复位后可据此单元判系统原来的运行状态,并跳到出错处理程序中恢复系统原运行状态。



(2)非正常复位后系统自恢复运行的程序设计
对顺序要求严格的一些过程控制系统,系统非正常复位否,一般都要求从失控的那一个模块或任务恢复运行。所以测控系统要作好重要数据单元、参数的备份,如系统运行状态、系统的进程值、当前输入、输出的值,当前时钟值、观测单元值等,这些数据既要定时备份,同时若有修改也应立即予以备份。



当在已判别出系统非正常复位的情况下,先要恢复一些必要的系统数据,如显示模块的初始化、片外扩展芯片的初始化等。其次再对测控系统的系统状态、运行参数等予以恢复,包括显示界面等的恢复。之后再把复位前的任务、参数、运行时间等恢复,再进入系统运行状态。



应当说明的是,真实地恢复系统的运行状态需要极为细致地对系统的重要数据予以备份,并加以数据可靠性检查,以保证恢复的数据的可靠性。其次,对多任务、多进程测控系统,数据的恢复需考虑恢复的次序问题。



系统基本初始化是指对芯片、显示、输入输出方式等进行初始化,要注意输入输出的初始化不应造成误动作。而复位前任务的初始化是指任务的执行状态、运行时间等。



对于软件抗干扰的还有一些其它常用方法,如数字滤波、RAM数据保护与纠错等。在工程实践中通常都是几种抗干扰方法并用,互相补充完善,才能取得较好的抗干扰效果。从根本上来说,硬件抗干扰是主动的,而软件抗干扰是被动的。细致周到地分析干扰源,硬件与软件抗干扰相结合,完善系统监控程序,设计一稳定可靠的单片机系统是完全可行的。  

使用特权

评论回复
沙发
modesty3jonah| | 2024-11-8 20:56 | 只看该作者
单片机系统抗干扰能力的提升,软件和硬件都非常重要,它们相辅相成,缺一不可

使用特权

评论回复
板凳
wwppd| | 2024-11-8 22:47 | 只看该作者
对于输入信号,先通过硬件滤波去除大部分干扰,再用软件数字滤波进一步提炼纯净信号

使用特权

评论回复
地板
plsbackup| | 2024-11-8 22:57 | 只看该作者
硬件抗干扰更为主动、根本,能从源头切断干扰的传播,效果立竿见影,但需要一定的硬件开销

使用特权

评论回复
5
chenjun89| | 2024-11-8 23:04 | 只看该作者
抗干扰是软硬件综合考虑的事

使用特权

评论回复
6
gygp| | 2024-11-9 07:27 | 只看该作者
硬件抗干扰措施在系统设计之初就需要考虑,能够在系统运行前就预防潜在的干扰问题。

使用特权

评论回复
7
belindagraham| | 2024-11-9 07:50 | 只看该作者
由软件实现的硬件功能,一般响应时间比硬件实现长

使用特权

评论回复
8
yeates333| | 2024-11-9 08:27 | 只看该作者
硬件抗干扰措施能从根本上减少干扰的产生和进入系统。例如,在电源方面,采用隔离电源可以防止外部电源干扰通过电源线直接进入单片机系统;使用低通滤波器能过滤掉电源中的高频噪声干扰,为单片机提供稳定的电源。这些措施直接针对干扰源进行处理,从源头降低了干扰对系统的影响。

使用特权

评论回复
9
abotomson| | 2024-11-9 09:58 | 只看该作者
软件抗干扰措施可以通过升级和更新来改进,而硬件通常需要更换或修改。

使用特权

评论回复
10
yeates333| | 2024-11-9 11:18 | 只看该作者
软件抗干扰措施通常可以通过修改程序代码或升级软件版本来进行改进和优化,便于系统的维护和升级。

使用特权

评论回复
11
loutin| | 2024-11-9 11:46 | 只看该作者
单片机系统抗干扰方面软件和硬件都至关重要,它们相互补充、相辅相成,共同确保系统在复杂环境下的稳定运行。

使用特权

评论回复
12
51xlf| | 2024-11-9 13:15 | 只看该作者
硬件抗干扰的优点是能够从根本上减少干扰的影响,特别是在高频和高功率的应用中,硬件措施是必不可少的。

使用特权

评论回复
13
wwppd| | 2024-11-9 14:03 | 只看该作者
在硬件方面,可以采取电源滤波、屏蔽、接地设计等措施来减少干扰的侵入;在软件方面,可以采用指令冗余、看门狗定时器、软件陷阱等技术来提高系统的容错能力和自恢复能力。

使用特权

评论回复
14
mnynt121| | 2024-11-9 14:34 | 只看该作者
通常,多层次、多手段的抗干扰策略更为有效。例如,可以先在硬件层面进行初步的抗干扰处理,然后在软件层面进行进一步的检测和恢复。

使用特权

评论回复
15
rosemoore| | 2024-11-9 15:43 | 只看该作者
良好的接地可以有效减少电磁干扰的影响。

使用特权

评论回复
16
febgxu| | 2024-11-9 17:14 | 只看该作者
系统有一个良好的接地系统,以减少电磁干扰。

使用特权

评论回复
17
maqianqu| | 2024-11-9 18:21 | 只看该作者
可以说软件和硬件在抗干扰方面同样重要,只是它们各自侧重不同的层面。理想的情况是,在设计单片机系统时,综合考虑硬件和软件抗干扰措施,以达到最佳的抗干扰效果。

使用特权

评论回复
18
linfelix| | 2024-11-9 18:56 | 只看该作者
硬件和软件在抗干扰方面都有其优势和局限性。一个良好的系统设计应该同时考虑硬件和软件的抗干扰措施。

使用特权

评论回复
19
yorkbarney| | 2024-11-9 21:43 | 只看该作者
硬件抗干扰措施可能会增加系统的成本和复杂性,尤其是在要求非常高的环境下。

使用特权

评论回复
20
phoenixwhite| | 2024-11-9 22:34 | 只看该作者
在一些对成本和硬件资源要求较高的应用场景中,软件抗干扰具有明显的优势。相比于增加硬件抗干扰电路所需的额外元器件和电路板空间,软件抗干扰只需要在单片机的程序代码中加入相应的抗干扰算法即可,能够大大节省硬件资源和成本

使用特权

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

本版积分规则

33

主题

1505

帖子

0

粉丝