添加到收藏夹 | 设为首页    首页 | 会员登录 | 我的电子助手 | 电子网站地图 | PD资料站 | 联系我们  
51电子网LOGO
 
  首 页  | 供应信息   |  求购信息  |  非IC专区   
   电子资讯   |  电子论坛
 
 
 
位置:首页 > 技术文章 > 存 储 器 > 详细内容  

AM30L V0064D在单片机系统中的典型应用

发布时间:2008-5-27   访问次数:

来源:单片机及嵌入式系统应用 作者:张 翼摘要: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口,则需要加一些简单的逻辑控制。下面介绍am30lv0064dat89ls8252单片机接口时的一种应用设计电路。由于单片机缺少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所示。

 
 关闭窗口  打印本页
遥操作机器为系统中6自由度输入设备的设计  [2008-6-3]
  此篇文章推荐型号 X25128P  的供应信息
基于神经网络模块SN9701开发多变量系统解耦控制器  [2008-6-3]
  此篇文章推荐型号 TLC393CPS  的供应信息
模糊控制在基于CAN总线的数据采集与控制系统中的应用  [2008-6-3]
  此篇文章推荐型号 VT8363E  的供应信息
BP神经网络用于三相电弧炉弧流控制  [2008-6-3]
  此篇文章推荐型号 LTC1798CS8-4.1  的供应信息
带RTC的I2C总线铁电存储器FM31256的设计  [2008-5-27]
  此篇文章推荐型号 LMV931MG  的供应信息
基于ISP1362的U盘MP3播放器设计来源:电子设计应用  [2008-5-27]
  此篇文章推荐型号 AT49F040-12TI  的供应信息
铁电在电力参数监测中的应用  [2008-5-27]
  此篇文章推荐型号 GM71VS65163CLT5  的供应信息
AM30L V0064D在单片机系统中的典型应用  [2008-5-27]
  此篇文章推荐型号 DTC114YK  的供应信息
赛普拉斯非易失性静态随机存取存取器(NVSRAM) [2008-6-3]
  此篇文章推荐型号 MSP3410B-PP-F7  的供应信息
基于OrCAD/Pspice 9平台的电子电路设计 [2008-6-3]
  此篇文章推荐型号 MB3776APNF-G-BND-EF  的供应信息
基于USB的数据采集系统设计及实现 [2008-6-3]
  此篇文章推荐型号 M64084AGP  的供应信息
用Visual C++实现工控设备多线程控制程序  [2008-6-3]
  此篇文章推荐型号 MIC4426BN  的供应信息
汽车变截面板簧轧机计算机控制系统的研究  [2008-6-3]
  此篇文章推荐型号 SG3526BN  的供应信息
片外FIash存储器IAP的n种方案  [2008-5-27]
  此篇文章推荐型号 MAX1762EUB  的供应信息
SDRAM在任意波形发生器中的应用  [2008-5-27]
  此篇文章推荐型号 AD3410A  的供应信息
 
 
 

 
版权所有:51电子网-中国最专业的电子元件交易平台 2000-2005 → 给本站留言 粤ICP备06016101
服务热线 深圳:0755-83754112、83754219 传真:0755-83752517 
库存上载:51dzw_stock@163.com  在线MSN咨询:service_51dzw@hotmail.com  OICQ:点击这里给我发消息  点击这里给我发消息