NOR Flash基本原理

news2025/1/24 14:51:02

目录

1. Flash Memory中存储的信息

2. Flash操作

2.1 Read操作

2.2 Program操作

2.3 Erase操作

3 电压阈值分布

4 Block Erase

4.1 Pre-Program Phase

4.2 Erase Phase

4.3 Recovery Phase

5 Erase 中断

6 注意要点


        这是之前搞Flash IP时的一个学习笔记,有点记不清楚出处是在哪里了,分享给大家关于Nor Flash的理解

        NOR Flash的一个基本原理是必须先将其擦除,然后才能对其进行编程。另一个重要特征是擦除操作必须同时(批量)发生在整个内存块上,而不是按字节逐字节的方式依次发生。

        所以,Erase操作包含了三个步骤:Pre-Program,Erase,Recovery。了解这个三个步骤中硬件原理是提升系统鲁棒性的重要因素。

1. Flash Memory中存储的信息

        存储器的基本存储元件(单元)是由带“浮栅”的MOSFET组成的。困在存储单元浮栅内的电荷量决定了存储单元是否被编程或被擦除,浮栅中可以存储电荷,从而改变该单元的控制栅极(Control Gate)开关阈值电平Vth,当浮栅中没有电荷时(Erased)表示为“1”, 当浮栅中存有负电荷/电子时(Programmed)表示为“0”。如下图所示:

Source:源级

Tunnel Oxide:隧道氧化层

Control Gate:控制栅

Floating Gate:浮栅

Drain:漏极

P-well:P型衬底;每个p-well都有自己的电极,允许它在存储控制器的控制下,以特定的电压进行偏置。

Substrate:硅制造要求所有的存储单元都建立在一个共同的基础

        擦除、读取、编程等操作后续具体讲。

        为了存储大量的信息,Flash Memory由memory cell按照N行M列来组成,每个行列交叉点都是一个cell,存储一个bit数据。因此一个flash的容量就为N*M bit。为便于记忆,我们把行叫做Word-line(WL),列叫做Bit-Line(BL)如下所示:

        从上图看到,漏极通过bitline连接在一起,WL连接到控制栅;PAGE是一个WL中所有BL的集合,通常一个WL可以包含一个或者多个page。

        重要的一点是,在每个physical block中,p-well和BL是共享的。

        更进一步的,每个物理block可以分为更小的逻辑sector,方便管理。

2. Flash操作

        对于Nor Flash来说,在写block之前必须擦除,并且擦除操作还要包括对已擦出的cell进行预编程。

2.1 Read操作

        要确定单元格的状态(是已编程还是已擦除),必须读取单元格的内容,这是通过在MOSFET的栅极上施加大约5.5 V的参考电压来完成的。

        如上图:Q1状态是已擦除,浮栅里被捕获电子耗尽了,由于其GATE-SOURCE阈值电压比VTREF小(VGSTH1<VTREF)。当确定该单元的状态时,对GATE施加一个5.5V的电压,这种情况下,MOSFET传导电流,因此处于逻辑“1”。

        如上图:Q1状态是已编程,浮栅里充满了被捕获电子,由于其GATE-SOURCE阈值电压比VTREF大(VGSTH2>VTREF)。当确定该单元的状态时,对GATE施加一个5.5V的电压,这种情况下,MOSFET不传导电流,因此处于逻辑“0”。

        通常情况下,浮栅不带电荷,则场效应管处于不导通状态,场效应管的漏极电平为高,则表示数据1。

        编程时,场效应管的漏极和选择栅都加上较高的编程电压,源极则接地。这样大量电子从源极流向漏极,形成相当大的电流,产生大量热电子,并从衬底的二氧化硅层俘获电子,由于电子的密度大,有的电子就到达了衬底与浮栅之间的二氧化硅层,这时由于选择栅加有高电压,在电场作用下,这些电子又通过二氧化硅层到达浮栅,并在浮栅上形成电子团。浮栅上的电子团即使在掉电的情况下,仍然会存留在浮栅上,所以信息能够长期保存(通常来说,这个时间可达10年)。由于浮栅为负,所以选择栅为正,在存储器电路中,源极接地,所以相当于场效应管导通,漏极电平为低,即数据0被写入。由于热电子的速度快,所以编程时间短,并且数据保存的效果好,但是耗电量比较大。

        擦除时,源极加上较高的编程电压,选择栅接地,漏极开路。根据隧道效应和量子力学的原理,浮栅上的电子将穿过势垒到达源极,浮栅上没有电子后,就意味着信息被擦除了。

