NAND Flash芯片K9F1208在uPSD3234A上

nand flash芯片k9f1208在upsd3234a上的应用
1 nand flash和nor flash 闪存(flash memory)由于其具有非易失性、电可擦除性、可重复编程以及高密度、低功耗等特点,被广泛地应用于手机、mp3、数码相机、笔记本电脑等数据存储设备中。nand flash和nor flash是目前市场上两种主要的非易失闪存芯片。与nor flash相比,nand flash在容量、功耗、使用寿命等方面的优势使其成为高数据存储密度的理想解决方案。nor flash的传输效率很高,但写入和擦除速度较低;而nand flash以容量大、写速度快、芯片面积小、单元密度高、擦除速度快、成本低等特点,在非易失性类存储设备中显现出强劲的市场竞争力。
结构:nor flash为并行,nand flash为串行。
总线:nor flash为分离的地址线和数据线,而nandflash为复用的。
尺寸:典型的nand flash尺寸为nor flash尺寸的1/8。
坏块:nand器件中的坏块是随机分布的,需要对介质进行初始化扫描以发现坏块,并将坏块标记为不可用。
位交换:nand flash中发生的次数要比nor flash多,建议使用nand闪存时,同时使用edc/ecc算法。
使用方法:nor flash是可在芯片内执行(xip,execute in place),应用程序可以直接在fiash闪存内运行,不必再把代码读到系统ram中;而nand flash则需i/o接口,因此使用时需要写入驱动程序。
通过以上的分析和比较,nand flash更适合于大容量数据存储的嵌入式系统。本设计选用samsung公司生产的nand flash存储器芯片k9f1208作为存储介质,并应用在基于upsd3234a增强型8051单片机的嵌入式系统中。
2 upsd3234a简介
upsd3234a是由意法半导体公司生产的一款基于8052内核的增强型flash单片机,其结构如图1所示。该单片机包含1个带8032微控制器的flash psd、2块flash存储器、sram、通用i/o口可编程逻辑、管理监控功能,并可实现usb、i2c、adc、dac和pwm功能。其中,片内8032微控制器,带有2个标准异步通信口、3个16位定时/计数器、1个外部中断以及jtag isp接口(用于在系统编程),一般应用于手持设备、家用电器等领域中。
3 k9f1208介绍
k9f1208是samsung公司生产的512 mb(64m×8位)nand flash存储器。该存储器的工作电压为2.7~3.6 v,内部存储结构为528字节×32页×4 096块,页大小为528字节,块大小为(16 kb+512字节);可实现程序自动擦写、页程序、块擦除、智能的读/写和擦除操作,一次可以读/写或者擦除4页或者块的内容,内部有命令寄存器。如图2所示,该器件按功能可以划分为:存储阵列、输入/输出缓冲、命令寄存器、地址译码寄存器和控制逻辑产生。其中,命令寄存器用来确定外部设备对存储器进行操作的类型;地址译码寄存器用于保存被访问的地址并产生相应的译码选通信号。主设备通过8位i/o端口分时复用访问器件命令、地址和数据寄存器,完成对芯片内存储器的访问。
4 k9f1208读/写和擦除操作的实现
对于k9f1208的操作主要有页读取和页编程操作。图3是nand flash的标准页读取时序图。具体的页读取操作如下:发命令阶段,在片选信号ce有效的情况下,首先命令允许信号cle有效,此时写入信号we有效,芯片准备好信号r/b置高,表示准备好;同时向i/o口发送读操作命令(0x00或0x01),表示是读操作。发地址阶段,此时片选有效,地址允许信号ale有效,写入信号we保持有效,连续发送4个地址字;k9f1208的地址寄存器接收到地址值后,r/b信号将维持“忙”一段时间,此后r/b变为准备好状态。最后是数据输出阶段,每次读有效信号置低有效时,将会输出一组数据。如此往复直到所有数据输出完毕。
图4是nand flash的标准页编程时序图。具体的页编程操作如下:发命令阶段,向i/o口发送页编程操作第一个命令字(0x80),表示是页编程操作。发地址阶段,连续发送4个地址字,k9f1208的地址寄存器接收到地址值后,等待接收数据;当数据总线发送数据后,k9f1208连续接收数据,直到接收到页编程的第二个命令字(0x10),即结束等待接收数据的状态;r/b信号将维持“忙”一段时间,此后r/b变为准备好状态。最后总线上发出读状态命令字(0x70),则k9f1208的命令寄存器接收并响应该命令,向i/o口发送表示操作成功的状态数据(0x00)或表示操作失败的状态数据(0x01)。
5 upsd3234a与k9f1208的连接
5.1 硬件部分
upsd3234a的数据总线data0~7直接连接到k9f1208的数据线上。k9f1208的读/写信号是直接通过upsd3234a的读/写信号驱动的,k9f1208的ale地址允许信号、cle命令允许信号、片选使能信号分别由upsd3234a的p43、p44、p45来控制,而k9f1208的r/b状态输出信号由upsd3234a的p46来读取。硬件连接如图5所示。根据该硬件连接的情况,在驱动过程中,可以在upsd3234a中定义一个无效地址,通过对该无效地址进行读写来控制wr和rd信号。
5.2 软件部分
本设计的驱动程序包括基本的操作函数和flash操作api函数。基本的操作函数包括输入命令值、输入地址值、输入数据值、读取数据值和读取状态等函数。由于k9f1208是无地址的,故先定义一个外部存储器的空地址来对它进行空写和空读。定义的语句为:
xdata unsigned char rk9fl208data _at_0x5000000;
根据硬件连接图,基本api函数的程序为:
(1) 输入命令值函数
程序说明:赋予p4_5为0,使得ce信号成低电平,从而片选k9f1208有效;赋予p4_4为1,使得cle信号成高电平,从而使k9f1208的命令允许信号有效;赋予p4_3为0,使得ale信号成低电平,从而使k9f1208的地址允许信号无效;最后对rk9f1208data进行空写命令字,使得we信号成低电平,k9f1208的命令寄存器从数据总线接收到命令字,并执行相应的操作。
(2) 输入地址值函数
程序说明:赋予p4_5为0,使得ce信号成低电平,从而片选k9f1208有效;赋予p4_4为0,使得cle信号成低电平,从而使k9f1208的命令允许信号无效;赋予p4_3为1,使得ale信号成高电平,从而k9f1208的地址允许信号有效;最后对rk9f1208data进行空写地址字,使得we的信号成低电平,k9f1208从数据总线接收到地址字,并锁存到地址锁存器中。
(3) 输入数据值函数
程序说明:赋予p4_5为0,使得ce信号成低电平,从而片选k9f1208有效;赋予p4_4为0,使得cle信号成低电平,从而使k9f1208的命令允许信号无效;赋予p4_3为0,使得ale信号成低电平,从而使k9f1208的地址允许信号无效;最后对rk9f1208data进行空写数据,使得we的信号成低电平,k9f1208从数据总线接收到数据,并根据命令寄存器和地址锁存器来处理接收到的数据。
(4) 读取数据值函数
程序说明:赋予p4_5为0,使得ce信号成低电平,从而片选k9f1208有效;赋予p4_4为0,使得cle信号成低电平,从而k9f1208的命令允许信号无效;赋予p4_3为0,使得ale信号成低电平,从而使k9f1208的地址允许信号无效;最后对rk9f1208data进行空读数据,使得re的信号成低电平,k9f1208会根据命令寄存器和地址锁存器来向数据总线发送相应的数据。
(5) 读取状态函数
程序说明:只是读取p4_6的状态,以判断k9f1208是否“忙”。如果p4_6为高电平,则表示k9f1208不忙,返回高电平;如果p4_6为低电平,则表示k9f1208“忙”,返回高电平。
为了合理地操作k9f1208,还添加了不选中k9f1208的函数,以便在页读取和页编程操作后,使k9f1208不工作。程序只是让p4_5、p4_4、p4_3为低电平,从而使得k9f1208的片选信号、命令允许信号、地址允许信号无效。宏定义语句如下:
#define flash_inactive( ){p4_5=0;p4_4=0;p4_3=0;)
flash操作api函数包括复位k9f1208、验证k9f1208的id号、擦除k9f1208某一扇区、凑取k9f1208某一扇区数据和写入k9f1208某一扇区数据等函数。因为篇幅关系,只介绍页读取和页编程函数。
图6是读取k9f1208某一扇区或某一页的数据流程图。首先,开始向k9f1208发送页读取命令字0x00,使得k9f1208的命令寄存器接收到命令字;然后取得要读取扇区的地址,连续向k9f1208发送4个地址数据,发送完后读取k9f1208的r/b引脚的状态,直到k9f1208不忙(表示地址数据已接收完毕);k9f1208开始读取该地址所指的扇区,并向数据总线发送一个扇区的数据,此时读取k9f1208的数据总线,直到整页结束。
图7是写入k9f1208某一扇区或一页的数据流程图。首先向k9f1208发送页编程的命令字0x80,使得k9f1208的命令寄存器接收到命令字;然后取得要写入扇区的地址,连续向k9f1208发送4个地址数据,发送完后读取k9f1208的r/b引脚的状态,直到k9f1208不忙(表示地址数据已接收完毕);k9f1208准备从数据总线接收一个扇区的数据,此时向k9f1208的数据总线发送一个扇区的数据,让k9f1208接收数据,并存到相应的页或扇区中;待发送的数据结束后,向k9f1208发送0x10 命令,使得k9f1208结束页编程的操作;最后向k9f1208发送查询状态的命令字0x70,k9f1208接收到命令字后,就会向数据总线发送一个字节的数据,这时读取k9f1208的数据总线,若收到字节0x00,则表示操作成功,若收到字节0x01,则表示操作失败。
结 语
本文介绍了samsung公司k9f1208芯片特点,并在此基础上设计了基于upsd3234a的驱动设计。该方法对其他相关soc中实现nand flash的控制方法设计有直接的参考意义,可广泛应用于需要大存储容量的低端设备中。

暴风VR一体机要干翻全球三大头显,并带来四大VR预测
多层PCB压机温度和压力均匀性应该怎样来测试
联想aio520c 24一体机
小米公交爆发!MIUI首家支持“交通联合卡”可刷近百城市
奇瑞拟明年提交IPO申请,预计估值1500亿元
NAND Flash芯片K9F1208在uPSD3234A上
5G的到来将如何带领ICT行业打赢这场转型升级的攻坚战
第三届世界互联网大会上,安防又有哪些看点呢?
Intel结盟三星公布Tizen移动系统开发工具
中移物联:5G赋能,推动产业生态全面发展
成都将力争到2021年建成4个以上成熟的人工智能产业区
三星电视开启“圣诞欢乐购” 8K电视打造极致沉浸视觉享受
重磅官宣!机械师×柳全联名螺蛳粉,开黑嗦粉快乐翻倍
东芝闪存取消转让交易,这是坐地起价还是不需要卖了?
基于PSoC的精简LED点阵系统设计方案
如何选购LED透明屏_影响LED透明屏价格的因素
光敏电阻的基本原理
你的Apple Watch存在这种问题么?
基于51框架的高性能单片机软核设计
区块链有潜力改善行业中存在的脆弱性