0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

解读NAND Flash芯片K9F1208在uPSD3234A的应用

电子工程师 来源:单片机及嵌入式系统应用 作者:刘芳 赵振华 2021-06-03 18:01 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

以Samsung NAND Flash器件K9F1208为例,对比NAND Flash和NOR Flash的异同;介绍大容量NAND Flash在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口可编程逻辑、管理监控功能,并可实现USBI2CADCDAC和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端口分时复用访问器件命令、地址和数据寄存器,完成对芯片内存储器的访问。

NAND Flash芯片K9F1208在uPSD3234A的应用

4 K9F1208读/写和擦除操作的实现

对于K9F1208的操作主要有页读取和页编程操作。图3是NAND Flash的标准页读取时序图。具体的页读取操作如下:发命令阶段,在片选信号CE有效的情况下,首先命令允许信号CLE有效,此时写入信号WE有效,芯片准备好信号R/B置高,表示准备好;同时向I/O口发送读操作命令(0x00或0x01),表示是读操作。

发地址阶段,此时片选有效,地址允许信号ALE有效,写入信号WE保持有效,连续发送4个地址字;K9F1208的地址寄存器接收到地址值后,R/B信号将维持“忙”一段时间,此后R/B变为准备好状态。最后是数据输出阶段,每次读有效信号置低有效时,将会输出一组数据。如此往复直到所有数据输出完毕。

NAND Flash芯片K9F1208在uPSD3234A的应用

图4是NAND FLash的标准页编程时序图。具体的页编程操作如下:发命令阶段,向I/O口发送页编程操作第一个命令字(0x80),表示是页编程操作。发地址阶段,连续发送4个地址字,K9F1208的地址寄存器接收到地址值后,等待接收数据;当数据总线发送数据后,K9F1208连续接收数据,直到接收到页编程的第二个命令字(0x10),即结束等待接收数据的状态;

R/B信号将维持“忙”一段时间,此后R/B变为准备好状态。最后总线上发出读状态命令字(0x70),则K9F1208的命令寄存器接收并响应该命令,向I/O口发送表示操作成功的状态数据(0x00)或表示操作失败的状态数据(0X01)。

NAND Flash芯片K9F1208在uPSD3234A的应用

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信号。

NAND Flash芯片K9F1208在uPSD3234A的应用

5.2 软件部分

本设计的驱动程序包括基本的操作函数和Flash操作API函数。基本的操作函数包括输入命令值、输入地址值、输入数据值、读取数据值和读取状态等函数。由于K9F1208是无地址的,故先定义一个外部存储器的空地址来对它进行空写和空读。定义的语句为:

xdata unsigned char rK9Fl208DATA _at_0x5000000;

根据硬件连接图,基本API函数的程序为:

(1) 输入命令值函数

NAND Flash芯片K9F1208在uPSD3234A的应用

程序说明:赋予P4_5为0,使得CE信号成低电平,从而片选K9F1208有效;赋予P4_4为1,使得CLE信号成高电平,从而使K9F1208的命令允许信号有效;赋予P4_3为0,使得ALE信号成低电平,从而使K9F1208的地址允许信号无效;最后对rK9F1208DATA进行空写命令字,使得WE信号成低电平,K9F1208的命令寄存器从数据总线接收到命令字,并执行相应的操作。

(2) 输入地址值函数

NAND Flash芯片K9F1208在uPSD3234A的应用

程序说明:赋予P4_5为0,使得CE信号成低电平,从而片选K9F1208有效;赋予P4_4为0,使得CLE信号成低电平,从而使K9F1208的命令允许信号无效;赋予P4_3为1,使得ALE信号成高电平,从而K9F1208的地址允许信号有效;最后对rK9F1208DATA进行空写地址字,使得WE的信号成低电平,K9F1208从数据总线接收到地址字,并锁存到地址锁存器中。

(3) 输入数据值函数

NAND Flash芯片K9F1208在uPSD3234A的应用

