0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

浅谈NorFlash的原理及其应用

ss 作者:工程师谭军 2018-10-07 15:12 次阅读
NOR Flash
NOR Flash是现在市场上两种主要的非易失闪存技术之一。Intel于1988年首先开发出NOR Flash 技术,彻底改变了原先由EPROM(Erasable Programmable Read-Only-Memory电可编程序只读存储器)和EEPROM(电可擦只读存储器Electrically Erasable Programmable Read - Only Memory)一统天下的局面。紧接着,1989年,东芝公司发表了NAND Flash 结构,强调降低每比特的成本,有更高的性能,并且像磁盘一样可以通过接口轻松升级。NOR Flash 的特点是芯片内执行(XIP ,eXecute In Place),这样应用程序可以直接在Flash闪存内运行,不必再把代码读到系统RAM中。NOR 的传输效率很高,在1~4MB的小容量时具有很高的成本效益,但是很低的写入和擦除速度大大影响到它的性能。NAND的结构能提供极高的单元密度,可以达到高存储密度,并且写入和擦除的速度也很快。应用NAND的困难在于Flash的管理需要特殊的系统接口。
性能比较
flash闪存是非易失存储器,可以对称为块的存储器单元块进行擦写和再编程。任何flash器件的写入操作只能在空或已擦除的单元内进行,所以大多数情况下,在进行写入操作之前必须先执行擦除。NAND器件执行擦除操作是十分简单的,而NOR则要求在进行擦除前先要将目标块内所有的位都写为0。
由于擦除NOR器件时是以64~128KB的块进行的,执行一个写入/擦除操作的时间为5s,与此相反,擦除NAND器件是以8~32KB的块进行的,执行相同的操作最多只需要4ms。
执行擦除时块尺寸的不同进一步拉大了NOR和NAND之间的性能差距,统计表明,对于给定的一套写入操作(尤其是更新小文件时),更多的擦除操作必须在基于NOR的单元中进行。这样,当选择存储解决方案时,设计师必须权衡以下的各项因素。
l 、NOR的读速度比NAND稍快一些。
2、 NAND的写入速度比NOR快很多。
3 、NAND的4ms擦除速度远比NOR的5s快。
4 、大多数写入操作需要先进行擦除操作。
5 、NAND的擦除单元更小,相应的擦除电路更少。
此外,NAND的实际应用方式要比NOR复杂的多。NOR可以直接使用,并可在上面直接运行代码;而NAND需要I/O接口,因此使用时需要驱动程序。不过当今流行的操作系统对NAND结构的Flash都有支持。此外,Linux内核也提供了对NAND结构的Flash的支持。
详解
NOR和NAND是现在市场上两种主要的非易失闪存技术。Intel于1988年首先开发出NOR flash技术,彻底改变了原先由EPROM和EEPROM一统天下的局面。紧接着,1989年,东芝公司发表了NAND flash结构,强调降低每比特的成本,更高的性能,并且象磁盘一样可以通过接口轻松升级。但是经过了十多年之后,仍然有相当多的硬件工程师分不清NOR和NAND闪存。
像“flash存储器”经常可以与相“NOR存储器”互换使用。许多业内人士也搞不清楚NAND闪存技术相对于NOR技术的优越之处,因为大多数情况下闪存只是用来存储少量的代码,这时NOR闪存更适合一些。而NAND则是高数据存储密度的理想解决方案。
NOR的特点是芯片内执行(XIP, eXecute In Place),这样应用程序可以直接在flash闪存内运行,不必再把代码读到系统RAM中。NOR的传输效率很高,在1~4MB的小容量时具有很高的成本效益,但是很低的写入和擦除速度大大影响了它的性能。
NAND结构能提供极高的单元密度,可以达到高存储密度,并且写入和擦除的速度也很快。应用NAND的困难在于flash的管理需要特殊的系统接口。
接口差别
NOR flash带有SRAM接口,有足够的地址引脚来寻址,可以很容易地存取其内部的每一个字节。
NAND器件使用复杂的I/O口来串行地存取数据,各个产品厂商的方法可能各不相同。8个引脚用来传送控制、地址和数据信息
NAND读和写操作采用512字节的块,这一点有点像硬盘管理此类操作,很自然地,基于NAND的存储器就可以取代硬盘或其他块设备。
容量成本编辑
NAND flash的单元尺寸几乎是NOR器件的一半,由于生产过程更为简单,NAND结构可以在给定的模具尺寸内提供更高的容量,也就相应地降低了价格。
NOR flash占据了容量为1~16MB闪存市场的大部分,而NAND flash只是用在8~128MB的产品当中,这也说明NOR主要应用在代码存储介质中,NAND适合于数据存储,NAND在CompactFlash、Secure Digital、PC Cards和MMC(多媒体存储卡Multi Media Card)存储卡市场上所占份额最大。
可靠耐用
采用flash介质时一个需要重点考虑的问题是可靠性。对于需要扩展MTBF(平均故障间隔时间Mean Time Between Failures)的系统来说,Flash是非常合适的存储方案。可以从寿命(耐用性)、位交换和坏块处理三个方面来比较NOR和NAND的可靠性。
寿命(耐用性)
在NAND闪存中每个块的最大擦写次数是一百万次,而NOR的擦写次数是十万次。NAND存储器除了具有10比1的块擦除周期优势,典型的NAND块尺寸为NOR器件的八分之一,每个NAND存储器块在给定的时间内的删除次数要少一些。
.NorFlash简单来说与sdram与Nand的中间品,它能像sdram一样直接读,但是又得像nand一样编程擦写。因此程序可以直接在nor里跑,速度要比sdram慢一些,往nor里写数据必须先擦除,因为nor的每一位只能由1变为0。Nor可读不可直接写的特性可以被用来判断是Nor启动还是nand启动,因为nand启动的话前4K是可写的,我们写入数据再读取出来应该是没有问题的,而nor启动的话,读出的数据必然是错误的。

