一种NAND FLASH自启动的新方法

发布者:caoxians4589最新更新时间:2007-06-26 来源: 今日电子关键字:ARM7  缓冲  编码 手机看文章 扫描二维码
随时随地手机看文章
1 引 言

随着消费类电子产品包括PDA,MP3、智能手机等手持设备的市场需求逐步扩大,产品间的竞争也愈发激烈,降低产品的设计成本,提升产品的市场竞争力成为嵌入式系统开发者所面临的重大挑战。NAND FLASH和NORFLASH作为两种主要的非易失性存储器,被应用于各种嵌入式系统。其中NAND FLASH主要优点在于存储密度高、容量大,有更占优势的存储性价比。但是NANDFLASH由于其独特的页式读写方式,并不适合程序的直接执行。因此,从NAND FLASH启动需要片上存储器作为代码执行的中转区。本文所讨论的一种系统启动方式,是在缺少片上存储器支持的情况下,实现系统直接从NAND FLASH启动。论文中充分考虑了如何实现软、硬件之间的协同工作,以完成SOC系统的设计。

2 NAND FLASH控制器的结构

本文所讨论的NAND FLASH控制器是针对一款基于ARM7TDMI的SoC芯片,该控制器在芯片中的位置如图1所示,作为AMBA总线上的一个从设备集成于AHB上。主要模块包括总线接口模块、FIFO缓冲模块、ECC编码模块以及逻辑控制模块。

 

总线接口模块主要的功能是转换AMBA总线上的控制和数据信号:将总线上的数据送入FIFO或将数据从FIFO读出到总线上,将总线上的控制信号转换时序后送到控制模块。

NAND控制器包含一个宽度为32 b,深度为4的缓冲FIFO,用于解决高速总线与低速设备之间数据传输速度的匹配问题。为提高总线的传输效率,以及控制器设计的便利性,NAND FLASH在总线上的数据传输采用DMA的方式来完成。譬如在读取FLASH一页数据时,数据持续写入控制器FIFO,FIFO满时发出DMA传输的请求,同时暂停FLASH的数据读取,控制信号nRE拉高,直至DMA响应请求即FIFO不满时,FLASH的数据传输重新开始。当选择应用的FLASH位宽为8,页大小为(512+16)B时,控制器需要发出(32+1)次4拍字宽度的DMA传输请求来完成数据和校验信息的读取。

控制模块的上作主要是将总线接口转换的控制信号,按照NAND FLASH的接口协议.将片选、地址、命令、读写使能按照所配置的时序要求,发送到NAND FLASH中,并且控制数据的传输个数,以及DMA请求、数据传输完成中断、数据错误中断等系统信号。

NAND FLASH可靠性相对较差,存储器芯片中有坏块的存在,会导致存储数据出错。ECC校验模块针对NAND FLASH的可靠性问题,提供了一种查错、纠错的机制。ECC校验码在数据读人时,由硬件计算完成后写入到FLASH的校验位中,当此页数据读出时,校验码再次生成与存储器校验位中的数据进行比较,若相同则没有损坏位,若不同,则给出出错中断,软件通过检查比较结果,判断出错位的位置进行纠错处理。纠错功能仅针对单bit位的出错,当一个以上位同时在一页中出现时,ECC校验不能给出出错位正确的位置。

3 NAND FLASH工作的软件流程

按照上节对控制器结构以及传输机理的分析,NANDFLASH的使用需要在FLASH控制器模块以及DMA控制器模块的协同下完成,工作的软件流程如图2所示。

软件驱动的主要工作是配置DMA模块以及FLASH控制模块,当传输完成,检测到中断后,软件查询状态寄存器,其中的状态位来自FLASH。当一次操作完成后,控制器自动向FLASH发出查询状态的命令0x70,读出的状态字保存在控制器的状态寄存器中。

4 NAND FLASH系统启动的传统模式

目前支持从NAND FLASH启动的SoC芯片中,一般都内嵌有片卜存储器。各个处理器厂商对这块片上存储器定义的容量大小有所不同,但是启动模式都是比较一致的。NAND FLASH按页顺序读取的方式,意味着对当前的存储地址访问后就无法马上再次访问,需在当前页访问完成后,重新对此页访问时,才可对先前的地址单元再次访问,这就导致了一些程序语句无法执行,譬如跳转、循环等语句的使用。因此NAND FLASH仅作为启动代码的存储区,而真正执行的存储器区域是内嵌的片上存储器或者片外的SDRAM。