程序说明:赋予P4_5为0,使得CE信号成低电平,从而片选K9F1208有效;赋予P4_4为0,使得CLE信号成低电平,从而使K9F1208的命令允许信号无效;赋予P4_3为0,使得ALE信号成低电平,从而使K9F1208的地址允许信号无效;最后对rK9F1208DATA进行空写数据,使得WE的信号成低电平,K9F1208从数据总线接收到数据,并根据命令寄存器和地址锁存器来处理接收到的数据。

(4) 读取数据值函数

NAND Flash芯片K9F1208在uPSD3234A的应用

程序说明:赋予P4_5为0,使得CE信号成低电平,从而片选K9F1208有效;赋予P4_4为0,使得CLE信号成低电平,从而K9F1208的命令允许信号无效;赋予P4_3为0,使得ALE信号成低电平,从而使K9F1208的地址允许信号无效;最后对rK9F1208DATA进行空读数据,使得RE的信号成低电平,K9F1208会根据命令寄存器和地址锁存器来向数据总线发送相应的数据。

(5) 读取状态函数

NAND Flash芯片K9F1208在uPSD3234A的应用

程序说明:只是读取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的数据总线,直到整页结束。

NAND Flash芯片K9F1208在uPSD3234A的应用

图7是写入K9F1208某一扇区或一页的数据流程图。首先向K9F1208发送页编程的命令字0x80,使得K9F1208的命令寄存器接收到命令字;然后取得要写入扇区的地址,连续向K9F1208发送4个地址数据,发送完后读取K9F1208的R/B引脚的状态,直到K9F1208不忙(表示地址数据已接收完毕);

K9F1208准备从数据总线接收一个扇区的数据,此时向K9F1208的数据总线发送一个扇区的数据,让K9F1208接收数据,并存到相应的页或扇区中;待发送的数据结束后,向K9F1208发送0x10 命令,使得K9F1208结束页编程的操作;最后向K9F1208发送查询状态的命令字0x70,K9F1208接收到命令字后,就会向数据总线发送一个字节的数据,这时读取K9F1208的数据总线,若收到字节0x00,则表示操作成功,若收到字节0x01,则表示操作失败。

NAND Flash芯片K9F1208在uPSD3234A的应用

结 语