2.2 Program操作

        编程操作是基于称为“热电子注入”的物理过程。GATE与大电压相连(通常为+9V),同时漏极正偏压到约+ 4v,导致电子流从源极流向漏极。由于应用于GATE的强正电场,一些电子被“拉进”浮栅。一旦进入,这些电子就不再拥有逃离浮门限制所需的能量,它们仍然被困住:Cell被编程了。

        为了将一个单元置于编程状态,所需要的阈值电压至少要大于5.5V,最好6.5V.。

2.3 Erase操作

        擦除操作是基于Fowler-Nordheim Tunneling隧穿。

        首先往p-well添加正电压(约+8V),用于吸引浮栅中被困电压;同时,在选择栅施加负电压(-10V),用于排斥电子,因此源极和漏极断开。

        这两种电压叠加并产生一个大的电场,使电子能够隧穿氧化层。通过这个过程,浮栅耗尽了电子,降低了它们的阈值电压。如果观察单个细胞水平(通常在nA范围内),电流是微小的。由于电流非常小,电场必须维持很长时间才能提取足够数量的电子,这使得Erase操作相对缓慢

3 电压阈值分布

        VT是电池中MOSFET在特定水平(通常为10 uA)上传导电流所需的阈值电压。它与浮栅中被困的电荷量有关。含有大量被捕获电子的Cell(程序Cell)具有较高的VT,通常为6.5 V或更高。耗尽电子的cell(擦除cell)具有较低的VT,通常为4v或更低。

        在擦除和编程之间的VT范围的中间通常被用作参考阈值电压(VTREF),以确定特定的一组单元是否被编程或擦除。该电压用于被选择的WL(Word-Line),根据每个cell的浮栅状态以及被解码/选择的位行,模拟信号输出到shared WL。当WL电压从低电压依次增加到高电压时,y轴记录了从擦除状态切换到编程状态的单元数。

4 Block Erase

        在NOR Flash的生命周期内,设备会被多次擦除和编程。在这个过程中,由于单个单元的状态从被编程变为被擦除,VT分布发生了变化,反之亦然。为了保持良好的VT分布和良好的边距,Erase操作分三个不同的阶段完成:

  1. Pre-Program Phase
  2. Erase Phase
  3. Recovery Phase

4.1 Pre-Program Phase

        预编程的目的是为了让擦除操作工作在一个理想环境下。理论上讲,Erase操作同时影响所有cell,两个驼峰(橙色和蓝色曲线)都会向左移动。已经被擦除的cell位于负的VT区域,这在物理上是不可能的,因此,这些单元在VT接近0v时变得过度擦除,即使它们的栅极电压设置为0v时也会漏电流。

        因此,通过预编程,所有cell都处于编程状态,这样可避免过擦出现,如下:

4.2 Erase Phase

        Block Erase与Erase操作相同,不过是同时发生在完整的Logica块中;

        一个巨大的电场——施加在物理块的公共p-well上的正电压(+8 V),以及施加在被擦除的逻辑块内的所有WL上的负电压(-10 V)——使电子“隧穿”通过potential barrier。浮栅损耗越来越大,VT电压降低。

        在此过程中,一些cell可以移动到过度擦除的区域附近。如上所述,这种cell可以导电,即使当WL不活跃,其VT设置为接近0v。因为它是批量执行的,而且Erase操作必须持续到最慢的cell验证为止,因此Erase操作可能会导致较大的分布。

4.3 Recovery Phase

过度擦除的Cell被系统地软编程(以字节为基础),直到它们的VT足向右移动,以便它从左边越过恢复线。

        当内部算法正在进行时,Flash集成控制器保持一个用户可读的状态位断言(状态寄存器中的BUSY/READY位)。

5 Erase 中断

        如果擦除操作被设备重启或者电源关闭打断,此时擦除操作的三个阶段还没完成,会导致memory进入到一个undefined状态:可以是擦除三个阶段的任意状态,因此读取的数据不可信。

        如果Erase进程中断,内存设备可以通过几种不同的机制返回错误数据:

  1. 如果擦除中断是由软硬件复位、电源供电不足造成的,memory控制器会重启,并且会重置擦除操作。具体如下表所示

阶段

状态

影响

Pre-program

部分cell被编程,部分擦除

Block数据无意义

Erase

部分被编程、部分擦除、部分过擦

显示全部擦除,但某些bit处于过擦状态,擦除不完全状态

Recovery

