什么是Flash盘?Flash盘的结构是什么样的?
21ic 2025-07-01

Flash是大家常使用的存储之一,对于Flash,大家或多或少有所了解。上篇文章中,小编对Flash闪存的类型有所介绍。为继续增进大家对Flash的认识,本文将对Flash盘、Flash盘结构以及Flash读写操作予以介绍。如果你对本文内容具有兴趣,不妨继续往下阅读哦。


一、Flash 盘的FAT 结构

Flash 硬盘与普通的磁头、柱面式介质不一样。在开发U 盘的过程中,使用Flash 作为存储介质。它有其特定的结构特点。以16M 的三星K9F2808U0A-YCB0 Flash 为例,它有1024 个Block,每个Block 有32个Page,每个Page 有512+16=528 个字节。


二、Flash 的结构

Flash 的读写有其自身特点:1)必须以Page 为单位进行读写;2)写之前必须先擦除原有内容;3)擦除操作必须对Block 进行,即一次至少擦除一个Block 的内容。针对这种情况,将Flash 的一个Page 定为1 个扇区,将其2 个Block,64 个扇区定为一个簇,这样,簇的容量刚好为512*64=32K,满足FAT16 对簇大小的要求。FAT 分配空间的时候,是按簇来分配的,但是其给出的地址却是LBA(Logical Block Address),即它只给出一个扇区号,比如对此Flash 而言,若给出LBA 为0x40,实代表簇1的扇区1。因此需要将Logical Block Address 转换为物理地址,这样,才可以对数据进行存取操作。根据我们定义的结构,转换公式为:

Flash 的Block = Logical Block Address/0x20

Flash 的Page = Logical Block Address %0x20

实际上,如果定义每个簇为32 个扇区是最好的,因为这样物理结构和逻辑结构刚好一致。但是这也无防,因为不管Logical Block Address 给出什么值,只要按上述公式,总可以得到物理上正确的Block 和Page,再使用Flash 的读写命令读取对应的Block 和Page 就可以了,读的问题复杂一些,在后面介绍。因此簇和扇区的概念只是在BPB 中给出存储介质信息的时候告之系统就可以了,我们只要做好LBA 与物理地址间的转换就可以了。

由于做为U 盘的Flash 不要求启动,因此可以没有MBR 区,只包含DBR、FAT、DIR

和DATA 四个区。因此,Flash 的前两个Block 的内容如下:

LBA Block/Page 长度 内容说明

0 0,0 512 字节 MBR=BPB+Excutable Code+55AA(查看内容)

1~2 0,1~0,2 1024 字FAT 区(第一份FAT)节

3~4 0,3~0,4 1024字节 FAT 区备份(第二份FAT)

5~39H 目录区(在BPB 中调整目录项数,使其刚好占尽本簇)

40H~ 数据区(因目录区占尽一个簇,故数据区始于新簇首扇)

当Host 发出READ 命令后,Flash 读写操作即告开始,Host 首先读取MBR,得到有关存储介质的有关信息,诸如扇区长度、每簇扇区数以及总扇区数等内容,以便知道此盘有多大。如果读取正确,会接着读取文件分配表,借以在PC 机上的可移动盘符中显示文件目录,并可以复制、删除或是创建文件。系统自动将这些命令都转换成Read 或Write 两种命令,通过USB 的READ 或WRITE 命令块描述符来从Flash 中相应扇区读取数据,或是将特定长度的数据写入Flash 相应簇中。

三、Flash 的读写

针对Flash 读写的特点,特别是其可随机读,但无法随机写的问题,需要通过设置缓冲区来解决。在与USB Host 进行数据交换的过程中,最小的单位是扇区:512 字节。由于Flash在写之前必须先擦除,而一擦又必须擦一个Block,因此在擦除某Block 之前必须保存同一个Block 中有关扇区的数据。因此,如果每收到一个扇区的内容就进行一次擦、保存、写的操作,系统任务将十分繁重,无法及时响应USB Host 端的请求。

因此,在系统中设置32K 的缓冲区(ARM7 系统具有2M SDRAM,因此内存足够,如果在8051 平台上,则需要另外想办法),每完成一次数据传输后,记下本次要写的开始扇区和总扇区数,将本次要写的数据所涉及的扇区以外的数据从Flash 中读出来,存放在缓冲区中对应位置,然后擦除一个Block,再将缓冲区中内容一次全部重新写入Flash。

