RAM Sequential

article/2025/8/20 11:29:25

    前段时间,在公众号上偶然看到一篇很不错的技术分享文章:《南湖处理器DFT设计范例》。文中详细介绍了中科院计算所的RISC-V处理器实施的DFT设计。

    去年,也基于一款处理器应用过Share Test Bus技术,但在memory界面fault测试的问题,我注意到南湖的测试方法(RAM_sequential)更加友好。本文针对这方面内容,做了一些简单的技术总结。

    通常,我们通过memory compiler 编译SRAM时,可以有以下几种选择或者场景:

    编译是否打开Test 专用的pin/bus: TA/A, TD/D

    编译器是否支持embedded scan chain

    然后,环绕memory界面的缺陷测试,我们的通常选择也有如下几种:

    1. RAM Bypass

        在测试模式下,将RAM Bypass, 实现从写一侧逻辑拉到读一侧,提高缺陷测试的覆盖率。

        在该方案下,我们注意到,进出memory的一段Net,实际上测试不到的。那么这部分,其实可以通过MBIST pattern 测试覆盖到。

        

        但是,如果memory 编译时将功能BUS 和MBIST Test BUS 分开的话,这样就没办法用MBIST pattern 覆盖剩下的那部分测试。

    2. Shadow logic

        本质上,就是添加Control Point 和Observe point, 与RAM Bypass 方案其实比较接近。

    3. RAM sequential Test

        如果上述功能BUS与Test BUS 分开的场景;

        或者,有些Core 有专门的Share Test Bus;

        特别是,后者,我们既然已经采用了Share Test Bus 方案,避免了常规MBIST 方案会在SRAM 附近增加很多逻辑(对PD和Timing 很友好)。那么前述的Shadow logic insertion 或者RAM Bypass 方案,都不再合适了。

        那么对,这两种场景,都将需要用到南湖方案:RAM Sequential Pattern.

        首先,以Memory Dataout BUS的Transition 测试流程为例,总结一下这个过程。

        测试流程:

        1. 通过scan chain load 给到Memory 前的Data flops = 0, Addr flops =0;

        2. 通过OCC/OPCG 给定第一个Pulse, 将Data flops (D=0) 读入Memory 相应的地址(Addr =0)。    

        同时,将Data1 flops/Addr1 flops 的值更新到 Data flops/Addr flops

        3. 通过OCC/OPCG 给定第二个Pulse, 将Data flops 的新值(D=1)读入Memory 相应的地址(Addr =1)

        同时,Addr flops 从前级拿到新值,Addr = 0

        4. 通过OCC/OPCG 给定第三个Pulse, 将Addr =0 的值读出到Memory Data Output.

        同时,Addr flops 从前级拿到新值,Addr = 1

        5. 通过OCC/OPCG 给定第四个Pulse, 将Addr = 1的值读出到Memory Data Output.

        同时, Observe flops 读到了前面Addr =0 的值,

        6. 通过OCC/OPCG给定第五个Pulse, 

        同时,Observe flops 读到了前面Addr = 1的值。

    

    下图展示了读端口Transition 测试的时序图:

cf1c62526e2b47c0a7d518208899ee67.png

    下图,展示了,memory及周围电路的示意图:

d8603352b8e547e6a7db19296187be0d.png

    当然,如果Memory有embedded scan chain, 界面测试就更简单一些了。SRAM IP 就像一个IEEE1500 compliant Core 一样了,甚至像一个大号的MUX-D flop.


http://chatgpt.dhexx.cn/article/hi7v5ibQ.shtml

相关文章

monoSLAM

单目相机的优点(和双目相机相比):双目相机测得的深度距离收到基线长度的限制,单目相机就可以解决这个问题。 参考博客:http://blog.csdn.net/heyijia0327/article/details/50758944 (一定要看&#xff0c…

Linux一键实现ramos打造自己的livecd

软件名:remastersys作者:nerun个人亲测可用,kali和ubuntu下都成功了,直接一键将当前使用的系统打包成iso,启动测试如下:1:iso直接加载启动成功进入ramos2:iso解压文件到根目录&#…

RAMOS系统简介及制作

同步发布在个人博客上:https://www.zhyong.cn ,可通过搜索文章名称找到该文章! RAMOS系统简介 内存操作系统(RAMOS)是全内存运行,启动后不依赖硬盘的Windows系统。它的原理是利用特殊的软件把多余的内存虚拟为内存盘,然…

如何打造内存操作系统RAMOS?

如何打造内存操作系统RAMOS?添加链接描述 把系统放进内存里 自己打造高速RAMOS 所谓内存操作系统就是全内存运行,系统将不再依赖硬盘。如今科技这么发达,电脑内存也越来越大,如果我们可以利用剩余内存来制作虚拟磁盘&#xff0c…

