NAND Flash芯片K9F1208在uPSD3234A上的应用

最新更新时间:2007-04-06来源: 单片机及嵌入式系统应用关键字:编程  擦除  功耗  串行 手机看文章 扫描二维码
随时随地手机看文章

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的控制方法设计有直接的参考意义,可广泛应用于需要大存储容量的低端设备中。

关键字:编程  擦除  功耗  串行 编辑: 引用地址:NAND Flash芯片K9F1208在uPSD3234A上的应用

上一篇:采用ST72F651实现的安全U盘
下一篇:USB海量存储类设备功能在ARM系统中的应用

推荐阅读最新更新时间:2023-10-13 10:44

ADI 推出低功耗 HDMI 接收器增强影音系统性能
利用 ADI 公司的 ADV7611 和 ADV7612 接收器,高清设计人员能够为需要小尺寸和 3D 支持的娱乐应用提供高端影音功能组合 Analog Devices, Inc. (ADI),全球领先的高性能信号处理解决方案供应商,最近宣布推出业界最小的单芯片接收器 ADV7611/12,两款器件均支持HDMI® (高清晰多媒体接口®)规范 1.4a 版规定的 3D 显示分辨率和扩展色度。ADI公司的 ADV7611低功耗165MHz接收器 和 ADV7612 225MHz双端口接收器 采用 Xpressview™ 快速切换技术,影音设计人员借助这些接收器能够提供过去只有价格昂贵的娱乐系统才具备的丰富功能组合和高清
[家用电子]
三菱PLC状态编程思想及步进梯形指令
    一、状态编程思想     以小车运动控制为例介绍状态编程思想。     二、步进梯形指令(STL、RET)     系列PLC的步进梯形指令是采用步进梯形图编制顺序控制状态转移图程序的指令,它包括STL和RET两条指令。其中步进梯形指令STL是利用内部状态软元件,在顺控程序上进行工序步进控制的指令;返回RET指令是表示状态流程结束,用于返回主程序的指令。     三、步进梯形指令的特点     步进梯形指令仅对状态器S有效,但是对于用作一般辅助继电器的状态器S,则不能采用STL指令,而只能采用基本指令。     其特点为:     1)转移源自动复位     2)允许双重输出:     3
[嵌入式]
德州仪器宣布推出业界最低功耗DC/DC 降压转换器
日前,TI 宣布推出业界最低功耗 DC/DC 降压转换器,与其它器件相比可将终端应用可使用的采集能量提升达 70%,回答了“在多低的电压下可以工作?”的问题。该超低功耗电路可实现各种应用的无电池供电,如无线传感器网络、监控系统、烟雾探测器、可佩戴医疗设备以及移动附件等。 TI 电源管理高级副总裁 Sami Kiriaki 指出:“设想一下,再也不用为烟雾探测器更换电池。TI 不断开发具有极低工作电流及极高电源效率的电路帮助管理微瓦至毫瓦级的电源,采集外界能量。该款最新电源电路可为设计人员提供传统电池供电系统所不具备的功能。” 最低功耗 DC/DC 转换器 TI TPS62736 DC/DC 转换器提供 10 uA 至
[工业控制]
IAR 编程器 STM8S 脚位的位定义
多余的就不说了,都明白,为了方便操作,我们常常会用到类似于LED1 = 1来点亮一个灯,此处LED1就是一个脚位,它当然不是系统自带,一般都是我们宏定义一个脚位。 昨天刚接触IAR这个编程器,想用类似的方法来操作,但是类似51内核操作(keil中写法) sbit LED1 PA0 ; STVD 中的 _Bool PA0_OUT @PA_ODR:0; 这是头有点大,一方面想着操作能方便点,一方面又不想折腾太多时间。 经过一番折腾,最后还是选择通过位操作结合宏定义来操作,具体如下: GPIO_PIN_0 = ((u8)0x01), /*! Pin 0 selected */ GPIO_PIN_1 = ((u8)
[单片机]
PIC 单片机软件异步串行口实现技巧
在用  单片机  开发各种嵌入式应用系统时,异步串行通信是经常要用到的一种通信模式,很多应用中还要求实现多路异步串行通信。大家平时熟悉的各种厂家的单片机,绝大部分片上只提供一个硬件 UART 模块,利用它可以方便实现一路串行通讯。P IC 系列单片机也不例外,在其丰富的产品家族成员中,除高端系列(PIC17/18)一些型号片上带有两路硬件UART模块外,其它大部分型号片上只有一路UART,一些低端廉价的PIC单片机甚至还不带硬件 UART。为了提高系统的性能价格比,就要求设计工程师用软件增加实现一路或多路异步串行通信。很多工程师对用软件实现的UART在可靠性和效率方面持怀疑态度,其实关键问题是看软件采用何种方式来实现可靠的UART
[单片机]
通用串行总线接口——USB
我相信大家都对USB有一定的了解吧。但是也不能排除有不懂的,不过没关系,下面我就把这一计算机外设接口技术——USB来个全面介绍。我以几个章节来介绍USB的概念、基本特性以及它的应用,让大家对USB有个全面的认识。   概念篇    由于多媒体技术的发展对外设与主机之间的数据传输率有了更高的需求,因此,USB总线技术应运而生。USB(Universal Serial Bus),翻译为中文就是通用串行总线,是由Conpaq,DEC,IBM,Inter,Microsoft,NEC和Northen Telecom等公司为简化PC与外设之间的互连而共同研究开发的一种免费的标准化连接器,它支持各种PC与外设之间的连接,还可实现数字多
[嵌入式]
MCS-51单片机与PLD 可编程器件接口设计
1 引 言 在电子设计技术领域,可编程逻辑器件的广泛应用,为数字系统的设计带来极大的灵活性。由于该器件可以通过软件编程而对其硬件的结构和工作方式进行重构,使得硬件的设计可以如同软件设计那样方便快捷。极大地改变了传统的数字系统设计方法和设计过程。 众所周知,单片机具有性能价格比高、功能灵活、易于人机对话、良好的数据处理能力等特点,PLD则具有高集成度、高速、高可靠以及开发便捷规范等优点,就目前常用的智能化仪器仪表和工业测控系统而言,由PLD和单片机为核心器件构成的综合电子系统的应用领域十分广阔。如果将单片机灵活的控制功能以及良好的人机对话功能与PLD高速高可靠性相结合,必将有效地突破传统电子系统设计中的障碍,并使电子系统
[单片机]
MCS-51单片机与PLD 可<font color='red'>编程</font>器件接口设计
高集成度编程工具软件STM32代码烧录编程实战
凡用过STM32的用户应该知道,当你完成程序调试后,想对STM32芯片进行程序代码烧录编程的话可以有多种方式。若通过调试接口【JTAG/SWD】来烧写程序,一般要使用STVP或STLinkUtility工具软件来完成;若通过UART接口来烧写程序,往往要下载个基于PC 端的flash烧录工具软件STM32 Flash loader demo配合;若通过USB接口来烧写程序,往往需下载DfuSe USB 固件升级工具软件来实现。如今ST推出了新的高集成度编程工具软件STM32CubeProgrammer,以后就不用这么麻烦了,因为它同时支持上述三类编程接口,而且还兼具其它功能。 一、STM32CubeProgrammer具备如下
[单片机]
高集成度<font color='red'>编程</font>工具软件STM32代码烧录<font color='red'>编程</font>实战
小广播
最新缓冲存储文章
换一换 更多 相关热搜器件

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