FLASH的知识【转】

简介:   转自:http://blog.csdn.net/xgbing/article/details/18422691   版权声明:原创文章,转载请注明来自:http://blog.csdn.net/xgbing     传统的FLASH分为Nor falsh和Nand flash。

 

 

转自:http://blog.csdn.net/xgbing/article/details/18422691

 

    传统的FLASH分为Nor falsh和Nand flash。

(1)Nor flash

     Nor flash存储以块为单元,写入时必须先擦除,并且擦除和写入的速度都很慢。但nor fash具有SRAM接口,有单独的地址总线和地址总线,接口简单,就像是访问ROM一样,读取速度快,能随机访问存储单元。正是这些特性,所以nor falsh被广泛用来存储启动代码。Nor falsh的价格较贵,市面上一般1~16M的小容量的FLASH居多。

    例如SST39VF6401B(支持JEDEC标准),它的大小是8MB,共128个块,块大小是64KB,具有SRAM接口:

    读写速度:读70~90ns,擦除块典型值是18ms。

    在mtd源代码中,nor falsh的驱动代码在drivers\mtd\maps目录下。

 

     目前,Nor flash有两种标准JEDEC和CFI。

     JEDEC:全称是Joint Electron Device Engineering Council 即电子元件工业联合会。JEDEC是由生产厂商们制定的国际性协议,主要为内存制定。JEDEC用来帮助程序读取Flash的制造商ID和设备ID,以确定Flash的大小和算法,如果芯片不支持CFI,就需使用JEDEC了。工业标准的内存通常指的是符合JEDEC标准的一组内存。

    CFI:即公共闪存接口(Common Flash Interface)。CFI是一个公开的标准的从Flash Memory器件中读取数据的接口。它可以使系统软件查询已安装的Flash Memory器件的各种参数,包括器件阵列结构参数、电气和时间参数以及器件支持的功能等。CFI标准的应用解决了各个FLASH厂商操作命令集和电气参数千差万别的难题,目前市面上的Nor flash大多支持CFI校准。

     CFI标准规定先往FLASH数据总线写入55H,再写入98H,然后从地址10H处读取3个数据,如果这3个数据是'Q'、'R'、'Y',那么遵循CFI标准。在其它地址,保存了FLASH的其它信息,如生产厂商ID,设备ID,FLASH总线宽度,BLOCK总数据,BLOCK大小等所有FLASH有关的信息。cfi.h中的cfi_ident即是查询的数据结构:

[cpp]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1. /* Basic Query Structure */  
  2. struct cfi_ident {  
  3.     uint8_t  qry[3];//’Q‘,'R','Y'  
  4.     uint16_t P_ID;  
  5.     uint16_t P_ADR;  
  6.     uint16_t A_ID;  
  7.     uint16_t A_ADR;  
  8.     uint8_t  VccMin;  
  9.     uint8_t  VccMax;  
  10.     uint8_t  VppMin;  
  11.     uint8_t  VppMax;  
  12.     uint8_t  WordWriteTimeoutTyp;  
  13.     uint8_t  BufWriteTimeoutTyp;  
  14.     uint8_t  BlockEraseTimeoutTyp;  
  15.     uint8_t  ChipEraseTimeoutTyp;  
  16.     uint8_t  WordWriteTimeoutMax;  
  17.     uint8_t  BufWriteTimeoutMax;  
  18.     uint8_t  BlockEraseTimeoutMax;  
  19.     uint8_t  ChipEraseTimeoutMax;  
  20.     uint8_t  DevSize;  
  21.     uint16_t InterfaceDesc;  
  22.     uint16_t MaxBufWriteSize;  
  23.     uint8_t  NumEraseRegions;  
  24.     uint32_t EraseRegionInfo[0]; /* Not host ordered */  
  25. } __attribute__((packed));  


 

    

(2)Nand flash

    和Norflash一样,Nand flash存储以块为单元,写入时必须先擦除。nand flash擦除和写要比nor flash快,但读取速度比它慢。Nand flash采用复杂的IO口来串行地访问数据,读和写的最小单元都是一个页,所以CPU不能像nor flash一样直接运行FLASH上的代码。Nor falsh的优势是价格便宜,市面上一般以大容量为主,容量大小一般为8M~几个GB。Nand flash一般用来存储数据,如用来做文件系统存储空间。

    Nand falsh的一个页的数据分为数据区域和额外数据区(称为OOB),例如一个页包含2KB的数据区和64B的OOB。OOB数据区一般用来存储特定的数据,如数据校验、坏块标识等。

    Nand flash在擦写的过程中可能形成坏块,如果检测到坏块,一般在OOB数据区标识它。而实际上,Nand flash从工厂生产出来就可能存在坏块,有关坏块标识的细节可以相应的FLASH手册上找到说明。

    举例:三星的K9K8G08U0B

它的大小是1GB,共8192个块,块大小是2KB,OOB大小是64B。它的接口是8位的串行数据:

