STM32 NAND FLASH知识点

1.NAND FLASH的简介

NAND FLASH 的概念是由东芝公司在 1989 年率先提出,它内部采用非线性宏单元模式,为固态大容量内存的实现提供了廉价有效的解决方案。 NAND FLASH 存储器具有容量较大,改写速度快等优点,适用于大量数据的存储,在业界得到了广泛应用,如: SD 卡、 TF 卡、 U盘等,一般都是采用 NAND FLASH 作为存储的。 关于 NAND FLASH 的基础知识,请大家自行百度学习。接下来,我们介绍 NAND FLASH 的一些重要知识。

2.NAND FLASH 信号线

在这里插入图片描述因为 NAND FLASH 地址/数据是共用数据线的,所以必须有 CLE/ALE 信号,告诉 NAND
FLASH,发送的数据是命令还是地址。

3.存储单元

NAND FLASH 存储单元介绍,我们以 MT29F4G08( x8,8 位数据)为例进行介绍, MT29F4G08 的存储单元组织结构如图所示
在这里插入图片描述由图可知: MT29F4G08 由 2 个 plane 组成,每个 plane 有 2048 个 block,每个 block 由 64
个 page 组成,每个 page 有 2K+64 字节( 2112 字节)的存储容量。所以, MT29F4G08 的总容
量为: 2204864*( 2K+64) = 553648128 字节( 512MB)。其中, plane、 block、 page 等的个数,根据 NAND FLASH 型号的不同,会有所区别。

4.NAND FLASH 的地址

NAND FLASH 的地址分为三类:块地址( Block Address)、页地址( Page Address)和列地
址( Column Address)。以 MT29F4G08 为例,这三个地址,通过 5 个周期发送,如图所示
在这里插入图片描述
表中, CA0~CA11 为列地址( Column Address),用于在一个 Page 内部寻址, MT29F4G08
的一个 Page 大小为 2112 字节,需要 12 个地址线寻址; PA0~PA5 为页地址( Page Address),用于在一个 Block 内部寻址, MT29F4G08 一个 Block 大小为 64 个 Page,需要 6 个地址线寻址;
BA6~BA17 为块地址( Block Address),用于块寻址, MT29F4G08 总共有 4096 个 Block,需要
12 根地址线寻址。
整个寻址过程,分 5 次发送( 5 个周期),首先发送列地址,在发送页地址和块地址。这里提醒一下:块地址和页地址,其实是可以写在一起的,由一个参数传递即可,所以表中的 BA并不是由 BA0 开始的,大家可以理解为这个地址( PA+BA)为整个 NAND FLASH 的 Page 地址。在完成寻址以后,数据线 I/O0~ I/O7 来传输数据了。

5.NAND FLASH的控制命令

例如:读页命令
在这里插入图片描述
READ PAGE
该指令用于读取 NAND 的一个 Page(包括 spare 区数据,但不能跨页读),该指令时序如图所示:
在这里插入图片描述由图可知, READ PAGE 的命令分两次发送,首先发送 00H 命令,然后发送 5 次地址( Block&Page&Column 地址),指定读取的地址,随后发送 30H 命令,在等待 RDY 后,即可读取 PAGE 里面的数据。注意:不能跨页读,所以最多一次读取一个 PAGE 的数据(包括 spare区)。

6.FMC 接口的 NAND FLASH 控制寄存器

⚫ 独立 NAND FLASH 存储区域,可独立配置
⚫ 支持 8 位和 16 位 NAND FLASH
⚫ 支持硬件 ECC 计算(汉明码)
⚫ 支持 NAND FLASH 预等待功能

NAND FLASH 的控制寄存器: FMC_PCR,该寄存器各位描述如图所示:
在这里插入图片描述
该寄存器只有部分位有效,且都需要进行配置:
PWAITEN:该位用于设置等待特性: 0,禁止; 1,使能。这里我们设置为 0,禁止使用控制器自带的等待特性,因为如果使能的话,将导致 RGB 屏抖动( STM32 硬件 bug)。

PBKEN:该位用于使能存储区域: 0,禁止; 1,使能。我们要正常使用某个存储区域,必须设置该位为 1,所以,这个位要设置为 1。

PWID:这两个位,用于设置数据总线宽度: 00, 8 位宽度; 01, 16 位宽度。我们使用的MT29F4G08 为 8 位宽度,所以这里应该设置为: 00。