NorFlash的硬件接线:

首先,如果做过sdram实验的朋友应该知道,NorFlash与sdram很相似,只不过sdram位宽为32,NOR为16。在硬件连接上,Nor的地址线与cpu的地址线错开1位,sdram错开2位。简单分析一下:

32位的CPU地址线为32位,每一个地址对应1个byte,地址的步长为1byte

0x0000 0000 对应第1个地址空间 大小为1bytes

0x0000 0001 对应 2 大小为1bytes

依次类推。。.

可以理解为cpu的地址类型 为 u8 * addraddr+1 移动1个字节

32位的sdram,每一个地址对应于4个byte,地址步长为4byte

0x0000 0000 对应第1个地址空间 大小为4bytes

0x0000 0001 对应 2 大小为4bytes

依次类推。。.

可以理解为sdram的地址类型 为 u32 * addraddr+1 移动4个字节

16位的nor,每一个地址对应于2个byte,地址步长为2byte

0x0000 0000 对应第1个地址空间 大小为2bytes

0x0000 0001 对应 2 大小为2bytes

依次类推。。.

可以理解为nor的地址类型 为 u16 * addraddr+1 移动2个字节

因此,CPU的地址与它们的地址是错位的。

CPU的4个连续地址 如 0 1 2 3 均对应于sdram的 0地址

CPU的2个连续地址 如 0 1 均对应于nor 的 0地址

假如我想取sdram 0地址的 第二个byte 地址如何写?对于sdram和nor具体的每一个byte是无法寻址的呀,但是arm有一个叫存储管理器的东西,它大概会帮我们实现单字节的读写,至于sdram和nor支不支持单字节读写,我们后边在分析。

NorFlash的软件设置:

需要像初始化sdram一样,设置Bank寄存器,主要是一些时序图的时间大小。

位宽在BWSCON寄存器中设置,不过它是由硬件决定的,bank0的位宽,我们拨动开关选择nor启动还是nand启动的时候,它就已经确定了。

NorFlash信息:

我这款Nor大小为2M,32个Block,每个block分为16个sector,一个sector为4K,具体信息如下图。

NorFlash写、擦除、读芯片ID:

