NandFlash_control
驱动:编写任何设备的驱动程序,都需要对该设备的原理有一定了解和认识。对于外部设备的访问总是需要通过一个控制器来间接访问,对于这个控制器的控制程序称为驱动程序
Nandflash 原理:
一:角色分析
数据存储的物理介质
二:Nandflash 分类
根据不同的方式可以将Nandflash 分出不同的类别出来,这里采用物理结构的方式来分类
(1)SLC(single level cell):单层次存储
(2)MLC(multi level cell):多层次存储
特点比较:
1)SLC 的存储格上只存储以为数据,而MLC的存储格上却存储两位数据,所以MLC的单位存储容量价格比SLC 更低
2)SLC使用寿命更长,SLC 10万次擦写,MLC只有1万次
3)SLC 比MLC访问速度更快,大约是3倍
4)MLC比SLC的功耗更高,大约高出15%
三:访问方式
(1)编址
注意:内存采用的是统一编址的方式,Nandfash采用的是独立编址的方式
1)内存单元既有地址总线,也有数据总线,然而Nandflash,地址和数据总线是复用的。
2)由于Nandflash 不像内存一样通过统一编址,那么怎么访问Nandflash呢?在cpu内部有一个叫做“Nandflash控制器”的东西,用来控制访问Nandflash
(2)地址结构
1)Nandflash控制器总共只有8个I/O管脚与之相连,明显根数太少,所以数据(地址或数据)是分几次送入的。
2)CPU内部的Nandflash控制器中,有几个寄存器,一个是“地址数据寄存器”,另外一个是“指令数据寄存器”,还有“数据寄存器”,这些寄存器的地址是统一编址的。实际上三个寄存器统称为“数据寄存器”,只是存放的数据的功能各不同。
地址——命令——数据
Nandflash 物理结构:
3)由图可知:
一个NandFlash被分为了,2048个块,每一个块又被分为64个页,每一个页被分为2k的空间,外加64byte 的空间用来放置校验码之类的。
4)对nandflash的读有两种方式:
页读:一种是给出页地址,一次将怎个页的内容读出来(只需要提供页地址,即为行地址)
随机读:另外一个方式是将页中的某个字节读出来。(需要给出行地址和列地址)
(3)信号引脚
控制引脚的含义如上图。
四:对Nandflash 的读操作
对于一些复杂的设备的操作,看懂时序图是一个很重要工作,按照时序图,根据I/O管脚上的信号有节奏的控制设备。
时序图:
Nandflash控制寄存器/Nandflash 配置寄存器(初始化配置):
作用分析:
用于初始化nandflash ,因为任何一个硬件的使用都必须事先进行初始化。
Nandflash控制寄存器
作用:
NFCONT 用于片选控制
nandflash 配置寄存器:
NFCONF 用于初始nandflash的时序控制,主要用于配置该寄存器中的TACLS TWRPH0 TWRPH1 这几个位。
作用分析:
根据上表可以算得各部分时间的最小值,然后根据此值,进行配置
重启控制方式时序逻辑:
写入时序逻辑图:
根据I/O管脚上的命令流,有节奏的操作
写入时序逻辑图:
根据I/O管脚上的命令流,有节奏的操作
擦除时序逻辑:
根据I/O管脚上的命令流,有节奏的操作
NandFlash_control的更多相关文章
随机推荐
- SpringCloud之Eureka(注册中心集群篇)
一:集群环境搭建 第一步:我们新建两个注册中心工程一个叫eureka_register_service_master,另一个叫eureka_register_service_backup eureka ...
- 弗罗贝尼乌斯範数(Frobenius norm)
弗罗贝尼乌斯範数 对 p = 2,这称为弗罗贝尼乌斯範数(Frobenius norm)或希尔伯特-施密特範数( Hilbert–Schmidt norm),不过后面这个术语通常只用于希尔伯特空间.这 ...
- JavaScript常用数组方法
JavaScript数组方法有以下这些: forEach() 方法对数组的每一个元素执行一次提供的函数. map() 方法创建一个新数组,其结果是该数组都执行一次函数,原函数保持不变. filter( ...
- 解决java计算中double类型结果不一致问题,使用BigDecimal解决
一.需求:从数据表中读出一个double的数据,比如是3.5,没问题,但是如果再用3.5进行计算,比如乘以100,结果就是350了,而是35000000004 因为是浮点运算,所有语言中的浮点数都会有 ...
- 彻底搞懂字符编码(unicode,mbcs,utf-8,utf-16,utf-32,big endian,little endian...)[转]
最近有一些朋友常问我一些乱码的问题,和他们交流过程中,发现这个编码的相关知识还真是杂乱不堪,不少人对一些知识理解似乎也有些偏差,网上百度, google的内容,也有不少以讹传讹,根本就是错误的(例如说 ...
- Laravel 5.5 迁移报错:General error: 1215 Cannot add foreign key constraint
问题 之前一直用的 Laravel 5.4,数据库也是直接写 sql 的,感觉可定制性更强,顺便锻炼下 sql.这次改用了 Laravel 5.5,索性用迁移建库试试,结果报错如下: SQLSTATE ...
- mysql5.7.10 源码编译安装记录 (centos6.4)【转】
一.准备工作 1.1 卸载系统自带mysql 查看系统是否自带MySQL, 如果有就卸载了, 卸载方式有两种yum, rpm, 这里通过yum卸载 rpm -qa | grep mysql //查看系 ...
- Java集合Map与其子类回顾
接10月12号昨天的笔记,今天继续回顾集合中的Map集合. 一.集合工具操作类Collections 问题:collection和collections的区别? 1.collection是单列集合的顶 ...
- mysql -> 事务&事务锁_09
事务的特性 redo undo 锁的隔离级别
- docker stack 部署 seafile(http)
=============================================== 2018/5/13_第1次修改 ccb_warlock == ...