ECCEN:该位用于使能 STM32 的硬件 ECC 计算逻辑: 0,禁止/复位 ECC; 1,使能 ECC计算;每次读写数据前, 应该设置该位为 1,在数据读写完毕,读取完 ECC 值之后,设置该位为 0,复位 ECC,以便下一次 ECC 计算。

TCLR:这四个位用于设置 CLE 到 RE 的延迟: 0000~1111,表示 1~16 个 fmc_ker_ck 周期。对应 NAND FLASH 数据手册的 tCLR 时间参数: t_clr=(TCLR+SET+2)*Tfmc_ker_ck。 TCLR 就是本寄存器的设置值, SET 对应 MEMSET 的值(我只用到 MEMSET), Tfmc_ker_ck 对应fmc_ker_ck 的周期。 MT29F4G08 的 tCLR 时间最少为 10ns,以 220M 的 fmc_ker_ck 频率计算,一个 fmc_ker_ck=4.5ns(下同),我们设置 TCLR=5,则 t_clr 至少为 7 个 fmc_ker_ck 即 31.5ns。

TAR:这四个位用于设置 ALE 到 RE 的延迟: 0000~1111,表示 1~16 个 HCLK 周期。对应NAND FLASH 数据手册的 tAR 时间参数,这里设置的 t_ar=(TAR+SET+2)* Tfmc_ker_ck。 TAR就是本寄存器的设置值, SET 对应 MEMSET 的值(我只用到 MEMSET), Tfmc_ker_ck 对应fmc_ker_ck 的周期。 MT29F4G08 的 tAR 时间最少为 10ns,我们设置 TAR=5,则 t_ar 至少为 7个 fmc_ker_ck 即 31.5ns。

ECCCPS:这三个位用于设置 ECC 的页大小: 000, 256 字节; 001, 512 字节; 010, 1024字节; 011, 2048 字节;100, 4096 字节; 101, 8192 字节。我们需要以 512 字节为单位进行ECC 计算,所以 ECCCPS 设置为: 001 即可。

NAND FLASH 的空间时序寄存器: FMC_PMEM,该寄存器各位描述如图所示:
在这里插入图片描述
该寄存器用于控制 NAND FLASH 的访问时序,非常重要。我们先来了解下 NAND FLASH控制器的通用存储器访问波形,如图所示:
在这里插入图片描述
由图可知, MEMxSET+MEMxHOLD 控制 NWE/NOE 的高电平时间, MEMxWAIT 控制NWE/NOE 的低电平时间, MEMxHIZ 控制写入时数据线高阻态时间。接下来我们分别介绍这几个参数:

MEMSET: 这八个位定义使能命令( NWE/NOE)前,地址建立所需要的 fmc_ker_ck 时钟周期数,表示 NWE/NOE 的高电平时间, 0000 0000~1111 1110 表示 1~255 个 fmc_ker_ck 周期。MT29F4G08 的 tREH/tWH 最少为 10ns,设置 MEMSET=3,即 4 个 fmc_ker_ck 周期,约 18ns。另外, MEMHOLD,也可以用于控制 NWE/NOE 的高电平时间,在连续访问的时候, MEMHOLD
和 MEMSET 共同构成 NWE/NOE 的高电平脉宽时间。

MEMWAIT:这八个位用于设置使能命令( NWE/NOE)所需的最小 fmc_ker_ck 时钟周期数(使能 NWAIT 将使这个时间延长),实际上就是 NWE/NOE 的低电平时间, 0000 0000~1111,1110 表示 1~255 个 HCLK 周期。 MT29F4G08 的 tRP/tWP 最少为 10ns,我们设置 MEMWAIT =5,即 6 个 fmc_ker_ck 周期,约 27ns。这里需要设置时间比较长一点,否则可能访问不正常。

MEMHOLD:这八个位用于设置禁止使能命令( NWE/NOE)后,保持地址(和写访问数据)的 fmc_ker_ck 时钟周期数,也可以用于设置一个读写周期内的 NWE/NOE 高电平时间, 00000000~1111 1110 表示 0~254 个 HCLK 周期。我们设置MEMHOLD=2,表示 2 个 fmc_ker_ck 周期,加上前面的 MEMSET,所以 NEW/NOE 高电平时间为 6 个 HCLK,即 27ns 左右。