部分被擦出、部分过擦

        过擦的bit,导致共享BL上的泄漏,从而导致共享同一物理BL上的所有其他位的编程裕度降低。

        上图展示了如果共享Bit Line上有一个泄露的cell,那么未选定WL上的“leaky cell”如何影响选定WL上“0单元格”的读取。当前选中WL[241],读取BL[1082]数据,但此时WL[65]BL[1082]处于过渡擦除状态;当泄漏量(漏电流)足够高时,所选单元中存储的“0”可能被错误读取为“1”。

        如果是由于Erase Suspend指令中断Erase操作,上述副作用同样会发生,区别在于,当前设备中的SUSPEND bit会置1,用户可用于追踪,通过考虑状态位的状态,如果采取适当的预防措施,可以确保操作的成功完成。虽然过度擦除不太可能损坏同一物理块中的数据,但最好不要在挂起期间将要编程或读取的数据映射到同一物理块中。

6 注意要点

  • 在发出软复位或硬复位和/或回收电源之前,始终检查BUSY/READY状态位是否有任何正在进行的操作。如果不这样做,可能会使内存处于未定义的状态,从而导致数据损坏;
  • 当确实需要中断擦除操作,使用Suspend 指令,并将重要的系统级代码(在进行EraseSuspend操作时需要读取的代码)保存在单独的物理块中,远离用于数据记录的内存或经常被擦除更改的memory;
  • 处理可能发生异步擦除中断的系统的另一种方法是,在逻辑块的开头编写一个唯一的字节值(“签名”),作为每次成功擦除操作的最后一步。如果由于计划外的电源中断或擦除操作过程中的小故障导致系统崩溃,作为崩溃恢复的一部分,将读取逻辑块的签名,并与已知的正确值进行比较。一个特定块的差异表明擦除操作没有正确完成,需要重复擦除,以恢复其正确的分布。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1164668.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

力扣 搜索旋转排序数组 二分

&#x1f468;‍&#x1f3eb; 33. 搜索旋转排序数组 class Solution {public int search(int[] nums, int target){int l 0;int r nums.length - 1;while (l < r){int m l r >> 1;//else大法&#xff0c;把无序段抛给else&#xff0c;if只处理有序段 // 需要特…

Flutter屏幕适配

文章目录 一、Flutter单位二、设备信息三、常见适配方案四、flutter_screenutil 一、Flutter单位 Flutter使用的是类似IOS中的点pt&#xff08;point&#xff09;。 iPhone6的尺寸是375x667&#xff0c;分辨率为750x1334。 iPhone6的dpr( devicePixelRatio ) 是2.0。 DPR 物…

论文 辅助笔记:t2vec train.py

1 train 1.1 加载training和validation数据 def train(args):logging.basicConfig(filenameos.path.join(args.data, "training.log"), levellogging.INFO)设置了日志的基本配置。将日志信息保存到名为 "training.log" 的文件中日志的级别被设置为 INFO&…

Vue动态树、配置请求路径、表格数据显示、实现分页、创建书本管理组件、点击菜单实现路由跳转以及系统首页配置。

目录 1. 准备工作 2. 动态树 2.1 在配置请求路径 2.2 使用动态数据构建导航菜单 2.2.1 通过接口获取数据 2.2.3 通过后台获取的数据构建菜单导航 2.2.3.1 先构建一级导航菜单 2.3 点击菜单实现路由跳转 2.3.1 创建书本管理组件 3. 系统首页配置 4. 表格数据显示 4.…

探密工业互联网网络体系:构建端到端的稳定传输

什么是工业互联网网络&#xff1f; 工业互联网网络是一种将工业设备、传感器和计算机系统连接到一起&#xff0c;以便它们可以共同工作、共享数据和实现更高效的生产和控制。这个网络体系的目标是提高工业过程的效率、可靠性和安全性。 在数字时代的今天&#xff0c;工业互联网…

无广告弹出的便签工具选择哪一款?

广告弹窗&#xff0c;是许多人在日常办公中比较反感的问题&#xff0c;打开一个软件正准备使用时&#xff0c;突然冒出一个广告弹窗&#xff0c;这会给人一种特别反感的情绪&#xff0c;尤其是在专注记录工作任务备忘的时候&#xff0c;意外冒出的广告窗口可真让人心烦。那么&a…

Apple 苹果发布 M3、M3 Pro 和 M3 Max 芯片

本心、输入输出、结果 文章目录 Apple 苹果发布 M3、M3 Pro 和 M3 Max 芯片前言M3、M3 Pro 和 M3 Max 芯片的性能相关资料图M3 Pro规格M3 Max规格弘扬爱国精神 Apple 苹果发布 M3、M3 Pro 和 M3 Max 芯片 编辑&#xff1a;简简单单 Online zuozuo 地址&#xff1a;https://blog…

若依框架中SpringSecurity的实现流程

