一、概述

1、NandFlash

  NAND结构能提供极高的单元密度,可以达到高存储密度,比如能达到256M,并且写入和擦除的速度也很快。应用NAND的困难在于flash的管理需要特殊的系统接口。

2、NandFlash和NorFlash对比

Nor/Nand Flash 的差别
  Nor  Nand
容量 1MB~32MB 16M~512MB
XIP Yes No
擦除 非常慢(5S) 快(3ms)
慢        快
可靠性 比较高,位反转的比例小于NandFlash的10% 比较低,位反转比较常见,必须有校验措施,比如TNR必须有坏块管理措施
可擦除次数 10000~100000               100000~1000000
生命周期     低于NandFlash的10%              是NorFlash的10倍以上    
接口       与RAM接口相同                    I/O接口
访问方法 随机访问 顺序访问
易用性 容易 复杂
主要用途 常用于保存代码和关键数据 用于保存数据
价格 便宜

二、NandFlash常见引脚

1、输入输出(I/O0~I/O7)

  数据输入/输出

2、芯片使能(Chip Enable,CE#)

  如果没有检测到CE信号,那么NAND器件就保持待机模式,不对任何控制信号作出响应
3、写使能(Write Enable, WE#)

  WE#负责将数据、地址或指令写入NAND之中
4.读使能(Read Enable, RE#)

  允许输出数据缓冲器。
5.指令锁存使能(Command Latch Enable, CLE)

   当CLE为高时,在WE#信号的上升沿,指令被锁存到NAND指令寄存器中
6.地址锁存使能(Address Latch Enable, ALE)

  当ALE为高时,在W6.地址锁存使能(Address Latch Enable, ALE)E#信号的上升沿,地址被锁存到NAND地址寄存器中
7.就绪/忙(Ready/Busy, R/B#)

  如果NAND器件忙,R/B#信号将变低。该信号是漏极开路,需要采用上拉电阻

三、NandFlash的物理结构

  以下内容皆以K9F2G08U0B为例进行说明。

1、结构框图

2、存储结构

1 Page = (2K+64)Bytes

1 Block = 64 Pages

       = (128K + 4K) Byte

1 Device= 2048 Blocks

        = 128K Pages

    = (256M + 8M)Byte

    =  2112 Mbits

ECC

  Linux系统中,一般叫做OOB(Out Of Band)。NandFlash在操作过程中容易出错,为了保证数据的正确性,需要有检测和纠错机制,此机制被叫做EDC(Error Detection Code)/ECC(Error Code Correction, 或者 Error Checking and Correcting),因此设计了多余的区域,用于放置数据的校验值。

3、地址序列

A0~A11 页内寻址 不仅可以寻址到有效数据,还能寻址到校验区

A12~A28 页寻址

其中:

  A12~A17 块内页寻址

  A18~A28 块寻址

、NandFlash相对于RAM使用的特殊性 

NandFlash相对于RAM使用的特殊性

RAM

NandFlash

读取/写入的叫法

读取/写入

读取/编程(Program)①

读取/写入的最小单位

字节

Page/页

擦除(Erase)操作的最小单位

字节

Block/块②

擦除操作的含义

将数据删除/全部写入0

将整个块都擦除成全是1,也就是里面的数据都是0xFF ③

对于写操作

直接写即可

在写数据之前,要先擦除,然后再写

注:

①之所以将写操作叫做编程,是因为,flash 和之前的EPROM,EEPROM继承发展而来,而之前的EEPROM(Electrically Erasable Programmable Read-Only Memory),往里面写入数据,就叫做编程Program,之所以这么称呼,是因为其对数据的写入,是需要用电去擦除/写入的,就叫做编程。

②对于目前常见的页大小是2K/4K的Nand Flash,其块的大小有128KB/256KB/512KB等。而对于Nor Flash,常见的块大小有64K/32K等。

③在写数据之前,要先擦除,内部就都变成0xFF了,然后才能写入数据,也就是将对应位由1变成0。

五、实验代码

1、擦除操作

/* *********************擦除函数*******************************
参数说明:
block 要擦除的块
返回参数:
0 擦除失败
1 擦除成功
*/
unsigned char EraseBlock(unsigned int block)
{
unsigned int blockpage = ;
blockpage = block << ;
/* 选中芯片 */
nand_select_chip();
/* 发出WRITE0命令 */
write_cmd(0x60);
/* Write Address */
NFADDR = blockpage & 0xff; /* Row Address A12~A19 */
NFADDR = (blockpage >> ) & 0xff; /* Row Address A20~A27 */
NFADDR = (blockpage >> ) & 0x01; /* Row Address A28 */
write_cmd(0xD0);
wait_idle();
write_cmd(0x70);
wait_idle();
if(read_data()&0x1) // Page write error
{
/* 取消片选信号 */
nand_deselect_chip();
return ;
}
else
{
/* 取消片选信号 */
nand_deselect_chip();
return ;
}
}

2、页读操作

/* *********************页读函数*******************************
参数说明:
buf 存放读取数据的目的地址
addr 从nandflash中读取数据的源地址
*/
static unsigned char ReadPage(unsigned char * buf,unsigned int addr)
{
int j;
if (addr & NAND_BLOCK_MASK) {
return ; /* 地址或长度不对齐 */
}
/* 选中芯片 */
nand_select_chip(); /* 发出READ0命令 */
write_cmd();
/* Write Address */
write_addr(addr);
write_cmd(0x30);
wait_idle(); for(j=;j < NAND_SECTOR_SIZE; j++) {
*buf = read_data();
buf++; /*i每经过一个大循环就增加NAND_SECTOR_SIZE*/
}
/* 取消片选信号 */
nand_deselect_chip();
return ;
}

3、页写操作

/* *********************页写函数*******************************
参数说明:
buf 源地址
addr 写入nandflash的目的地址
*/
static unsigned char WritePage(unsigned char * buf,unsigned int addr)
{
unsigned int i = ;
if (addr & NAND_BLOCK_MASK) {
return ; /* 地址或长度不对齐 */
}
/* 选中芯片 */
nand_select_chip();
/* 发出WRITE0命令 */
write_cmd(0x80);
/* Write Address */
write_addr(addr);
/* Write Data */
for(i=;i<;i++)
{
write_data(*buf);
buf++;
}
write_cmd(0x10);
wait_idle();
write_cmd(0x70);
wait_idle();
if(read_data()&0x1) // Page write error
{
/* 取消片选信号 */
nand_deselect_chip();
return ;
}
else
{
/* 取消片选信号 */
nand_deselect_chip();
return ;
}
}

4、打印页内容(调试用)

/* *********************打印出指定地址的一个页的内容********************
*/
void nand_printf()
{ unsigned int i;
unsigned char block=, page=;
unsigned char * downPt;
downPt=(unsigned char *)_NONCACHE_STARTADDRESS; printf("\n\rK9F2G08 NAND Page Read.\n");
printf("\nBlock # to read: ");
block = getc()-;
printf("%d\n\r", block);
printf("\nPage # to read: ");
page = getc()-;
printf("%d\n\r", page); if(ReadPage(downPt,((block<<)+page)<<)==) {
printf("\nRead error.\n");
} else {
printf("\nRead OK.\n");
}
// Print data.
printf("Read data(%d-block,%d-page)\n", block, page); for(i=; i<; i++) {
if((i%)==) printf("\n\r%4x: ", i);
printf("%02x ", *downPt++);
}
printf("\n");
}

5、发送地址函数

static void write_addr(unsigned int addr)
{
int i;
unsigned int col, page; col = addr & NAND_BLOCK_MASK;
page = addr / NAND_SECTOR_SIZE; NFADDR = col & 0xff; /* Column Address A0~A7 */
for(i=; i<; i++); NFADDR = (col >> ) & 0x0f; /* Column Address A8~A11 */
for(i=; i<; i++); NFADDR = page & 0xff; /* Row Address A12~A19 */
for(i=; i<; i++); NFADDR = (page >> ) & 0xff; /* Row Address A20~A27 */
for(i=; i<; i++); NFADDR = (page >> ) & 0x01; /* Row Address A28 */
for(i=; i<; i++);
}

  着重强调一下,“for(i=0; i<10; i++); ”延时代码绝不能省略。笔者发现,当S3C2440的主频在12MHz时,如果没有延时代码,NandFlash发送地址还能正常工作;一旦主频在400MHz,没有延时代码,地址就不能正常发送。

参考资料:如何编写linux下nand flash驱动-1

nandflash内存详解

附:实现NandFlash程序下载的代码(nand.zip

NandFlash的更多相关文章

  1. nandflash的读写(2440)

    说明: 根据物理结构上的区别 , NandFlash主要分为如下两类:1)•SLC (Single Level Cell): 单层式存储2)•MLC (Multi Level Cell): 多层式存储 ...

  2. 使用jlink直接烧norflash或者nandflash不借助uboot的猜想

    由于喜欢折腾,我是在linux下使用jlink的,既然JLinkExe可以进行内存读写操作,loadbin等操作,并且通过指定命令文件支持批量指令输入,那么首先jlink是可以直接访问内部存储器的,包 ...

  3. 关于NOR-FLASH和NAND-fLASH的区别。——Arvin

    NANDFLASH: Nand-flash内存是flash内存的一种,1989年,东芝公司发表了NAND flash结构.其内部采用非线性宏单元模式,为固态大容量内存的实现提供了廉价有效的解决方案.N ...

  4. NandFlash读写

    1.NandFlash分类 根据物理结构上的区别,NandFlash主要分为如下两类:•SLC (Single Level Cell): 单层式存储•MLC (Multi Level Cell): 多 ...

  5. u-boot中nandflash初始化流程分析(转)

    u-boot中nandflash初始化流程分析(转) 原文地址http://zhuairlunjj.blog.163.com/blog/static/80050945201092011249136/ ...

  6. 路由器 NorFlash与NandFlash区别

    在淘宝上买修改openwrt的路由器,基本上都是改的16MB flash,那么为什么不改到1GB呢? 现在U盘的价格也很便宜啊. 于是我调查了一下,发现flash分为两种,NorFlash与NandF ...

  7. WinCE开机Logo的实现(USB下载图片到nandflash)

    WinCE开机启动Logo使用Eboot读取NandFlash中的图片数据,然后显示的方式.对于开机logo的方式网友http://jazka.blog.51cto.com/809003/664131 ...

  8. 通过NORFLASH中的uboot烧写uboot到nandFlash

    在mini2440的教程中,在构建nandflash系统的时候是首先通过supervivi借助dnw烧写uboot.bin到nand flash 第零块, 由于我使用的是64位操作系统,usb驱动没安 ...

  9. NorFlash和NandFlash区别

      Flash编程原理都是只能将1写为0,而不能将0写成1.所以在Flash编程之前,必须将对应的块擦除,而擦除的过程就是将所有位都写为1的过程,块内的所有字节变为0xFF.因此可以说,编程是将相应位 ...

  10. uboot在nandflash和norflash是如何运行的

    转自:http://www.aiuxian.com/article/p-2796357.html 电子产品如果没有了电,就跟废品没什么区别,是电赋予了他们生命,然而程序则是他们的灵魂. 小时候一直很好 ...

随机推荐

  1. [置顶] MyEclipse下安装插件方法(properties文件编辑器Propedit为例)

    网上流传了很多安装插件的方法.在这里我只讲解一种方法. 因为我认为这种方法有以下两个优点:第一.简单,方便安装:第二.对于自己安装的插件易于管理. 我的myeclipse版本号为10.5,操作系统为w ...

  2. 29. Divide Two Integers

    用加减法模拟除法. 除法本质就是 被除数 - 商个除数相加 = 0 如果你电脑足够好,可以无限减..但是这个题肯定不是这么简单. 最快的方法还是 减去 商乘以除数. 但是这里不能使用乘法,那只好用BI ...

  3. U3D C# 实现AS3事件机制

    写了很多年的AS3,最近接触U3D感觉事件机制没AS3的爽.咬紧牙关一鼓作气 基于C# 的委托实现了一版.废话不多说上干货. EventDispatcher代码如下: using UnityEngin ...

  4. SQL 存储过程 分页 分类: SQL Server 2014-05-16 15:11 449人阅读 评论(0) 收藏

    set ANSI_NULLS ON set QUOTED_IDENTIFIER ON go -- ============================================= -- Au ...

  5. winform Execl数据 导入到数据库(SQL) 分类: WinForm C# 2014-05-09 20:52 191人阅读 评论(0) 收藏

    首先,看一下我的窗体设计: 要插入的Excel表: 编码 名称 联系人 电话 省市 备注 100 100线 张三 12345678910 北京 测试 101 101线 张三 12345678910 上 ...

  6. Swing的设计是MVC的典范

    无论你的项目是否用到了Swing技术,我都要说,Swing是一个设计优秀的Java包,它充满了大师的智慧.假设你学了Java却连一个Button还不会写,就象你学习Visual Basic却不会用Bu ...

  7. 娓娓道来c指针 (3)指针和数组

    (3)指针和数组 在c中指针和数组似乎有着千丝万缕的关系.事实上它们不是一回事:指针是指针,数组是数组.两者不同样. 说它们有关系,只是是由于常见这种代码: int main() { int arra ...

  8. 腾讯QQ企业邮箱POP3/SMTP设置

    腾讯企业邮箱支持通过client进行邮件管理. POP3/SMTP协议 收发邮件server地址分别例如以下. 接收邮件server:pop.exmail.qq.com (port 110) 发送邮件 ...

  9. Linux 性能分析工具 nmon for Linux

    http://blog.csdn.net/defonds/article/details/41725929 http://blog.csdn.net/fansy1990/article/details ...

  10. 用户输出表单处理php

    php中的表单输入处理,我用两个文件,在linux输出: touch php_post1.html php_post1.php php_post1.html代码如下: <!doctype htm ...