数据读取一个页的时间是25us。擦除一个块的时间典型值是1.5ms。

    在mtd源代码中,nor falsh的驱动代码在drivers\mtd\nand目录下。

 

OneNand Flash

    随着过去几十年的Nand技术的发展,一些公司,基于原先的NAND的架构,设计出一种理想的单存储芯片,其集成了SRAM的缓存和逻辑接口,它就是OneNand Flash。OneNand既实现NOR Flash的高速读取速度,又保留了Nand Flash的大容量数据存储的优点。由于笔者在实际项目中还没有用到一款onenand,所以不做举例,读者可以到GOOGLE搜索到onenand的信息。

    在mtd源代码中,nor falsh的驱动代码在drivers\mtd\onenand目录下。

【作者】 张昺华
【新浪微博】 张昺华--sky
【twitter】 @sky2030_
【facebook】 张昺华 zhangbinghua
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
目录
相关文章
|
XML 数据格式 SoC
深入理解AMBA总线(十)AHB Bus Matrix以及AHB的局限性
深入理解AMBA总线(十)AHB Bus Matrix以及AHB的局限性
925 0
|
编解码 语音技术
【经典蓝牙】 蓝牙HFP层协议分析
HFP(Hands-Free Profile), 是蓝牙免提协议, 可以让蓝牙设备对对端蓝牙设备的通话进行控制,例如蓝牙耳机控制手机通话的接听、 挂断、 拒接、 语音拨号等。HFP中蓝牙两端的数据交互是通过定义好的AT指令来通讯的
2805 0
【经典蓝牙】 蓝牙HFP层协议分析
|
SoC
深入理解AMBA总线(二)APB slave设计
深入理解AMBA总线(二)APB slave设计
558 0
|
SoC 内存技术
深入理解AMBA总线(五)AHB-lite Transfer进阶
深入理解AMBA总线(五)AHB-lite Transfer进阶
858 0
|
存储
深入理解AMBA总线(六)AHB-lite Slave响应和其它控制信号
深入理解AMBA总线(六)AHB-lite Slave响应和其它控制信号
999 0
一把王者的时间,学会generate语句【Verilog高级教程】
一把王者的时间,学会generate语句【Verilog高级教程】
一把王者的时间,学会generate语句【Verilog高级教程】
|
算法 Serverless 数据安全/隐私保护
【密码学】一文读懂SHA-2
SHA-2安全散列算法2(Secure Hash Algorithm 2)一种密码散列函数算法标准,由美国国家安全局研发,由美国国家标准与技术研究院(NIST)在2001年发布。属于SHA算法之一,是SHA-1的后继者。其下又可再分为六个不同的算法标准,包括了:SHA-224、SHA-256、SHA-384、SHA-512、SHA-512/224、SHA-512/256。
1196 0
【密码学】一文读懂SHA-2
|
20天前
|
存储 人工智能 测试技术
小鱼深度评测 | 通义灵码2.0,不仅可跨语言编码,自动生成单元测试,更炸裂的是集成DeepSeek模型且免费使用,太炸裂了。
小鱼深度评测 | 通义灵码2.0,不仅可跨语言编码,自动生成单元测试,更炸裂的是集成DeepSeek模型且免费使用,太炸裂了。
141061 20
小鱼深度评测 | 通义灵码2.0,不仅可跨语言编码,自动生成单元测试,更炸裂的是集成DeepSeek模型且免费使用,太炸裂了。
|
19天前
|
人工智能 运维 前端开发
基于阿里百炼的DeepSeek-R1满血版模型调用【零门槛保姆级2084小游戏开发实战】
本文介绍基于阿里百炼的DeepSeek-R1满血版模型调用,提供零门槛保姆级2048小游戏开发实战。文章分为三部分:定位与核心优势、实战部署操作指南、辅助实战开发。通过详细步骤和案例展示,帮助开发者高效利用DeepSeek-R1的强大推理能力,优化游戏逻辑与视觉效果,解决官网响应延迟问题,提升开发效率和用户体验。适合企业开发者、教育行业及多模态探索者使用。
70897 17
基于阿里百炼的DeepSeek-R1满血版模型调用【零门槛保姆级2084小游戏开发实战】
|
23天前
|
人工智能 自然语言处理 API
快速使用 DeepSeek-R1 满血版
DeepSeek是一款基于Transformer架构的先进大语言模型,以其强大的自然语言处理能力和高效的推理速度著称。近年来,DeepSeek不断迭代,从DeepSeek-V2到参数达6710亿的DeepSeek-V3,再到性能比肩GPT-4的DeepSeek-R1,每次都带来重大技术突破。其开源策略降低了AI应用门槛,推动了AI普惠化。通过阿里云百炼调用满血版API,用户可以快速部署DeepSeek,享受高效、低成本的云端服务,最快10分钟完成部署,且提供免费token,极大简化了开发流程。
191016 23
快速使用 DeepSeek-R1 满血版