以上文中描述的控制器为例,按照这种启动模式,程序搬运以及执行的过程如下:

 

 

 

系统上电前,外部硬线NAND BOOT开关选择从NAND FLASH启动。芯片设计时,默认DMA占有系统总线,DMA按照配置寄存器的默认值工作,其源地址指向NAND FLASH,目标地址指向片上SRAM,NANDFLASH控制器在NAND BOOT选中的情况下,默认向NAND FLASH的首页发出读命令。即上电后,DMA控制器以及NAND FLASH控制器默认的把FLASH存储器中的第一页搬到了片上SRAM中。一直到DMA的工作完成前,ARM核无法占用总线。此时零地址映射在片上SRAM,DMA完成搬运后,ARM开始执行程序。此段代码完成的工作包括对SDRAM控制器的初始化,从NAND FLASH搬运核心代码至SDRAM,配置地址重映射寄存器至零地址处,最后将PC指向零地址的SDRAM。在SDRAM执行的代码开始真正启动系统。

5 NAND FLASH系统启动的新方法

一般情况下,片上存储器在作为启动代码转移阶石的同时,往往在启动后也有其特殊的作用。可以作为特殊的程序区,譬如在进行MP3解码过程中,核心解码函数作为频繁调用的程序,可以安排在片上SRAM中,以提高读取速度,提升系统性能。在SoC芯片开发过程中,在整体架构以及模块功能的变化之后,这块内嵌的SRAM失去了原来的作用,而仅作为NAND FLASH启动时的代码跳板,对于整个芯片而言,付出的代价比较大。于是提出了在没有片上存储器的架构下,从NAND FLASH启动的一种新模式。

在上述一般模式启动过程中,片上SRAM所起到的作用,就是执行NAND FLASH中第一页的代码,将真正的启动代码引入到SDRAM,最后将PC指针指向SDRAM。在失去片上SRAM的支持后,可以在控制器的FIFO中去执行此段代码,这需要在硬件以及软件代码中作出适当的改变。 (1) 首先需要改变的是地址映射的机制,系统上电后,ARM即从零地址开始执行指令,零地址映射到NAND FLASH的FIFO入口地址,地址的译码过程由AMBA总线模块完成。在外部硬线NAND BOOT拉高的条件下,AMBA从设备地址译码模块在启动过程中,将零地址的设备选择权给到缓冲FIFO。在第一页的指令执行完毕后,PC指针也指向SDRAM。

(2) 其次是NAND FLASH控制器在启动过程中,对数据的读取方式。鉴于NAND FLASH大批量数据读写的特性,往往采用DMA方式对数据进行操作。启动过程中,由ARM core直接向FIFO读取数据,在FIFO读空的情况下,将从没备READY信号拉低,等待NAND中的数据读出。并且在此读取过程中,DMA的请求被屏蔽。

(3) NAND FLASH型号类型众多,从每页容量大小、数据宽度、地址级数以及各型号芯片不同的时序参数,决定了一个控制器接口的兼容性要求相当的高。为了兼容从不同的NAND FLASH启动,设置了4根硬线作为选择。NAND BOOT选择是否从NAND FLASH启动;PAGESIZE选择每页大小,支持512 B/page,2 kB/page;IOWIDE选择数据端口的宽度,支持8位、16位;AD-DRESSCYCLE选择发送地址级数,支持3级、4级、5级地址。时序参数的配置值可以采用默认的宽松值,在读取首页信息之后,将配置值根据当前的时钟频率以及芯片类型,选择舍适的时序值以达到最佳的性能。 (4) 存储器首页的代码是在缓冲FIFO中执行的,FIFO的入口地址是一个高24位的选通地址,因此当系统启动时,零地址开始增加,对FIFO中渎出的指令而言,低8位地址的变化是无关的,FIFO始终被选通。指令的输出是默认的顺序输出。这就要求首页的代码中不可以出现循环、跳转等语句,并且要求在128条指令内完成需要的操作。

6 启动代码和流程的分析

上述的汇编程序即是存放在NAND FLASH首页的启动代码,启动的流程如下:

(1) 配置DMA控制器的4个寄存器,通道使能后,等待FLASH发出的搬运请求;

(2) 配置NAND FLASH控制器的3个寄存器,选择适合的地址、时序参数与所用的FLASH芯片吻合;

