
flash接口电路的实现.docx
4页flash接口电路的实现0引言 我们在进行嵌入式系统设计的过程中,根据需求,要设计出特定的嵌入式应用系 统,而嵌入式应用系统的设计包含硬件系统设计和软件系统设计两个部分,并且这两部分设 计是互相关联、密不可分的,嵌入式应用系统的设计经常需要在硬件和软件设计之间进行权 衡与折中因此,这就要求嵌入式系统设计者具有较深厚的硬件和软件基础,并具有熟练应 用的能力在整个设计过程中,硬件设计是系统设计的基础和核心,而各功能部件在整个设 计中的调试又是该环节的重点和难点本文详细介绍嵌入式系统Flash存储器的接口电路的 调试 1 Flash存储器接口电路的引脚信号及各项特性 1.1 Flash存储器接口电路的特点 Flash存储器是一种可在系统(In-System)中进行电擦写,掉电后信息不会丢失的 存储器它具有低功耗、大容量、擦写速度快、可整片或分扇区在系统编程(烧写、)擦除等 特点,并且可由内部嵌入算法完成对芯片的操作,因而在各种嵌入式系统中得到了广泛的应 用作为一种非易失性存储器,Flash在系统中通常用于存放程序代码、常量表以及一些在 系统掉电后需要保存的用户数据等常用的Flash为8位或16位数据宽度,编程电压为单 3.3V。
主要有ATMEL、AMD、HYUNDAI等生产厂商,他们生产的同型器件一般具有相同的电气 特性和封装形式,可通用 1.2以HY57V641620为例的SDRAM接口电路的基本特性 本文以Flash存储器HY29LV160为例,简要描述一下Flash存储器的基本特性: HY29LV160 的单片存储容量为16M位(2M字节),工作电压为2.7V〜3.6V,采用48脚TSOP封装或48 脚FBGA封装,16位数据宽度,可以以8位(字节模式)或16位(字模式)数据宽度的方式 工作 HY29LV160仅需单3V电压即可完成在系统的编程与擦除操作,通过对其内部的命 令寄存器写入标准的命令序列,可对Flash进行编程(烧写)、整片擦除、按扇区擦除以及其 它操作 HY29LV160的逻辑框图、引脚分布及信号描述分别:图1 HY29LV160引脚分布(TSOP48封装)表1 HY29LV160的引脚信号描述引脚类型描述A[19:0]I地址总线在字节模式下,DQ[15]/A[-1]用作21位字节地址的最低位DQ[15]/A[-1]DQ[14:0]I/O三态数据总线在读写操作时提供8位或16位数据的宽度在字节模式下,DQ[15]/A[-1]用作 21位字节地址的最低位,而DQ[14:8]处于高阻状态。
BYTE#I模式选择低电平选择字节模式,高电平选择字模式CE#I片选信号,低电平有效在对HY29LV160进行读写操作时,该引脚必须为低电平,当为高电 平时,芯片处于高阻旁路状态OE#I输出使能低电平有效输出使能,低电平有效在读操作时有效,写操作时无效WE#I低电平有效写使能,低电平有效在对HY29LV160进行编程和擦除操作时,控制相应的写命 令RESET#I硬件复位,低电平有效对HY29LV160进行硬件复位当复位时,HY29LV160立即终止正在 进行的操作RY/BY#O用就绪/忙状态指示用于指示写或擦除操作是否完成当HY29LV160正在进行编程或擦除操 作时,该引脚位低电平,操作完成时为高电平,此时可读取内部的数据VCC一一3.3V电源VSS一一接地1.3以HY29LV160为例的Flash接口电路的使用方法下面,我们使用HY29LV160来构建存储系统由于ARM微处理器的体系结构支持8位/16 位/32位的存储器系统,对应的可以构建8位、16位、32位的Flash存储器系统32位的存 储器系统具有较高的性能,而16位的存储器系统则在成本及功耗方面占有优势,而8位的存 储器系统现在已经很少使用。
下面主要介绍16位和32位的Flash存储器系统的构建 1.3.1.16位的FLASH存储器系统 在大多数的系统中,选用一片16位的Flash存储器芯片(常见单片容量有1 MB、2MB、4MB、8MB等)构建16位Flash的存储系统已经足够, 在此采用一片HY29LV160构建16位的Flash存储器系统,其存储容量为2MBFlash存储器 在系统中通常用于存放程序代码,系统上电或复位后从此处获取指令并开始执行,因此,应 将存有程序代码的Flash存储器配置到ROM/SRAM/FLASH Bank0,即将S3C4510B的 nRCS<0>(Pin75)接至 HY29LV160 的 CE#端 HY29LV160 的 RESET#端接系统复 位信号; OE#端接 S3C4510B 的 nOE (Pin72); WE#端 S3C4510B 的 nWBE<0>(Pin100); BYTE# 上拉,使HY29LV160工作在字模式(16位数据宽度); RY/BY#指示HY29LV160编程或擦除操作的工作状态,但其工作状态也可通过查询片内的相关寄存器来 判断,因此可将该引脚悬空; 地址总线[A19〜A0]与S3C4510B的地址总线[ADDR19〜ADDR0]相连; 16位数据总线[DQ15~DQ0]与S3C4510B的低16位数据总线[XDATA15~XDATA0]相连。
注意此时应将 S3C4510B 的 B0SIZE[1:0]置为“10”,选择 ROM/SRAM/FLASHBank0 为16位工作方式 1.3.2. 32位的FLASH存储器系统 作为一款32位的微处理器, 为充分发挥S3C4510B的32性能优势,有的系统也采用两片16位数据宽度的Flash存储器芯 片并联(或一片32位数据宽度的Flash存储器芯片)构建32位的Flash存储系统其构建 方式与16位的Flash存储器系统相似 采用两片HY29LV16并联的方式构建32位的FLASH 存储器系统,其中一片为高16位,另一片为低16位,将两片HY29LV16作为一个整体配置到 ROM/SRAM/FLASHBank0,即将S3C4510B 的 nRCS<0>(Pin75)接至两片HY29LV16 的 CE#端; 两片HY29LV160的RESET#端接系统复位信号; 两片HY29LV160的OE#端接S3C4510B 的 nOE(Pin72); 低 16 位片的 WE#端接 S3C4510B 的 nWBE<0> (Pin100),高 16 位片的 WE#端接 S3C4510B 的 nWBE<2> (Pin102); 两片 HY29LV160 的 BYTE #均上拉,使之均工作在字模式; 两片HY29LV160的地址总线[A19〜A0]均与S3C4510B的地址总线[ADDR19〜ADDR0]相连; 低16位片的数据总线与S3C4510B的低16位数据总线[XDATA15~XDATA0]相连,高16位片的数据总线与S3C4510B的高16位数据总线 [XDATA31~XDATA16]相连。
注意此时应将S3C4510B 的 B0SIZE[1:0]置为“11”,选择ROM/SRAM/FLASH Bank0为32位工作方式 2.S3C4510B系统管理器关于存储器映射的工作原理 当系统设计制作完成时,必须经过仔细的调试,才能保证系统按照设计意图正常工作尽管系统的调试与个人对电路工作原理的理解和实际的电路调试经验有很大的关 系,但一定的调试方法也是必不可少的掌握正确的调试方法可使调试工作变得容易,大大 缩短系统的开发时间,反之,可能会使整个系统的开发前功尽弃,以失败告终 在系统 的两类存储器中,SDRAM相对于FLASH存储器控制信号较多,似乎调试应该困难一些,但由 于SDRAM的所有刷新及控制信号均由S3C4510B片内的专门部件控制,无需用户干预,在 S3C4510B正常工作的前提下,只要连线无误,SDRAM就应能正常工作,反之,Flash存储器 的编程、擦除操作均需要用户编程控制,且程序还应在SDRAM中运行,因此,应先调试好SDRAM 存储器系统,再进行Flash存储器系统的调试 基于S3C4510B系统的最大可寻址空间为64MB,采用统一编址的方式,将系统的SDRAM、SRAM、ROM、Flash、外部I/O以及片内的特 殊功能寄存器和8K 一体化SRAM均映射到该地址空间。
为便于使用与管理,S3C4510B又将64MB 的地址空间分为若干个组,分别由相应的特殊功能寄存器进行控制: (1) ROM/SRAM/Flash组0〜ROM/SRAM/Flash组5,用于配置ROM、SRAM或Flash,分别由特殊功能寄存器ROMCON0〜 ROMCON5 控制; (2) DRAM/SDRAM 组 0〜DRAM/SDRAM 组 3 用于配置 DRAM 或 SDRAM,分别 由特殊功能寄存器DRAMCON0〜DRAMCON3控制; (3)外部I/O组0〜外部I/O组3用于配置系统的其他外扩接口器件,由特殊功能寄存器REFEXTCON控制; (4)特殊功能寄存器组用于配置S3C4510B片内特殊功能寄存器的基地址以及片内的8K 一体化SRAM,由特殊功 能寄存器SYSCFG控制; 在系统中,使用了 Flash存储器和SDRAM,分别配置在ROM/SRAM/FLASH组0和DRAM/SDRAM组0,暂未使用外扩接口器件 3基于S3C4510B的嵌入式系统Flash存储器接口电路的调试 Flash存储器的调试主要包括Flash存储器的编程(烧写)和擦除,与一般的存储器件不同,用户只需对Flash存储器发出相应的命令序 列,Flash存储器通过内部嵌入的算法即可完成对芯片的操作,由于不同厂商的Flash存储 器在操作命令上可能会有一些细微的差别,Flash存储器的编程与擦除工具一般不具有通用 性,这也是为什么Flash接口电路相对较难调试的原因之一,因此,应在理解Flash存储器 编程和擦除的工作原理的情况下,根据不同型号器件对应的命令集,编写相应的程序对其进 行操作。
若使用SDT调试环境,调试过程与上述步骤相似 >obey C:memmap.txt打开AXD Debugger的命令行窗口,执行obey命令: 此时,2MB的Flash存储器映射到 地址空间的 0x0000,0000〜0x001F,FFFF 处,选择菜单 Processor Views→Memory 选项, 出现存储器窗口,在存储器起始地址栏输入Flash存储器的映射起始地址:0x0,数据区应显 示Flash存储器中的内容,若Flash存储器为空,所显示的内容应全为0xFF,否则应为已有 的编程数据双击其中的任一数据,输入新的值,对应存储单元的内容应不能被修改,此时 可初步认定Flash存储器已能被访问,但是否能对其进行正确的编程与擦除操作,还需要编 程验证,通过程序对Flash存储器进行编程和擦除操作 4结束语 这样整个基于的嵌入式系统Flash存储器接口电路的调试基本上完成了,当然对于不同的系统,操作是略有 不同的,我们可以根据所要开发或使用的嵌入式系统模式,进行适当的调整,保证我们正确 的使用Flash存储器。
