- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
自检程序
自检的方法
实际的智能仪器种类很多,需要自检的项目也各不相同,在此仅介绍一些常见的检测项目和常用的检测方法。
一 ROM的检测
ROM中存放着仪器的监控程序、工作程序和常数表格,不允许出任何故障,故ROM的检测至关重要。最常用的校验方法是采用“校验和”的方法。
自检原理在将智能仪器程序的机器码写入ROM时,在最后一个单元写入“校验字”。“校验字”应能满足ROM中所有单元的每一列都具有奇数个“1”。自检程序对每一列进行异或运算,若ROM无故障,各列的运算结果均应为“1”,即校验和等于FFH,否则,表明ROM有故障。也可以设计为“校验字”满足ROM中所有单元的每一列都具有偶数个“1”。自检程序对每一列进行异或运算,若ROM无故障,各列的运算结果均应为“0”,即校验和等于00H。或直接将所有程序的异或运算结果存储在ROM中,自检时求出所有程序的异或和并与存放在ROM中的正确结果相比较,若相等则ROM无故障。
从理论讲,此方法不能发现同一列上的偶数个错误,但同一列上出现两个以上错误出现的概率极小,可不予考虑。若要考虑则需采用更复杂的校验算法。程序流程图:见附图2-1所示源程序清单:见附件2-1。附件2-1 ROM自检子程序data1为程序的起始地址data2为程序的结束地址data3为代码校验和(异或运算)的存储单元地址TROM0:MOV DPTR,#data2
PUSH DPH ;程序的结束地址进栈
PUSH DPL
MOV DPTR,#data1 ; CLR B
TROM1:CLR A
MOVC A,@A+DPTR ;读ROM
XRL B,A ;异或运算,结果存入B
POP A ;结束地址低8位出栈
MOV R2,A结束地址低8位 CJNE A,DPL,TROM3 ;当前地址≠结束地址转移
POP A ;结束地址高8位出栈
CJNE A,DPH,TROM2 ;当前地址≠结束地址转移
AJMP TROM4
TROM2:PUSH A ;结束地址高8位进栈
MOV A,R2
TROM3:PUSH A ;结束地址低8位进栈
INC DPTR ;指向下1单元
AJMP TROM1 ;继续下一单元的异或和运算TROM4:MOV DPTR,#data3 ;代码校验和存储地址
CLR A
MOVC A,@A+DPTR ;读代码校验和
XRL A,B ;A、B相等时,(A)=0
JNZ TROM5 ;(A)≠0,ROM故障CLR 2FH.0 ;清除标志
RET
TROM5:SETB 2FH.0 ;置标志
RET
附件2-2 RAM自检自程序
有的纯仿真软件不允许向SP以上的地址写入数据
TRAM0:MOV SP,#7FH
MOV R0,#7FH ;置初始地址指针
TRAM1:MOV @R0,#55H
MOV A,@R0
CJNE A,#55H,TRAM2 MOV @R0,#0AAH
MOV A,@R0
CJNE A,#0AAH,TRAM2
DJNZ R0,TRAM1
CLR 2FH.1 ;清除标志
RET
TRAM2:SETB 2FH.1 ;置标志
MOV SP,#5FH
RET
方波源程序
ORG 0000H
AJMP START
ORG 0050H
START: MOV DPTR,#0FEFFH
LP: MOV A,#0FFH
MOVX @DPTR,A
LCALL DELAY
文档评论(0)