本文介绍了Samsung公司K9F1208芯片特点,并在此基础上设计了基于uPSD3234A的驱动设计。该方法对其他相关SoC中实现NAND Flash的控制方法设计有直接的参考意义,可广泛应用于需要大存储容量的低端设备中。

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片
    +关注

    关注

    463

    文章

    54377

    浏览量

    468987
  • 锁存器
    +关注

    关注

    8

    文章

    957

    浏览量

    45455
  • 函数
    +关注

    关注

    3

    文章

    4421

    浏览量

    67819
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    探索UPSD3212A/C/CV:集成8032 MCU、USB与可编程逻辑的闪存可编程系统设备

    探索UPSD3212A/C/CV:集成8032 MCU、USB与可编程逻辑的闪存可编程系统设备 在当今的电子设计领域,寻找一款功能强大、性能卓越且能满足多样化需求的系统设备至关重要。今天,我们将
    的头像 发表于 04-17 15:55 147次阅读

    探索PIC18(L)F2X/45K50 USB Flash MCU:功能特性与应用潜力

    探索PIC18(L)F2X/45K50 USB Flash MCU:功能特性与应用潜力 电子工程师的日常工作中,选择合适的微控制器(MCU)是项目成功的关键。Microchip的PI
    的头像 发表于 04-15 17:10 346次阅读

    探索Microchip PIC18(L)F2X/45K50 USB Flash MCU的卓越性能

    探索Microchip PIC18(L)F2X/45K50 USB Flash MCU的卓越性能 电子设计领域,选择一款合适的微控制器(MCU)对于项目的成功至关重要。Microch
    的头像 发表于 04-08 09:50 323次阅读

    NOR FLASHNAND FLASH的对比

    FLASH芯片的擦写次数一般来说都是有限的,目前主流产品的擦写寿命普遍10万次左右。当FLASH芯片接近使用寿命终点时,写操作可能会出现失
    的头像 发表于 03-31 16:58 428次阅读

    NOR FlashNAND flash有什么区别

    嵌入式系统、移动设备与存储领域,NOR FlashNAND Flash是两种最常见的非易失性存储技术。尽管它们都属于闪存(Flash E
    的头像 发表于 03-11 15:08 497次阅读
    NOR <b class='flag-5'>Flash</b>和<b class='flag-5'>NAND</b> <b class='flag-5'>flash</b>有什么区别

    从NOR FlashNAND Flash 和SD NAND,从底层结构到应用差异

    nor flash,nor nand,sd nand,spi nor,nand flash
    的头像 发表于 03-05 18:24 373次阅读
    从NOR <b class='flag-5'>Flash</b> 到 <b class='flag-5'>NAND</b> <b class='flag-5'>Flash</b> 和SD <b class='flag-5'>NAND</b>,从底层结构到应用差异

    从NOR FlashNAND Flash 和SD NAND,从底层结构到应用差异

    嵌入式系统开发中,“存储选型”是经常会遇到的问题,特别是许多曾长期使用 NOR   Flash 的工程师,切换到 NAND Flash
    发表于 03-05 18:23

    SPI NOR Flash和SPI NAND Flash存储芯片的区别

    SPI NOR Flash与SPI NAND Flash并非相互替代,而是互补关系。SPI NOR胜在读取速度快、使用简单、可靠性高,是代码存储的理想选择。SPI NAND则以其大容量
    的头像 发表于 01-29 16:58 832次阅读
    SPI NOR <b class='flag-5'>Flash</b>和SPI <b class='flag-5'>NAND</b> <b class='flag-5'>Flash</b>存储<b class='flag-5'>芯片</b>的区别

    从NOR FlashNAND Flash和SD NAND,从底层结构到应用差异

    嵌入式系统开发中,“存储选型”是经常会遇到的问题,特别是许多曾长期使用 NOR   Flash 的工程师,切换到 NAND Flash
    发表于 12-08 17:54

    震惊:他们家有现货。EMMC, DDR, NAND FLASH

    ; MT41K512M16VRP-107 AAT:P22000; MT40A1G8SA-062E:E 22000 MY40A256M16LY-062E:F 68000 NT5AD512
    发表于 11-27 15:58

    NAND Flash的基本原理和结构

    NAND Flash是什么?NAND Flash(闪存)是一种非易失性存储器技术,主要用于数据存储。与传统的DRAM或SRAM不同,NAND
    的头像 发表于 09-08 09:51 7705次阅读
    <b class='flag-5'>NAND</b> <b class='flag-5'>Flash</b>的基本原理和结构

    东芯半导体:强化SLC NAND Flash技术优势,拥抱可穿戴、汽车等新机会

    NOR Flash等产品广泛应用于物联网、汽车电子、可穿戴、安防监控等领域。   东芯聚焦利基型存储,构建了六大产品结构。包括,SPI NAND Flash,可提供单颗粒芯片设计的串
    的头像 发表于 09-04 15:38 5996次阅读
    东芯半导体:强化SLC <b class='flag-5'>NAND</b> <b class='flag-5'>Flash</b>技术优势,拥抱可穿戴、汽车等新机会

    对于STM32CubeMx使用FMC中的NAND FLASH里面配置这些时间有什么说明吗?

    对于STM32CubeMx使用FMC中的NAND FLASH里面配置这些时间有什么说明吗?
    发表于 07-21 07:07

    什么是Flash闪存以及STM32使用NAND Flash

    和再编程。任何flash器件的写入操作只能在空或已擦除的单元内进行,所以大多数情况下,进行写入操作之前必须先执行擦除。NAND器件执行擦除操作是十分简单的,而NOR则要求进行擦除前
    发表于 07-03 14:33

    兆易创新推出GD5F1GM9系列高速QSPI NAND Flash

    中国北京(2025 年4 月15 日) —— 业界领先的半导体器件供应商 兆易创新 GigaDevice (股票代码 603986)宣布推出GD5F1GM9系列高速QSPI NAND Flash
    发表于 04-22 10:23 1719次阅读
     兆易创新推出GD5<b class='flag-5'>F1GM9</b>系列高速QSPI <b class='flag-5'>NAND</b> <b class='flag-5'>Flash</b>