Nor可以像sdram一样直接读取,对于其它的操作,例如写、擦除、读信息等需要写特定的Date到特定的Addr。

这里尤其需要注意的是,Addr指的是nor地址线上看到的地址,相对于cpu也就是我们写程序的时候,需要将addr《《1,这样cpu错位的地址线发出的地址正好对上nor需求的地址。

对于擦除操作,nor支持按block、sector或者整片的擦除,整个擦除需要6个周期,以按sector擦除为例,前五个周期为往XXX里写XXX,最后一个周期将0X30写入要擦除的sector对应的首地址即可。

对于写操作,需要4个周期,前3个周期往XXX里写XXX,最后一个周期将Data写入addr,这里需要注意的是addr必须是半字对齐,data也要求为16bit。

对于读取信息的操作,主要是读ID的操作,前3个周期往XXX里写XXX,第四个周期去读特定的地址,对于DeviceID来说,A1-A19=0,A0=1,对于CPU来说就是0x1《《1.

NorFlash的等待:

NorFlash有三种方式,1中读硬件引脚,另外两种读地址线,主要用读地址线的两种方式。

1、Toggle

连续读两次相同地址的数据,看DQ6是否相等,相等则擦除或写完成

2、polling

读数据,看DQ7是否正确,正确则擦除完成。如果擦除的话DQ7应该等于1,写操作的话,对比数据的第7位。

还有,很重要的一点:

经过我的测试,sdram的单字节读取没有问题,但是Nor单字节读取的时候,读出的数据并不正确。比如我在0x00地址处写入了0xff11,单字节读取0x0理论上应该得到0x11,而我在实际实验的时候得到的却是0xff。也就是说nor在存储半字数据的时候高8位于低8位互换了。

[cpp] view plain copy

#include “uart.h”

#define MAIN_SECT_SIZE (4*1024) /* 4 KB */

#define CMD_UNLOCK1 0x000000AA

#define CMD_UNLOCK2 0x00000055

#define CMD_ERASE_SETUP 0x00000080

#define CMD_ERASE_CONFIRM 0x00000030

#define CMD_PROGRAM 0x000000A0

#define MEM_FLASH_ADDR1 (*(volatile U16 *)(0x000005555 《《 1))

#define MEM_FLASH_ADDR2 (*(volatile U16 *)(0x000002AAA 《《 1))

#define U16 unsigned short

#define U32 unsigned long

#define U8 unsigned char

int write_hword (U32 dest, U16 data);

typedef struct {

U32 size; /* total bank size in bytes */

U16 sector_count; /* number of erase units */

U32 flash_id; /* combined device & manufacturer code */

U32 start[512]; /* physical sector start addresses */

} flash_info_t;

/*-----------------------------------------------------------------------*/

void flash_id(){

MEM_FLASH_ADDR1 = CMD_UNLOCK1;

MEM_FLASH_ADDR2 = CMD_UNLOCK2;

MEM_FLASH_ADDR1 = 0x00000090;

print(“Manufacturer ID :%x\r\n”,*((U16 *)0x00));

MEM_FLASH_ADDR1 = CMD_UNLOCK1;

MEM_FLASH_ADDR2 = CMD_UNLOCK2;

MEM_FLASH_ADDR1 = 0x00000090;

print(“Device ID :%x\r\n”,*((U16 *)(0x01《《1)));

}

void flash_init () //计算总大小,每个sector的起始地址