(3) 分别在r8~r11中放入程序需要的备用值;

(4) 将需要在SDRAM中运行的4条指令搬入SDRAM 0x30000000处;

(5) 执行Nop指令,Nop指令用于填充一页NANDFLASH中的剩余空间;

(6) 执行在页末的指令,将PC指针指向SDRAM的0x30000000处;

(7) 执行SDRAM中的指令,首先启动NANDFLASH的数据传输,将程序搬往SDRAM的0x30001000处。其次执行一个循环语句,等待第一页的程序搬完,之后将PC指针指向0x30001000处,启动程序从0x30001000处正式开始执行。

7 结 语

本文提出了一种NAND FLASH自启动的新方案,通过对硬件电路以及软件代码作合适的调整,从芯片中去除了内部SRAM,降低了SoC芯片的开发成本。本方案已经通过一款命名为GarfieldV的SoC芯片的测试,达到了预期的效果。

关键字:ARM7  缓冲  编码 引用地址:一种NAND FLASH自启动的新方法

上一篇:基于FPGA的高速大容量固态存储设备设计
下一篇:基于VxWorks的FLASH存储器实时存取管理方案

推荐阅读最新更新时间:2024-05-13 18:36

基于MSP430的便携式心率计的设计
  在消费电子领域,便携式电子产品由于体积小、质量轻的特点越来越受到消费者的喜爱,已成为人们生活中不可缺少的部分。基于这个思路,我们设计了一款便携式心率计,它可以替代用脉搏听诊器等进行测量的传统方法,使用非常方便。该产品主要包括三个部分:信号的采集、数据处理以及LED显示和报警电路。    系统总体设计   图1为本系统的原理框图。 图1 系统结构框图   如图1所示,从传感器检测到的脉搏信号转化为电压信号送入电压跟随器,起到缓冲的作用,使前级和后级隔离开来,避免相互干扰。输出的信号经前置放大后送入高通滤波器,以滤除传感器的热电干扰,再经过低通滤波器滤除环境中的高频干扰。处理完的信号送入后级继续放大以便得到干扰小且
[医疗电子]
关于初学者该选择学习ARM7还是ARM9的一点建议
一. 谈谈ARM7与ARM9的区别: 本文是写给准备学习ARM技术,而又没想好要学ARM7还是ARM9, 或者对ARM7与ARM9的区别不是很了解的初学者。 ARM7和ARM9的区别: 1. 时钟频率的提高 虽然ARM7和ARM9内核架构相同,但ARM7处理器采用3级流水线的冯 诺伊曼结构;,而ARM9采用5级流水线的哈佛结构。增加的流水线设计提高了时钟频率和并行处理能力。5级流水线能够将每一个指令处理分配到5个时钟周期内,在每一个时钟周期内同时有5个指令在执行。在常用的芯片生产工艺下,ARM7一般运行在100MHz左右,而ARM9则至少在200MHz以上。 2 指令周期的改进 指令周期的改进对于处理器性能的提高有很大的帮
[单片机]
通信网络测试仪表中CAP软件模块的研究
  1 引 言   通信网络测试仪中的信令分析,针对的是协议栈一系列的传输层和应用层协议。仪表协议分析的基础,要能够实现对所接收到的网络数据进行译码解析,并在此功能上进行更高级的统计追踪功能。在进行协议分析时,鉴于协议之间消息格式和处理机制的不同,以及软件模块化的实现要求,采取以单个协议进行模块封装的办法是更有效的,其好处在于能够忽略协议问功能和格式的细微差别,对单个协议的分析方法也能在很大程度上推广到其他协议。   本文研究的主要内容是CAP消息的分析,一方面描述如何根据协议标准中规定的协议消息结构进行解码,另一方面结合实际情况探讨CAP消息的统计及呼叫数据记录合成等功能。   2 CAP协议概述   智能网是通信技术和