声明: 本文转载自其它媒体或授权刊载,目的在于信息传递,并不代表本站赞同其观点和对其真实性负责,如有新闻稿件和图片作品的内容、版权以及其它问题的,请联系我们及时删除。(联系我们,邮箱:evan.li@aspencore.com )
0
评论
  • 【7.24 深圳】2025国际AI+IoT生态发展大会/2025全球 MCU及嵌入式技术论坛


  • 相关技术文库
  • 单片机
  • 嵌入式
  • MCU
  • STM
  • ARM处理器的选型原则

    鉴于ARM微处理器的众多优点,随着国内外嵌入式应用领域的逐步发展,ARM微处理器必然会获得广泛的重视和应用。但是,由于ARM微处理器有多达十几种的内核结构,几十个芯片生产厂家,以及千变万化的内部功能配置组合,...

    12小时前
  • 有哪些低功耗设计方法?单片机系统低功耗设计要点介绍

    功耗,已经是一个老生常谈的话题了。对于功耗,大家多多少少有所了解。目前,很多产品的宣传里便带有低功耗噱头。为增进大家对功耗的认识,本文将基于两点介绍功耗:1.低功耗主要设计方法,2.单片机系统低功耗设计...

    12小时前
  • 8位32位MCU如何选择?如何选择合适的MCU?

    MCU,对于普通人而言,是一个高大上的存在。但是,在工业中,MCU确实常见产品。为增进大家对MCU的认识,本文将基于两点介绍MCU:1.8位MCU和32位MCU如何选择?2.如何选择合适的MCU。如果你对MCU具有兴趣,不妨继续往...

    昨天
  • ARM开发:一 ARM微处理器概述

    1.1ARM-Advanced RISC Machines ARM(Advanced RISC Machines),既可以认为是一个公司的名字,也可以认为是对一类微处理器的通称,还可以认为是一种技术的名字。 1991年ARM公司成立于英国剑桥,主要出售芯片设计技术...

    前天
  • 分析C51单片机的一些误区和注意事项

    简介:常看见初学者要求使用_at_,这是一种谬误,把C当作ASM看待了。在C中变量的定位是编译器的事情,初学者只要定义变量和变量的作 用域,编译器就把一个固定地址给这个变量。怎么取得这个变量的地址?要用指针。 1) C...

    前天
  • 51单片机几个延时程序

    简介:51单片机几个精确延时程序:在精确延时的计算当中,最容易让人忽略的是计算循环外的那部分延时,在对时间要求不高的场合,这部分对程序不会造成影响. 一. 500ms延时子程序(晶振12MHz,一个机器周期1us.) 程...

    前天
  • 总结单片机软件抗干扰的几种办法

    简介:在提高硬件系统抗干扰能力的同时,软件抗干扰以其设计灵活、节省硬件资源、可靠性好越来越受到重视。下面以MCS-51单片机系统为例,对微机系统软件抗干扰方法进行研究。 1、软件抗干扰方法的研究 在工程实践中...

    前天
  • 基于C51单片机实现汽车座椅自动控制系统的软硬件设计

    引言 随着人们生活水平的提高,对汽车座椅的舒适性要求也越来越高,要求对汽车座椅地调节能够更加简单、方便、快捷。目前,汽车座椅位置的调节多采用基于手动调节方式的机械和电动控制两种方式。汽车座椅位置的调节...

    07-02
  • MCS51单片机程序设计时堆栈的计算方法解析

    用C语言进行MCS51系列单片机程序设计是单片机开发和应用的必然趋势。Keil公司的C51编译器支持经典8051和8051派生产品的版本,通称为Cx51。应该说,Cx51是C语言在MCS51单片机上的扩展,既有C语言的共性,又有它自己...

    07-02
  • 51单片机定时器工作原理及用法

    TMOD : 控制定时器的工作方式。8个bit,高四位 bit 控制 T1,、低四位 bit 控制 T0。因为定时器有4种工作方式;TMOD = 0x00(工作方式0),TMOD = 0x01(工作方式0),TMOD = 0x02(工作方式2),TMOD = 0x03(工作方式3)。...

    07-02
  • 51单片机学习单片机之路总结

    学习单片机有一学期了,现在也由51转到STM32了。一直想对51的学习做一个总结。也希望对别人有一些启发。也给后学者提供一些建议。当然本文是我对自己学习过程的总结,若有不对的地方,还请高手指出。 我想,再看本...

    07-02
  • hot51增强型单片机开发板原理图

    功能要求: 一):绿灯25s倒计时,绿灯过度红灯有5s黄灯时间,红灯25s后直接跳绿灯。 二):按键按下模拟闯红灯输入,产生5s蜂鸣器鸣叫。 开发环境: 软件:Keil uVision4 硬件:HOT51增强型单片机开发板 程序代码:...

    07-01
下载排行榜
更多
评测报告
更多
广告