RAMOS(全内存操作系统)初识----仅供测试

内存操作系统(RAMOS)是全内存运行,启动后不依赖硬盘的Windows系统。它的原理是利用特殊的软件把多余的内存虚拟为内存盘,然后将制作好的操作系统镜像释放到这个虚拟内存盘中运行,让Windows操作系统和应用软件完全工作于内存之中,从…

英语拼读规则

前言: 想学英语就要用英语的思维去学。不能用某国某人指定的方法。误人子弟呀!! 一、就英语就要像学汉语一样要学会拼音,拼音会了汉字自然就会读了。 第一步:26个字母的【音标】要记牢。不只会写字母 也要会写字母对应…

英语名词复数s的发音规则

目录 1. 英语名词复数s的发音规则 1. 在清辅音后发/s/,[p], [t], [k], [h]; [f], [x], [s], [𝛉], [ꭍ]; [ts], [tr], [tꭍ]。记忆顺口溜:婆婆有位特殊的客户 ,她叫福西施,t前缀 2. 在浊辅音和元音后发/z/音&#x…

英语口语中的音变现象及读音规则

英语口语中的音变现象是指再说英语的过程中出于“省力” 的原因,在读英语的时候唇舌处于放松的状态,可以让我们更轻松地说英语。音变现象包括:连读,弱读,缩读,浊化,异化。这五大音变现象最具有代…

英语语法---读音规则

一、48个音标(音素)简表(18大语音语变现象) 单元音又分为前元音、中元音和后元音,其区分点在于发音时舌身是在口腔的前部、中部还是后部 音素发音链接:https://en-yinbiao.xiao84.com/ 18大语音语变现象&…

链表之头指针、头结点、首元结点、空链表

链表之头指针、头结点、首元结点、空链表 文章目录 链表之头指针、头结点、首元结点、空链表前言疑问整理头指针,头结点,首元结点定义首元结点定义头指针定义头结点定义 疑问回答 前言 最近在用力扣刷链表的题,总是写不出来,对这…

求二叉树指定结点到根结点的路径c++ 非常详细。

看了很多 没有看见完整的代码 我喜欢喂饭喂到嘴边。 部分代码参考16 二叉树:以x为根的子树的深度_DHU杨骅麟(紫外线过敏)的博客-CSDN博客 面试经典(16)--二叉树根节点到指定节点的路径_nginux的博客-CSDN博客_二叉树根节点到目标节点路径 运…

二叉树的结点数

二叉树的结点数(*) (10分) 已知二叉树的结点结构定义如下: typedef struct _NODE_ {char data;struct _NODE_ *lch, *rch; } NODE; 说明:data 为数据域,均为英文大写字母。lch 和 rch 分别为指示左、右孩子的指针。 请编写函数,求二叉树的结点个数。 函数原型 // 结点…

求一个结点x在在二叉树中的双亲结点算法

1、算法思想 使用先序递归遍历思想完成算法设计。首先判断节点的左右孩子是否存在,若存在,并且左右孩子中有一个符合查找要求,则返回元素!否则,继续递归查找,直到成功或者找不到符合要求的结点&#xff01…

计算二叉树中结点的个数

思想: 递归实现 图示为举例二叉树进行思路解释 二叉树中结点的个数:只要能计算出A左子树的个数A右子树的个数1 左子树个数:以B为结点的左子树个数右子树个数1 右子树个数:以C为结点的左子树个数右子树个数1 . . . .&#xff0…

(图解)单链表删除结点值为x的结点算法

目录 一、非递归的算法 第一种算法思路如下: 第二种算法思路如下: 二、递归的算法 一、非递归的算法 第一种算法思路如下: 先判断链表L是否为空,空链表退出程序;用p利用while循环从头到尾扫描单链表,p…

单链表的基本操作-插入结点、删除结点、新建链表、查找结点位置

** C语言新手小白的学习笔记-------------目前持续更新中 ** 本人90后电气工程及其自动化大学生,大二开始接触C语言,写过前端,Python,但是都不精通,通过许多认识后明白了自身的许多不足,因此,…

武汉轰趴团建年会的疯狂玩法活动不一样的经历

又是一年的历程与工作,今年来一点新花样,来吧,让我们一起快乐冲向前,空气中满是不一样的欢声笑语,让我们一起感受不一样的年会趴,让我们一起去快乐的游玩吧。武汉轰趴团建年会的疯狂玩法活动不一样的经历 感…

天猫双11全球狂欢节的诞生,源于对快乐的分享

时光荏苒,天猫双11全球狂欢节,如今已经迈入了第十个年头。 相信有不少读者小伙伴都知道,双11最早其实源于中国的“光棍节”。那么这样一个原本应该是单身狗们黯然神伤的日子,究竟是如何演变成一场让无数消费者和商家都激情澎湃的购…