MEMHIZ:这八个位定义通用存储空间开始执行写访问之后,数据总线保持高阻态所持续的 fmc_ker_ck 时钟周期数。该参数仅对写入事务有效, 0000~1111 1110 表示 0~254 个 fmc_ker_ck周期。我们设置 MEMHIZ=3,表示 3 个 fmc_ker_ck 周期, 即 13.5ns 左右。

7.NAND FLASH和STM32芯片的连接图
在这里插入图片描述
8.STM32CubeMx配置Nand Flash

(1).选择FMC项
Data/Address:由于Nand Flash是地址和数据共线,由于MT29F4G08芯片是8根数据线,所以这里设置为8bits。

Ready or busy:等待特性使能/失能,对应FMC_PCR寄存器中的PWAITEN位,用于设置等待特性: 0,禁止; 1,使能。这里我们设置为 0,禁止使用控制器自带的等待特性,因为如果使能的话,将导致 RGB 屏抖动( STM32 硬件 bug)。

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

ECC computation:ECC计算逻辑使能/失能,对应FMC_PCR寄存器中的ECCEN位,0:禁止/复位ECC,1:使能ECC计算

ECC page size:ECC页大小,对应FMC_PCR寄存器中的ECCCPS,这三个位用于设置ECC的页大小,256字节,512字节,1024字节,2048字节,4096字节,8192字节。

CLE low to RE low delay in HCLK cycles:CLE到RE的延迟,对应FMC_PCR寄存器中的TCLR,这四个位用于设置 CLE 到 RE 的延迟: 0000~1111,表示 1~16 个 fmc_ker_ck 周期。对应 NAND FLASH 数据手册的 tCLR 时间参数: t_clr=(TCLR+SET+2)*Tfmc_ker_ck。 TCLR 就是本寄存器的设置值, SET 对应 MEMSET 的值(我只用到 MEMSET), Tfmc_ker_ck 对应fmc_ker_ck 的周期。 MT29F4G08 的 tCLR 时间最少为 10ns,以 220M 的 fmc_ker_ck 频率计算,
一个 fmc_ker_ck=4.5ns(下同),我们设置 TCLR=5,则 t_clr 至少为 7 个 fmc_ker_ck 即 31.5ns。

ALE low to RE low delay in HCLK cycles:ALE到RE的延时,对应FMC_PCR寄存器中的TAR位,这四个位用于设置 ALE 到 RE 的延迟: 0000~1111,表示 1~16 个 HCLK 周期。对应NAND FLASH 数据手册的 tAR 时间参数,这里设置的 t_ar=(TAR+SET+2)* Tfmc_ker_ck。 TAR就是本寄存器的设置值, SET 对应 MEMSET 的值(我只用到 MEMSET), Tfmc_ker_ck 对应fmc_ker_ck 的周期。 MT29F4G08 的 tAR 时间最少为 10ns,我们设置 TAR=5,则 t_ar 至少为 7个 fmc_ker_ck 即 31.5ns。

NAND common space timing in HCLK cycles为NAND 通用存储器空间时序,NAND attribute space timing in HCLK cycles为NAND 特性存储器空间时序,这两个参数信息设置一致即可。

Common space setup time:地址建立的时间,对应空间时序寄存器,FMC_PMEM中的MEMSET,这八个位定义使能命令( NWE/NOE)前,地址建立所需要的 fmc_ker_ck 时钟周期数,表示 NWE/NOE 的高电平时间, 0000 0000~1111 1110 表示 1~255 个 fmc_ker_ck 周期。MT29F4G08 的 tREH/tWH 最少为 10ns,设置 MEMSET=3,即 4 个 fmc_ker_ck 周期,约 18ns。另外, MEMHOLD,也可以用于控制 NWE/NOE 的高电平时间,在连续访问的时候, MEMHOLD
和 MEMSET 共同构成 NWE/NOE 的高电平脉宽时间。

Common space wait time:对应空间时序寄存器,FMC_PMEM中的MEMWAIT,这八个位用于设置使能命令( NWE/NOE)所需的最小 fmc_ker_ck 时钟周期数(使能 NWAIT 将使这个时间延长),实际上就是 NWE/NOE 的低电平时间, 0000 0000~11111110 表示 1~255 个 HCLK 周期。 MT29F4G08 的 tRP/tWP 最少为 10ns,我们设置 MEMWAIT =5,即 6 个 fmc_ker_ck 周期,约 27ns。这里需要设置时间比较长一点,否则可能访问不正常。

