存储器故障诊断算法的研究及实现.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
作者:?来源:电子与封装/刘炎华1?景为平2 1 东南大学集成电路学院 2南通大学?上网日期:?2007年01月18日1 引言  存储器是各种电子设备中保存信息的主要部件,随着存储器芯片的密度和复杂度的日益提高,设计一个良好的测试算法来测试存储器变得尤为重要,存储器按功能,主要可分为随机存储器(RAM)和只读存储器(ROM)。  随机存储器(RAM)根据存储阵列所用的电路类型可分为静态随机存储器(SRAM)、动态随机存储器(DRAM),只读存储器(ROM)可分为掩模编程ROM和现场可编程ROM。  2 存储器的故障模型  研究存储器的检测方法,就必须先建立存储器单元的故障模型,也就是要求把物理故障模型化为逻辑故障,通常可以用功能模型或灰匣子模型将存储器故障模型化,典型RAM功能模型如图1所示,该模型是由Vande Goor提出的简化功能DRAM模型[1]。  ?  对于图1的功能模型,存储器的故障主要表现有3类:  (1)地址解码器故障(AF)[2],主要表现为4种形式(如图2所示)。  ?  (2)读写逻辑模块故障。主要表现为在读写电路中,某些检测放大器的出或者写入驱动器的逻辑部分,可能产生开路、短路或者I/O固定的故障,在读写电路的数据线之间存在交叉耦合的干扰。  (3)存储单元阵列故障,由于存储单元阵列是存储器内规模最为复杂的一个模块,因此出现故障的概率最大,故障的类型也最为复杂,主要是由于存储器单元内的数据线开路、短路以及串扰所引起的。  对于上述的功能模型去掉其中的某些逻辑模块,就可用于ROM的测试。  3 存储器的简化功能故障[2、5、6]  基于以上各模块的故障表现形式,又由于地址译码故障和读写逻辑故障可以等效的功能映射为存储器单元阵列故障,故可把存储器故障简化为下列四种功能故障:  (1)固定故障(stuck-At Fault,SAF)  单元或连线的逻辑值总为0或总为1的故障,单元/连线总是处于有故障的状态,并且故障的逻辑值不变。  (2)转换故障(Transition Fault.TF)  转换故障是SAF的一种特殊情况,当写数据时,某一存储单元失效使得0→1转变或1→0转变不能发生,表现为固定故障的形式。  (3)耦合故障(Coupling Fault,CF)  存储单元中某些位的跳变导致其他位的逻辑发生非预期的变化,它既可以发生在不同单元之间,也可以发生在同一单元不同位之间。  (4)相邻矢量敏化故障(Neighborhood Pattern Sensitive Faults,NPSF)  一个单元因相邻单元的活动导致状态不正确,一个单元的相邻单元可能有5个,也可能有9个,如图3的(a)、(b)所示。  ?  4 存储器故障诊断算法分析  针对存储器故障模型中的各种故障,人们提出了各种诊断算法,目前主要使用的算法有:Checkerboard算法(棋盘法)、Gallop算法(奔跳法)、March算法(进行法)等。  4.1 Checkerboard算法(棋盘法)[7]  棋盘法的测试过程是首先对每一个存储单元赋值,使得每一个单元与其紧相邻的各个单元的值都不同,如图4所示,即把整个存储阵列分为两块a、b,然后采用如下过程对a、b进行读写;  (1)对分块a(b)中的单元写0(1);  (2)读所有单元;  (3)对分块a(b)中的单元写1(0);  (4)读所有单元;  (5)该算法理论上操作的次数是O(N),其中N为存储器容量,可以检测SAF故障和相邻单元的桥接故障,其故障覆盖率较低。  ?  4.2 Gallop算法(奔跳法)[5,7]  Gallop算法也称为1(0)漫游或乒乓测试,测试过程如下:  (1)部分地址单元清0(1);  (2)A0写1(0),然后A1读0(1),A0读1(0),然后A2读0(1),A0读1(0),接着A3读0(1),A0读1(0),直到全部单元;  (3)将A0改写为0(1),写A1为1(0),重复以上步骤。  整个过程就像1(0)在整个阵列中漫游一样,图5表示1漫游的情况,该算法具有较高的故障覆盖率,能检测SAF故障、TF故障以及CF故障,单位该算法操作次数是O(N2)需要较长的测试时间。  ?  4.3 March算法(进行法)[3,4]  (1)全部单元中写0;  (2)读A0单元的0,然后再改写为1,然后读A1的0,再改写A1为1,直到An-1。这样所有单元均为1;  (3)然后从An-1到A0作读1写0再读0的操作。  该算法的操作次数为O(N),能检测全部的SAF故障、AF故障以及TF故障。5 一种基于棋盘算法的改进及实现  通过研究和对比上述3个算法发现,Checkerboard(棋盘)算法和March算法以线性方式进行读写,因此存储器操作次数与存储器容量N

文档评论(0)

0520 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档