当前位置: 首页 > news >正文

MBIST - Memory BIST会对memory进行清零吗?

MBIST(Memory Built-In Self-Test)的核心目标是检测存储器(RAM, ROM, Cache等)的物理缺陷(如单元失效、位线/字线故障、耦合故障等),而不是执行功能性的清零操作。不过,MBIST的测试过程本身会覆盖性地写入特定的测试模式,这可能(但不一定)导致存储器原有数据被覆盖或“清零”

具体分析整理如下:

  1. MBIST 测试的本质是“读写测试”:

    • MBIST 通过执行一系列精心设计的测试算法来检测故障。
    • 这些算法的核心步骤就是反复地对存储单元进行写入(Write)和读取(Read)操作,并比较读取结果与预期值。
    • 写入操作是测试的必需步骤。为了检测一个单元是否能正确存储0和1,MBIST 必须向该单元写入0,读出验证;再写入1,读出验证(或按算法规定的顺序进行)。
  2. 测试过程会覆盖原有数据:

    • 当 MBIST 启动时,它不关心存储器中当前存储的数据是什么
    • 为了执行测试,MBIST 控制器会按照选定的测试算法,向存储器的地址空间写入特定的测试模式(例如,全0、全1、0/1交替、棋盘格模式等)。
    • 这个过程必然会覆盖掉存储器在测试开始前存储的所有用户数据或系统数据。 从这个角度看,执行一次完整的 MBIST 测试后,存储器的内容不再是测试前的原始数据,而是最后一次测试写入操作留下的数据模式
  3. 测试结束后的状态:

    • 测试结束时,存储器的内容取决于:
      • 所使用的测试算法: 不同的算法最后一步写入的模式不同(可能是0,也可能是1,或者是某种特定模式)。
      • 算法是否执行完成: 如果测试中途因故障停止,内容则是故障发生前最后写入的状态。
      • BIST 控制器的设计: 有些设计可能在测试完成后有意将存储器置为某种已知状态(例如全0),但这不是 MBIST 的标准或核心目标,而是额外的设计选择。
    • 标准 MBIST 本身不保证存储器被“清零”。它最后写入的可能是1,也可能是0,或者是0和1混合的特定测试模式(如棋盘格)。它不会特意执行一个将所有位都写0的操作(除非算法最后一步恰好是写全0)。
  4. “清零”是否是目标?

    • MBIST 的原始目标不是清零: MBIST 的首要且核心目标是故障检测(Pass/Fail 判定)。数据覆盖是其实现测试的必要副作用。
    • 清零可以作为安全或初始化需求: 如果系统要求在测试后或启动前存储器处于清零状态(例如出于安全考虑或初始化需求),这通常需要:
      • 额外的硬件清零逻辑: 在 MBIST 控制器之外,专门设计一个状态机或逻辑来执行全存储空间写0操作。这个逻辑可以与 MBIST 集成,但本质上是独立的功能。
      • 软件清零: 在 MBIST 测试完成后,由 CPU 运行软件循环来写0。但这依赖于系统能正常工作。

因此:

  • MBIST 测试过程必然会覆盖(破坏)存储器原有的数据。
  • 执行一次完整的 MBIST 测试后,存储器的内容会被测试算法最后写入的模式所填充。
  • MBIST 本身的设计目的和标准行为不是特意将存储器“清零”。 它不保证测试后存储器内容是全0。
  • 如果需要确保存储器在 MBIST 后处于清零状态,必须额外实现专门的硬件清零逻辑或在软件控制下进行清零操作,这不是 MBIST 的固有功能。
http://www.xdnf.cn/news/1144189.html

相关文章:

  • 基于单片机的便携太阳能光伏系统研究
  • C语言—如何生成随机数+原理详细分析
  • 20250718-FDU-HDUOJ钉耙编程一
  • 初探:C语言FILE结构之文件描述符与缓冲区的实现原理
  • 更适合后端宝宝的前端三件套之HTML
  • CentOS7 内网服务器yum修改
  • 有好内容,如何做好知识变现?
  • 【Zephyr开发实践系列】08_NVS文件系统调试记录
  • GEV/POT/Markov/点过程/贝叶斯极值全解析;基于R语言的极值统计学
  • 【案例教程】基于现代R语言【Tidyverse、Tidymodel】的机器学习方法与案例分析实践技术应用
  • [AI8051U入门第五步]modbus_RTU主机
  • stack and queue 之牛刀小试
  • Excel批量生成SQL语句 Excel批量生成SQL脚本 Excel拼接sql
  • 大型市政污水处理厂“智变”记:天拓四方IOT平台让磁悬浮鼓风机“活”起来
  • React 实现人员列表多选、全选与取消全选功能
  • MC0457符咒封印
  • Ansible + Shell 服务器巡检脚本
  • mysql not in 查询引发的bug问题记录
  • pycharm结构查看器
  • 2.3 前端-ts的接口以及自定义类型
  • 哪个厂家生产的戒烟药好:从机制到体验的差异化博弈
  • MySQL 插入时间 更新时间
  • 推荐 1 款 4.5k stars 的AI 大模型驱动的开源知识库搭建系统
  • 跨域问题及解决方案
  • AI(day10)模块化编程概念(模块、包、导入)及常见系统模块总结和第三方模块管理
  • Java Web项目Dump文件分析指南
  • LLM(Large Language Model)大规模语言模型浅析
  • 在 Jenkins 中使用 SSH 部署密钥
  • 游戏盾能否保护业务免受DDoS攻击吗?
  • C语言基础:数组练习题