{

flash_id();

//print(“flash init OK\r\n”);

print(“*((U32 *)0x32000000) = 0x00001100\r\n”);

*((U32 *)0x32000000) = 0x00001100;

print(“U8 0x32000001 == %x\r\n”,*((U8 *)0x32000001));

*((U8 *)0x32000003) = 0xff;

print(“*((U8 *)0x32000003) = 0xff\r\n”);

print(“now the U32 0x32000000 should be 0xff001100\r\n”);

print(“U32 0x32000000 = %x\r\n”,*((U32 *)0x32000000));

print(“U8 0x32000000 = %x\r\n”,*((U8 *)0x32000000));

print(“U8 0x32000001 = %x\r\n”,*((U8 *)0x32000001));

print(“U8 0x32000002 = %x\r\n”,*((U8 *)0x32000002));

print(“U8 0x32000003 = %x\r\n”,*((U8 *)0x32000003));

if(flash_erase(0,1) == 0)

print(“erase OK\r\n”);

U32 a = 0x00001c15;

U16 b = 0x11ff;

write_hword(a,b);

print(“*(U32 *0x00001c15) == 0x11ff\r\n”);

print(“U8 0x1c15 = %x\r\n”,*((U8 *)0x1c15));

print(“U8 0x1c16 = %x\r\n”,*((U8 *)0x1c16));

print(“U16 0x1c15 = %x\r\n”,*((U16 *)0x1c15));

if(write_buff((1024*20),0,(7*1024)) == 0)

print(“write OK\r\n”);

}

int flash_erase (int s_first, int s_last)

{

int i,j;

U32 size = 0;

flash_info_t flash_info;

for (i = 0; i 《 1; i++) {

U32 flashbase = 0;

flash_info.size = 2*1024*1024;

flash_info.sector_count = 512;

flashbase = 0;

for (j = 0; j 《 flash_info.sector_count; j++) {

flash_info.start[j] =

flashbase + (j) * MAIN_SECT_SIZE;

//print(“%d \t:%d\r\n”,j,flash_info.start[j]);

}

}

int sect;

unsigned short temp;

/* Start erase on unprotected sectors */

for (sect = s_first; sect 《= s_last; sect++) {

print (“Erasing sector %d 。。. \r\n”, sect+1);

volatile U16 * addr = (volatile U16 *)(flash_info.start[sect]);

MEM_FLASH_ADDR1 = CMD_UNLOCK1;

MEM_FLASH_ADDR2 = CMD_UNLOCK2;

MEM_FLASH_ADDR1 = CMD_ERASE_SETUP;

MEM_FLASH_ADDR1 = CMD_UNLOCK1;

MEM_FLASH_ADDR2 = CMD_UNLOCK2;

*addr = CMD_ERASE_CONFIRM;

print(“wait\r\n”);

while(1){

temp = (*addr) & 0x40; // 0100 0000 DQ6

if(temp != (*addr) & 0x40) //DQ6

continue;

if(*addr & 0x80) //dq7 ==1

break;

}

}

return 0;

}

//写16位数据,地址应该是16位对齐的。

int write_hword (U32 dest, U16 data)

{

//print(“now to write %d\r\n”,dest);

int rc;

volatile U16 *addr = (volatile U16 *)dest;

U16 result;

//Check if Flash is (sufficiently) erased

result = *addr;

if ((result & data) != data)

return 1;

MEM_FLASH_ADDR1 = CMD_UNLOCK1;

MEM_FLASH_ADDR2 = CMD_UNLOCK2;

MEM_FLASH_ADDR1 = CMD_PROGRAM;

*addr = data;

while(1){

unsigned short i = *addr & 0x40;

if(i != (*addr & 0x40)) //D6 == D6

continue;

if((*addr & 0x80) == (data & 0x80)){

rc = 0;

break; //D7 == D7

}

}

//print(“write %d OK\r\n”,dest);

return rc;

}

int write_buff (U32 src, U32 addr, U32 len)

{

int rc;

U16 data; //16Bit?

if(addr % 2){

print(“addr is not for 16bit align\n”);

return 1;

}

while (len 》= 2) {

data = *((volatile U16 *) src);

if ((rc = write_hword (addr, data)) != 0) {

return (rc);

}

src += 2;

addr += 2;

len -= 2;

}

return 0;

}


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FlaSh
    +关注

    关注

    10

    文章

    1635

    浏览量

    148087
  • 存储器
    +关注

    关注

    38

    文章

    7493

    浏览量

    163875
收藏 人收藏

    评论

    相关推荐

    NorFlash与NandFlash对比

    本帖最后由 ORCAD__PCB 于 2012-8-9 14:24 编辑 NorFlash与NandFlash对比
    发表于 08-09 14:22

    浅谈认知无线电关键技术及其在煤矿通信中的应用

    浅谈认知无线电关键技术及其在煤矿通信中的应用
    发表于 03-16 16:06

    arm 裸机 norflash

    想法是这样的,利用norflash中未用的sector保存运行数据。实验:1、芯片:s3c2440,norflash:en29lv160ab。裸机程序在ADS1.2中编译,完成读取ID,擦除,写,读
    发表于 03-09 16:30

    请问把uImage烧到norflash的命令是什么?

    我的nandflash已经坏了,只有norflash可以进入u-boot, 以前老师视频里面的,方法都是 把uImage烧到 nandfalsh里面的,但是我现在的nandflash已经坏了,我想请问,把uImage烧到 norflash的命令是什么呀?
    发表于 09-19 03:11

    浅谈Keil-MDK创建及其编译过程

    浅谈Keil-MDK创建项目&编译过程---Code-data,RO-data,RW-data,ZI-data一、编译过程二、MDK 编译工具(1)创建一个新的工程(2)添加 startup
    发表于 02-24 06:03

    浅谈待机能耗问题及其电源解决方案

    浅谈待机能耗问题及其电源解决方案:随着家用电器、视听产品的普及,办公自动化的广泛应用和网络化的不断发展,越来越多的产品具有了待机功能,例如电池充电、遥控、数字
    发表于 10-29 15:34 19次下载

    数字电视及其测量浅谈

    数字电视及其测量浅谈 摘要:本文在介绍数字电视基本概念和背景的前提下,介绍了数字电视测试的主要参数和主要仪器,并介绍数字电
    发表于 11-27 07:45 948次阅读
    数字电视<b class='flag-5'>及其</b>测量<b class='flag-5'>浅谈</b>

    浅谈WiMax技术及其应用前景

    浅谈WiMax技术及其应用前景 WiMax技术概述 宽带无线接入技术作为下一代通信网中最具发展
    发表于 05-21 01:19 873次阅读

    浅谈PLC控制系统设计要点及其在使用中的问题

    浅谈PLC控制系统设计要点及其在使用中的问题 PLC是工业自动化的基础平台。PLC应用系统设计的首要问题是工程选型与编程平台的架构设
    发表于 06-16 13:47 678次阅读

    浅谈有线网络基础上的无线规划及其管理

    浅谈有线网络基础上的无线规划及其管理  如今,企业的新业务和新应用对于无线网络带来的移动性需求十分迫切。然而,如何能在原有的网络基础上更好地添加无线
    发表于 02-22 09:26 829次阅读

    EDGE演进及其测量技术

    浅谈EDGE演进及其测量
    发表于 03-30 17:25 919次阅读
    EDGE演进<b class='flag-5'>及其</b>测量技术

    浅谈同步电动机噪声及其抑制方法

    浅谈同步电动机噪声及其抑制方法_苏国霞
    发表于 01-02 16:09 2次下载

    微雪电子NorFlash S29GL128P简介

    NorFlash S29GL128P 外扩存储模块 容量128M Bit 可直接接入带有32I/Os接口的Open系列开发板 型号 NorFlash Board (B)
    的头像 发表于 12-30 09:31 2939次阅读
    微雪电子<b class='flag-5'>NorFlash</b> S29GL128P简介

    STM32F1_ 外部NorFlash存储程序代码

    STM32F1_外部NorFlash存储程序代码
    的头像 发表于 04-08 09:55 4318次阅读
    STM32F1_ 外部<b class='flag-5'>NorFlash</b>存储程序代码

    基于硬件损耗均衡算法的片上norflash控制器设计

    基于硬件损耗均衡算法的片上norflash控制器设计(嵌入式开发产品)-该文档为基于硬件损耗均衡算法的片上norflash控制器设计讲解文档,是一份很不错的参考资料,具有较高参考价值,感兴趣的可以下载看看………………
    发表于 07-30 15:41 9次下载
    基于硬件损耗均衡算法的片上<b class='flag-5'>norflash</b>控制器设计