[测试测量]
基于APEX20K和ARM7 TDMI-S微处理器实现通用智能传感器IP核的设计
智能传感器技术是一门正在蓬勃发展的现代传感器技术,是涉及微机械和微电子技术、计算机技术、网络与通信技术、信号处理技术、电路与系统、传感技术、神经网络技术、信息融合技术、小波变换理论、遗传理论、模糊理论等多种学科的综合技术。 智能传感器中智能功能如:数字信号输出、信息存储与记忆、逻辑判断、决策、自检、自校、自补偿都是以微处理器为基础的。基于微处理器的传感器从简单的数字化与信息处理已发展到了目前具有网络通信功能、神经网络、模糊理论、遗传理论、小波变换理论、多传感器信息融合等新理论新技术逐步完善的现代智能传感器。其微处理器硬件也经历了从单CPU结构到多CPU甚至DSP、ASIC与MCU相混合的结构。然而微处理器在可靠性、功耗、功能复
[单片机]
基于APEX20K和<font color='red'>ARM7</font> TDMI-S微处理器实现通用智能传感器IP核的设计
基于旋转变压器移相编码的工程设计
1 移相编码器原理概述 1.1 原理及说明     本方案采用以旋转变压器作为轴角传感器的机械转角转换其与之成正比的相位移。首先用激磁信号作为计数器计数的开门信号,通过移相网络与机械转角成正比关系的移相信号作为计数器的关门信号。开门信号使计数器开始计数,而关门信号使计数器停止计数。此时保存在计数器里的数码大小,便为机械转角成对应关系的数码。 1.2 框图 1.3 所能达到的技术指标     采用粗精双通道组合,粗:精=20:1。粗、精计数器均采用10位,粗满量程为6000密位,精满量程为300密位。210=1024故在360°里对应的数码为1024。显然计数器中相差一个数码对应的粗密位数密位。对应的精密位数。     各个角度里的
[电源管理]
基于旋转变压器移相<font color='red'>编码</font>的工程设计
具有波特率自适应功能的无线数据传输模块设计
1 模块总体结构 基于nRF401无线数据传输器件的数传模块总体硬件结构如图1所示,主要由微控制器和蓝牙芯片及其相应的外围电路组成,能自动完成波特率识别,并进行数据的编码处理,给用户提供了一个透明的数据接口。微控制器选用Atmel公司推出的可在线编程的单片机AT89S51,便于以后软件的升级。通过对发送数据是否需要曼彻斯特编码、所需外围元件的数量、功耗及发射功率等方面的因素综合比较,选用nRF40l作为无线数传器件。 nRF401是单片无线收发器件,采用蓝牙核心技术设计,内部集成高频发射、高频接收、PLL合成、FSK调制、FSK解调、多频道切换等诸多功能和外围部件协议,是目前集成度最高的无线数传产品,也是唯一可以直接连接微控制
[应用]
CDMA 2000系统中前向链路卷积编码器的FPGA实现
摘要:为了缩短卷积编码器设计周期,使硬件设计更具灵活性,在介绍卷积编码器原理的基础上,论述了一种基于可编程逻辑器件,采用模块化设计方法,利用VHDL硬件描述语言实现CDMA2000系统前向链路卷积编码器的方法,给出了在QuartusⅡ软件下的仿真结果,并在FPGA器件上验证实现。仿真和实验都证明了这种方法的可行性和正确性。 关键词:FPGA;VHDL;CDMA 2000;卷积编码器;前向差错控制 0 引言 在通信系统中,由于数字信号在传输过程中受到各种干扰的影响,使信号码元波形变坏,故传输到接收端后可能发生错误判决,为解决这一问题,通常在设计数字通信系统时,首先应从合理地选择调制制度、解调方法以及发送功率等方面考虑,若采取
[工业控制]
CDMA 2000系统中前向链路卷积<font color='red'>编码</font>器的FPGA实现
STM32串口环形缓冲
1:概述 1.1:本篇实现串口驱动,实现printf函数的重定向,实现串口的中断接受和发送,效仿modbus协议中的3.5T超时机制,判断是否接受完毕; 1.2:如果串口仅仅是实现一个控制台,打印一些debug数据,使用printf函数(串口发送数据忙等待),如果是需要用串口进行外设设备的控制,比如串口GPRS模块,需使用串口中断进行控制,因为受限于串口的传输速率,如果使用忙等待发送数据,会阻塞主程序中的其它任务; 1.3:使用sysclk作为超时定时器,sysclk的中断优先级需高于串口中断; 1.4:除过使用3.5T超时时间判断接受数据是否完成外,还可使用ASCLL码的形式,利用字符操作库函数,自定义串口通信协
[单片机]
小广播
热门活动
换一批
更多
最新应用文章
更多精选电路图
换一换 更多 相关热搜器件
更多每日新闻
随便看看

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 安防电子 医疗电子 工业控制

词云: 1 2 3 4 5 6 7 8 9 10

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved