nandflash和norflash接口设计和驱动开发

nandflash和norflash接口设计和驱动开发

ID:14084162

大小:533.50 KB

页数:5页

时间:2018-07-25

nandflash和norflash接口设计和驱动开发_第1页
nandflash和norflash接口设计和驱动开发_第2页
nandflash和norflash接口设计和驱动开发_第3页
nandflash和norflash接口设计和驱动开发_第4页
nandflash和norflash接口设计和驱动开发_第5页
资源描述:

《nandflash和norflash接口设计和驱动开发》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、NandFLASH和NorFLASH接口设计和驱动开发0引言随着嵌入式系统的迅速发展,其应用环境的广泛性,复杂性对构建于系统上的Nor和Nand闪存设备提出更高要求,需要闪存设备传输速度更快,体积更小,容量更大,稳定性更好。该文在基于Samsung公司的S3C2410处理器平台上,针对FLASH闪存设备在嵌入式系统中的应用,详细分析FLASH闪存设备的接口设计方法,并针对FLASH接口特点,提出Linux环境下NorFLASH和NandFLASH的驱动开发流程,给出详细的代码分析。1NandFLASH和NandFL

2、ASH对比随着存储技术的高速发展,闪存设备因其在性能和成本方面的优势,如非易失性,可擦除性以及更低廉的价格正逐步取代传统记忆体。目前常用闪存是Nor-FLASH和NandFLASH。它们的技术性能差异显著,表1是它们的技术对比。NorFLASH使用方便,易于连接,可以在芯片上直接运行代码,稳定性出色,传输速率高,在小容量时有很高的性价比,这使其很适合应于嵌入式系统中作为FLASHROM。相对于NorFLASH,NandFLASH强调更高的性能,更低的成本,更小的体积,更长的使用寿命。这使NandFLASH很擅于存储

3、纯资料或数据等,在嵌入式系统中用来支持文件系统,在该S3C2410平台上用以支持bon文件系统。然而FLASH闪存却是保证数据正确性不太理想的设备,应用中可能出现坏块;这就给其在嵌入式系统中的应用,如何更好地进行数据存储管理提出了更高要求。恰当的接口设计和驱动开发是解决问题的关键,本文基于S3C2410,详细分析FLASH接口设计和驱动开发流程。2FLASH接口设计2.1处理器内存分配情况在分析FLASH的接口以及工作模式前,先分析处理器的内存分配情况。内核ARM920T是32位处理器,寻址空间4GB,3GB被处理

4、器内部的寄存器和一些其他设备占用,只有1GB用于外部寻址;这1GB的空间S3C2410分为8个部分以支持不同的设备,每个空间为128Mb,被命名为BANK。S3C2410给每个BANK一个片选即nGCS0~nGCS7来方便对BANK的操作,将CPU上相应的BANK连线接到外设芯片的片选引脚上就可以根据相应的地址对存储器进行控制。2.2FLASH在系统中的架构FLASH模块通过系统总线与处理器相连,如图1所示。为了拥有高速的数据交换通道,FLASH经由控制器模块通过AHB总线与处理器通信。NandFLASH控制器、N

5、orFLASH控制器和DMA控制器都是高速总线AHB上的Master模块,都包含符合AMBA标准的总线接口模块与AHB交互工作。FLASH工作时,FLASH控制器模块和DMA控制器模块相互协作,完成各种操作。2.3NorFLASH的接口设计系统用的NorFLASH芯片是Atmel公司开发的AT49BV1614A,存储空间为16MB,在系统中常用于存放代码,系统上电或复位后获得指令开始执行,因此,应将其配置到Bank0,将AT49BV1614A的片选端nCE接至S3C2410的nGCS0;AT49BVl614A的输出

6、使能端nOE接S3C2410的nOE;写使能端nWE接S3C2410的nWBE0;将模式选择nBYTE上拉,使AT49BV1614A工作在16位数据模式。AT49BV1614A地址总线A[19~0]和S3C2410的地址总线ADDR[20~1相连,16位数据总线DQ[15~0]和S3C2410的低16位数据总线DATA[15~0]相连。2.4NorFLASH在系统中的具体操作以AT49BV1614A芯片时序图为例,具体说明NorFLASH的写操作,如图2所示。CLE信号有效时系统通过I/O口向命令寄存器发送命令00

7、H,此时WE为低电平,写操作有效,NandFLASH处于写状态。发送命令后,接着发送要读的地址,该操作将占用WE的1,2,3,4四个周期,发送地址信息时,CLE为低电平,ALE为高电平。地址信息发送完毕后,不能立刻读取数据,因为此时芯片正处于BUSY(忙)状态,需要等待2~20ms,之后,才能开始数据读取。此时WE为高电平,处于无效状态,CE片选信号也始终为低以表明选中该芯片。3FLASH驱动程序开发3.1Linux系统下的驱动程序Linux系统将所有的设备都看作具体的文件,通过文件系统对设备进行管理。所以在Lin

8、ux架构中,和设备相关的处理分成两层:文件系统层和设备驱动层。设备驱动层用来屏蔽具体设备的细节,文件系统层向用户提供一组统一的接口。这种设备管理方法可以很好的实现设备无关性,使Linux系统可以随着外部设备的发展进行扩展,比如要添加一个设备,只要根据该硬件设备特性向文件系统提供一组接口,应用程序通过系统调用接口来访问设备。Linux系统里将FLASH设备归属

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。