Common space hold time:对应空间时序寄存器,FMC_PMEM中的MEMHOLD,这八个位用于设置禁止使能命令( NWE/NOE)后,保持地址(和写访问数据)的 fmc_ker_ck 时钟周期数,也可以用于设置一个读写周期内的 NWE/NOE 高电平时间, 00000000~1111 1110 表示 0~254 个 HCLK 周期。我们设置 MEMHOLD=2,表示 2 个 fmc_ker_ck 周
期,加上前面的 MEMSET,所以 NEW/NOE 高电平时间为 6 个 HCLK,即 27ns 左右。

Common space Hi-Z time:对应空间时序寄存器,FMC_PMEM中的MEMHIZ,这八个位定义通用存储空间开始执行写访问之后,数据总线保持高阻态所持续的 fmc_ker_ck 时钟周期数。该参数仅对写入事务有效, 0000~1111 1110 表示 0~254 个 fmc_ker_ck周期。我们设置 MEMHIZ=3,表示 3 个 fmc_ker_ck 周期, 即 13.5ns 左右。

Page size:Nand Flash芯片每页的字节数。
Spare area size:Nand Flash芯片每页中备份区域的字节数。
Block size:Nand Flash芯片中每块的字节数大小,字节限制为0-4294967295,因为最高支持的容量为4GB。128K+4K=135168。
Block number:Nand Flash芯片中块的数目。
Phane number:Nand Flash芯片中平面的数目。
Phane size:Nand Flash芯片中每个平面的字节数,128K+4K=135168,135168*1024=138412032。

(2).配置GPIO Settings
根据电路原理图,配置相应的管脚

9.MT29F4G08芯片时序时间表

在这里插入图片描述
在这里插入图片描述

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

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

相关文章

如何利用Flutter来写后端 服务端应用

前言 Flutter是谷歌推出的一款跨平台开发框架,现在属于此领域star最多的框架,其被广泛应用于构建前台界面,但或许很少人知道,他也可以写后端应用。 本文主角 flutter非常著名的getx库推出的get server jonataslaw/get_server:…

实验01-STP+链路聚合+VRRP实验

1.实验拓扑 2 实验需求 根据拓扑图配置IP地址。交换机之间通过STP防环为了防止SW2-SW3之间聚合的高效链路被STP 阻塞,请配置SW2 为网络中的主根,SW3为网络中的备份根桥。通过VRRP实现网关冗余,网关在SW2和SW3上,其中VLAN10的网关…

【3GPP】【核心网】【5G】5G核心网协议解析(一)(超详细)

1. 5G核心网概念 5G核心网是支撑5G移动通信系统的关键组成部分,是实现5G移动通信的重要基础设施,它负责管理和控制移动网络中的各种功能和服务。它提供了丰富的功能和服务,支持高速、低时延、高可靠性的通信体验,并为不同行业和应…

前端监控为什么采用GIF图片做埋点?