文章目录 Spring Security概述核心原理 若依Sprint Security分析配置类分析流程分析图过滤器分析 若依登录/退出流程流程图登录退出 写在开头: 本篇博客与核桃共同完成 Spring Security 概述 Spring Security 是一个功能强大且高度可定制的身份验证和访问控制框架&#xff0c…

go微信开发sdk-简单使用_已设置图床

go微信开发sdk-简单使用 GitHub - silenceper/wechat: WeChat SDK for Go &#xff08;微信SDK&#xff1a;简单、易用&#xff09; 使用的sdk为上述的&#xff0c;这边给出快速的项目实例 git clone https://github.com/gowechat/example.git简单的项目结构 这边简单用dock…

多线程锁的升级原理是什么

在 Java 中&#xff0c;锁共有 4 种状态&#xff0c;级别从低到高依次为&#xff1a;无状态锁&#xff0c;偏向锁&#xff0c;轻量级锁和重量级锁状态&#xff0c;这几个状态会随着竞争情况逐渐升级。锁可以升级但不能降级。 多线程锁锁升级过程 如下图所示 多线程锁的升级过程…

数字孪生技术:城市交通的智能引领

城市交通问题一直是我们日常生活中的头等大事。交通拥堵、公共交通不便、环境污染等问题常常困扰着城市居民。然而&#xff0c;数字孪生技术正以令人兴奋的方式改变着城市交通的面貌&#xff0c;为城市交通带来了新的变化。 实时交通监测&#xff1a;数字孪生技术通过网络连接的…

动态规划:“以宇换宙”的优雅工艺

Those who do not remember the past are condemned to repeat it. 那些不能铭记历史的人注定要重蹈覆辙。 在动态规划——经典案例分析中我们提到了斐波那契数列的求解思路。知道动态规划的主要优点是能够在解决问题时避免重复计算&#xff0c;通过利用已经计算过的结果来加速…

Java实现Web的ashx对接ORM

之前的介绍已经实现了ORM的主体和Web的调用结构主题&#xff0c;那么这次把Web和LIS.Core的容器和ORM做对接&#xff0c;通过ashx实现的业务类测试调用ORM查询数据。 首先改造容器让传入根地址 package LIS.Core.Context;import org.w3c.dom.Document; import org.w3c.dom.El…

单例模式-懒汉式双重锁机制

正是因为担心并发问题&#xff0c;才在双重检查锁模式中的synchronized内部进行了再次判断 tnull。 在第一次判断 tnull 之后&#xff0c;当多个线程同时通过这个检查&#xff0c;其中一个线程会获得锁并创建实例。然而&#xff0c;其他线程在此期间可能会继续等待锁释放&…

ViT Vision Transformer超详细解析,网络构建,可视化,数据预处理,全流程实例教程

关于ViT的分析和教程&#xff0c;网上又虚又空的东西比较多&#xff0c;本文通过一个实例&#xff0c;将ViT全解析。 包括三部分内容&#xff0c;网络构建&#xff1b;orchview.draw_graph 将网络每一层的结构与输入输出可视化&#xff1b;数据预处理。附完整代码 网络构建 …

【Code Reading】Transformer in vision and video

文章目录 1. vit2. Swin-t3. vit_3D4. TimeSformer First&#x1f680;&#x1f680;5. vivit 1. vit 详细解释 在论文的Table1中有给出三个模型&#xff08;Base/ Large/ Huge&#xff09;的参数&#xff0c;在源码中除了有Patch Size为16x16的外还有32x32的。其中的Layers就…

基于MIMO通信系统的球形译码算法matlab性能仿真,对比PSK检测,SDR检测

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 MATLAB2022A 3.部分核心程序 ................................................................ for i1:length(SNR) Bit…

SpringCloud(六) Nacos配置管理

Nacos除了可以做注册中心,同样可以做配置管理来使用; Nacos做注册中心的使用和注意事项详看:SpringCloud(四) Nacos注册中心-CSDN博客 目录 一, 统一配置管理 1. 在Nacos中添加配置文件 2. 从微服务拉取配置 (1) 引入nacos-config依赖 (2) 添加bootstrap.yaml (3) 读取n…

相机存储卡被格式化了怎么恢复?数据恢复办法分享!

随着时代的发展&#xff0c;相机被越来越多的用户所使用&#xff0c;这也意味着更多的用户面临着相机数据丢失的问题&#xff0c;很多用户在使用相机的过程中&#xff0c;都出现过不小心格式化相机存储卡的情况&#xff0c;里面的数据也将一并消失&#xff0c;相机存储卡被格式…

Android13充电动画实现

充电动画 以MTK平台为例&#xff0c;实现充电动画 效果图 修改文件清单 system/vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/charging/BubbleBean.javasystem/vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/system…