|
来源:单片机及嵌入式系统应用 作者:张 翼摘要:am30lv0064d是amd公司生产的一种新型超与非(u1tranand)结构的闪速存储器(flash)。本文介绍它的工作原理,以及它与at89ls8252单片机的硬件接口电路和pld内部逻辑控制设计的代码,并对编程操作的软件流程进行了描述。 关键词:am30lv0064d u1tranand 闪速存储器 1 概述am30lv0064d是amd公司生产的一种新型非易失性闪速存储器。或非(nor)结构的flash具有高速的随机存取功能,但成本较高;新的ultranand结构的flash相对于nor结构的flash,具有价格低,容量特别大的优势,支持对存储器高速地连续存取。谝芯片工作电压范围在2.7~3.6v,特别适用于需要批量存储大量代码或数据的语音、图形、图像处理场合,在便携式移动存储和移动多媒体系统中应用前景广阔。 2 工作原理与命令字设置am30lv0064d采用与工业级nand结构兼容的ultranand结构,内部包含1024个存储块(单元容量为8k字节+256字节缓存);存储块中的数据按页存放,每页可存储512字节,还有16字节缓存用作与外部数据交换时的缓冲区,每块共16页。所以,主存储区一共有16 384数据页,相当于64 mbit的数据存储器。 图1为am30lv0064d的内部结构和主要引脚示意图。 
am30lv0064d的主要引脚定义: ce--片选使能输入; ale--地址输入使能; cle--命令字输入使能; se--缓冲区使能输入,低电平有效; re--读使能输入,低电平有效; we--写使能输入,低电平有效; wp--写保护输入,低电平有效; ry/by--内部空闲/忙信号输出; i/o7~0--8位数据输入/输出口; vcc--3.3v核心电源; vccq--i/o口电源; vss--地。 am30lv0064d的读、编程和擦写等操作都可以在3.3v单电源供电状态下进行,同时它提供的vccq引脚在接5v时,i/o口可兼容5v电平。am30lv0064d支持对主存高速地连续存取和编程操作,连续读取数据的时间可小于50ns/字节(随机读取数据的响应时间为7μs,所以连续读取时第一个数据的响应时间也是7μs);对flash的编程是以页为单位的,步骤是先写入数据,再执行编程命令,编程速度为200μs/页(平均约400ns/字节);芯片擦除操作以存储块为单位,擦除其中某一块对其它存储块的数据没有影响,擦除时间2ms/存储块,而且还有延缓擦降/得擦除命令,允许用户在必要时暂缓擦除操作,转而处理对其它存储块进行数据读、写、编程等操作;此外,主机可以通过读ry/by引脚状态的方法了解flash内部操作是否已经完成,ry/by也可用于实现硬件判忙接口。am30lv0064d还具有写保护功能,这一功能通过将wp引脚设为低电平实现。 
所有操作都建立在命令字基础上。对主存操作时,所有命令字都通过芯片的8个i/o引脚写到命令寄存器中,激活状态机进行相应的操作。存储器地址以及数据也从8位i/o脚写入。对存储器地址进行连续操作或对存储块操作时都要先向地址寄存器写入1个起始地址。地址分3次写进去,从低字节开始传送,具体的地址位传送顺序分配如表1所列。(由于对存储器的读操作分前后2个半页,每半页256字节,在命令字中已经包含了此信息,而编程以页为单位、擦除以块为单位,所以传送的地址位中不含a8) 表1 地址分配表 i/o7 i/o6 i/o5 i/o4 i/o3 i/o2 i/o1 i/o0 第1周期 a7 a6 a5 a4 a3 a2 a1 a0 第2周期 a16 a15 a14 a13 a12 a11 a10 a9 第3周期 × × a22 a21 a20 a19 a18 a17am30lv0064d通过片选引脚ce使能,先是cle和we信号有效,通过i/o口写入命令字;接着ale和we有效,写入数据存取的起始地址。最后根据命令要求,读数据或数据。由于具有多元的控制总线,对应am30lv0064d的操作方式也是多样的。根据命令字的定义可进行以下操作,如表2所列。 表2 命令字定义表 命令字序列 总 线 周 期 1 2 3 4 5 6 操作 数据 操作 数据 操作 数据 操作 数据 操作 数据 操作 数据 读数据区-前半页 写 00h 写 sa 写 sa 写 sa 读 数据 etc. etc. 读数据-后半页 写 01h 写 sa 写 sa 写 sa 读 数据 etc. etc. 读数据-无缝隙读 写 02h 写 sa 写 sa 写 sa 读 数据 etc. etc. 读预留区 写 50h 写 sa 写 sa 写 sa 读 数据 etc. etc. 读id号 写 90h 写 00h 读 01h 读 e6h 读状态 写 70h 读 sr etc. etc. 输入数据 写 80h 写 sa 写 sa 写 sa 写 数据 etc. etc. 编程 写 10h 块擦除 写 60h 写 ba 写 ba 写 d0h 延缓擦除 写 b0h 重擦除 写 d0h 复位 写 ffh 注:sa表示起始地址,ba表示块地址,etc.表示操作同前一个周期。 3 应用电路设计am30lv0064d的外围电路设计简单。其控制总线包括ce(片选)、cle(命令字锁存使能)、ale(地址锁存使能)、we(写使能)、re(读使能)、se(预留区使能)、wp(写保护)等。对于那些具有可编程的i/o口的微控制器或dsp来说,可以直接把引脚与控制线相连。如果没有可编程的i/o口,则需要加一些简单的逻辑控制。下面介绍am30lv0064d与at89ls8252单片机接口时的一种应用设计电路。由于单片机缺少ultranand闪存所需的多元控制总线,在本设计中,采用地址译码的方法增加了控制端口,这部分逻辑可以用1片pld(可编程逻辑器件)完成。具体接口电路如图2所示。 以下是pld内部逻辑设计的源代码: port0=!a14&!a13&!a12&!a11; /*读写数据端口*/ port1=!a14&!a13&!a12&!a11; /*cle写端口*/ port2=!a14&!a13&!a12&!a11; /*设置ale端口*/ port3=!a14&!a13&!a12&!a11; /*清ale端口*/ port4=!a14&!a13&!a12&!a11; /*设置se端口*/ port5=!a14&!a13&!a12&!a11; /*清se端口*/ port6=!a14&!a13&!a12&!a11; /*设置wp端口*/ port7=!a14&!a13&!a12&!a11; /*清除wp端口*/ port8=!a14&!a13&!a12&!a11; /*设置ce1端口*/ port9=!a14&!a13&!a12&!a11; /*清除ce1端口*/ porta=!a14&!a13&!a12&!a11; /*读ry/by状态端口*/ portb=!a14&!a13&!a12&!a11; /*设置ce2端口*/ portc=!a14&!a13&!a12&!a11; /*清除ce2端口*/ /*逻辑方程*/ ready.oe=porta&read;/*ready只通过porta读取*/ ready=ry_by; cle=port1; ale=wrtie & port2#ale&!(write & port3)#ale & port2); se=write&port4#se&!(write & port5)#se & port4; wp=write & port6#wp&!(write & port7)# wp & port6; ce1=write &port8#ce &!(write &port9)#ce &port8; ce2=write & portb#ce&!(write & portc)#ce &portb; we=write & (port0#port1); re=read&port0; 4 软件流程 下面重点介绍通过单片机对am30lv0064d进行数据编程的软件流程:单片机启动编程程序,将is61lv256中的数据读出后再写到flash中,每次写512字节的数据(半页为256字节)。然后,对相应页进行编程,编程命令字写入后定期查询ry/by引脚,看编程是否已经完成,如果完成再读取flash的状态寄存器,可以知道编程是否成功。具体流程如图3所示。
|