一、什么是埋点监控 前端监控是开发人员用来跟踪和维护应用程序表现层的运行状况的过程和工具。它主要包括三种类型:数据监控、性能监控和异常监控。 1、数据监控 主要是为了收集跟用户相关的数据,例如用户设备类型、浏览器版本、页面浏览量(…

GIS之深度学习05:VisualStudio安装教程

在安装CUDA前,建议先安装VisualStudio,以防报错 VisualStudio安装步骤简单,但时间较长。。。。。。 正文开始: VisualStudio官网:Visual Studio: IDE and Code Editor for Software Developers and Teams 点击右上角…

XUbuntu22.04之解决:仓库xxx没有数字签名问题(二百一十七)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒…

Gitlab: PHP项目CI/CD实践

目录 1 说明 2 CI/CD 2.1 部署方式一:增量部署 2.1.1 目标服务器准备 2.2.2 Gitlab及Envoy脚本 2.2 部署方式二:镜像构建与部署 2.2.1 推送到私有化容器仓库 准备工作 脚本 要点 2.2.2 推送到hub.docker.com 准备工作 脚本 3 参考&#x…

1905_ARMv7-M的堆栈寄存器

1905_ARMv7-M的堆栈寄存器 全部学习汇总: g_arm_cores: ARM内核的学习笔记 (gitee.com) ARMv7-M实现了2种堆栈,分别是MSP和PSP。复位的时候默认是MSP,而当前是哪种可以通过CONTROL.SPSEL寄存器的bit来查看。 SP寄存器的最低2bit,S…

⭐每天一道leetcode:27.移除元素(简单;vector)

⭐今日份题目 给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。 不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。 元素的顺序可以改变。你不需要考虑数组中…

大模型基础应用框架(ReACT\SFT\RAG)创新及零售业务落地

如何将大语言模型的强大能力融入实际业务、产生业务价值,是现在很多公司关注的焦点。在零售场,大模型应用也面临很多挑战。本文分享了京东零售技数中心推出融合Agent、SFT与RAG的大模型基础应用框架,帮助业务完成大模型微调、部署和应用&…

Linux 安装k8s

官网 常见的三种安装k8s方式 1.kubeadm 2.kops:自动化集群制备工具 3.kubespray: 提供了 Ansible Playbook 下面以kubeadm安装k8s kubeadm的安装是通过使用动态链接的二进制文件完成的,目标系统需要提供 glibc ##使用 ss 或者 netstat 检测端…

搞流量,就这点事!

资产还是负债?赚钱之前想明白! 如果说你有一个产品,大概率的情况是,如果产品被更多人看到,那么最终购买的人也会多一些。结果就是,你的利润更多。所以,在产品没问题的情况下,流量越多…

【学习心得】响应数据加密的原理与逆向思路

一、什么是响应数据加密? 响应数据加密是常见的反爬手段的一种,它是指服务器返回的不是明文数据,而是加密后的数据。这种密文数据可以被JS解密进而渲染在浏览器中让人们看到。 它的原理和过程图如下: 二、响应数据加密的逆向思路 …

MATLAB 绘制带填充配色的雷达图--附案例代码

MATLAB 绘制带填充配色的雷达图 目录 MATLAB 绘制带填充配色的雷达图摘要1. 准备数据2. 绘制雷达图3. 设置填充颜色4. 案例代码及结果4. 结语 摘要 在MATLAB 中,可以使用多种方式绘制美观的雷达图。本文将介绍如何通过详细案例和代码说明,在MATLAB中绘制…

MCU设计--M3内核整体功能说明

整体架构 内核特性 CM3内核支持3级流水哈佛结构 :数据和指令隔离Blanked SP :两个堆栈,一个堆栈只允许系统操作,另一个堆栈开放给用户。Handler and Thread modes低延迟中断进入和退出支持非对齐操作 嵌套中断向量 最大支持1-240…

前端+php:实现提示框(自动消失)

效果 php部分&#xff1a;只展示插入过程 <?php//插入注册表中$sql_insert "INSERT INTO regist_user(userid,password,phone,email)VALUES (" . $_POST[UserID] . "," . CryptPass($_POST[Password]) . "," . $_POST[Phone] . ",&qu…

【AI视野·今日NLP 自然语言处理论文速览 第八十期】Fri, 1 Mar 2024

AI视野今日CS.NLP 自然语言处理论文速览 Fri, 1 Mar 2024 Totally 67 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Computation and Language Papers Loose LIPS Sink Ships: Asking Questions in Battleship with Language-Informed Program Sampling Authors G…

从零开始学习Netty - 学习笔记 -Netty入门【协议设计和解析】

2.协议设计和解析 协议 在计算机中&#xff0c;协议是指一组规则和约定&#xff0c;用于在不同的计算机系统之间进行通信和数据交换。计算机协议定义了数据传输的格式、顺序、错误检测和纠正方法&#xff0c;以及参与通信的各个实体的角色和责任。计算机协议可以在各种不同的层…

探索云原生世界:Spring Cloud全方位解读——构建微服务架构的利器

目录 一、微服务简介 二、微服务发展史 三、Spring Cloud 3.1 Spring Cloud 版本策略 3.2 Spring Cloud 发展历程 微服务是一种软件架构风格&#xff0c;将单一应用程序拆分成一组小型、独立的服务。每个服务运行在自己的进程中&#xff0c;服务之间采用轻量级通信机制进行交…

Open3D 进阶(21)无序点云平面检测的鲁棒统计方法

目录 一、算法原理1、算法过程2、参考文献二、代码实现三、结果展示本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫与GPT。 一、算法原理 1、算法过程 除了寻找具有最大支持的单个平面外,Open3D还包含一个算法,该算法使…