《基于单片机的U盘数据传输装置设计论文.doc》由会员分享,可在线阅读,更多相关《基于单片机的U盘数据传输装置设计论文.doc(18页珍藏版)》请在三一办公上搜索。
1、基于单片机的U盘数据传输装置 摘要:随着单片机技术的发展,各种嵌入式系统的逐渐应用于工作现场的数据采集和控制之中。USB总线技术的发展,使得数据传输和采集技术,变得简单,易携和方便使用。基于USB总线技术的USB储存设备简称U盘,它具有支持热拔热插,储存量大,耐用,和轻巧方便的特点。基于单片机技术的U盘数据采集是把单片机系统作为主机系统,再利用支持USB总线协议的U盘读写芯片或者模块来完成工业现场的数据采集或者传输。这样,便可以把U盘的大容量存储,方便易用的功能从PC机系统扩展到单片机系统中,可以方便在室外进行大量数据的采集。例如,可以将单片机系统中AD转换后采集到的数据,储存到U盘之中,以便
2、于利用计算机对数据经行整理或分析。本文主要介绍一种技术成熟U盘读写芯片CH375和以此芯片为核心的U盘读写模块,简单介绍了CH375芯片的构造和特点,以及U盘模块的应用特点。再次,介绍了串口版U盘模块的应用,并设计了串口模块和单片机之间的通信的应用方式,并附有模块和单片机之间采用RS232电平进行通信的连接电路图。同时,还简单的介绍了,U盘读写之中需要注意的几个协议等。最后附录中的程序提供了一个能够实现单片机以字节的方式对U盘的读和写的程序。关键词:单片机 U盘 USB2.0 U盘模块 串口 通信 RS232接口 CH375 电平一, 引言半导体技术的发展带来计算机向微型化发展的革命,同时随着
3、计算机技术的快速发展,USB(Universal Serial Bus)存储设备的使用已经非常普遍,USB 用于将适用USB 的外围设备(device)连接到主机(host),实现二者之间数据传输的外部总线结构;是一种快速、灵活的总线接口。它最大的特点是易于使用,携带方便,主要是用在中速,低速的外设。随着USB 规范的完善和成熟,USB 外设的种类不断丰富,应用领域也不断扩大。在传统的应用中,主要是PC 扮演着主机的角色。根据USB 的规范,可以看到在USB 的拓朴结构中居于核心地位的是主机,每一次的数据传输都必须由主机发起和控制。但是随着单片机产品应用领域的日益增长,USB 外设的应用范围也
4、随之扩大,为此在单片机系统中实现对USB外设控制也变得日益迫切。因此在一些需要转存数据的设备,仪器上使用USB移动存储设备接口的芯片便相继产生了,CH375 就是其中之一,它是一个USB 总线的通用接口芯片,支持HOST 主机方式和SLAVE 设备方式。如今的USB 就象当日的RS232,最终发展必是业界的主流外设接口技术。USB 有着其它接口不可替代的优势。随着USB 技术的发展,计算机的移动存储介质普遍采用U 盘或移动硬盘。如今,USB 技术已经越来越普及和成熟,低成本、高稳定性、较高的数据传输速率和即插即用的方便性,使其备受硬件厂商的青睐。随着数据采集和单片机用户对移动存储的需求越来越大
5、,具有USB 接口的存储设备以其优异的性价比和灵活性常用来进行数据的存储和交换,所以在单片机系统中实现对优盘或移动硬盘的直接读写是非常有价值的。二, 研究的意义 USB是近年发展起来的一种快速、灵活的总线接口。它最大的特点是易于使用、可热插拔、接口连接灵活,并且能够提供外设电源,在嵌人式系统及智能仪表中得到广泛的应用。而51系列单片机以其优越的性能、成熟的技术、高性价比被广应用于测控仪器等自动化领域。因此用51系列单片机实现USB主机接口,进而实现对USB外设的控制,对提高整个系统的数据存储、数据传输、设备控制等性能都有很大的作用。根据我们的调查和了解,我们发现,随着Flash Memory非
6、易失存储技术的发展,基于USB接口的闪存即U盘现已得到广泛应用。从理论上讲,以U盘作为便携式采集存储系统的存储载体完全能够满足长时间采集海量数据的要求。但目前所面临的问题是,U盘主要应用于PC机系统中。以单片机等微处理器为核心的嵌入式系统的应用中,尚缺少与U盘的直接接口技术。因此将单片机技术与U盘存储技术两者结合起来,利用单片机直接读写U盘,并通过总线方式与嵌入式系统的其它部分实现命令和数据的通信。采用单片机直接控制读写U盘,关键在于USB-HOST技术的实现,即单片机作为USB主机系统。USB系统包括两部分:USB主机和USB外设,它们组合在一起就构成了完整的USB系统。USB的拓扑结构中居
7、于核心地位的是Host(也称为主机),任何一次USB的数据传输都必须由主机来发起和控制,所有的USB外设都只能和主机建立连接,任何两个外设之间或是两个主机之间无法直接通信。鉴于复杂的USB协议,我们觉得可以采用USB读写模块,这样只要将USB读写模块嵌入到用户单片机系统中,就可以通过单片机的串口与USB读写模块之间的通信,进而读写U盘里面的数据,还可以方便的利用U盘储存海量的AD转换后的数据等。三 , USB总线接口芯片CH3753.1 概述: CH375 是一个USB总线的通用接口芯片,支持USB-HOST主机方式和USB-DEVICE/SLAVE设备方式。在本地端,CH375具有8位数据总
8、线和读、写、片选控制线以及中断输出,可以方便地挂接到单片机/DSP/MCU/MPU等控制器的系统总线上。在USB主机方式下,CH375还提供了串行通讯方式,通过串行输入、串行输出和中断输出与单片机/DSP/MCU/MPU 等相连接。CH375的USB 主机方式支持常用的USB 全速设备,外部单片机可以通过CH375 按照相应的USB 协议与USB 设备通讯。CH375 还内置了处理Mass-Storage 海量存储设备的专用通讯协议的固件,外部单片机可以直接以扇区为基本单位读写常用的USB 存储设备(包括USB 硬盘/USB闪存盘/U 盘)3.2 特点 1)全速USB-HOST 主机接口,兼容
9、USB V2.0,外围元器件只需要晶体和电容。 2)全速设备接口,完全兼容CH372 芯片,支持动态切换主机与设备方式。 3)主机端点输入和输出缓冲区各64 字节,支持常用的12Mbps 全速USB 设备。 4)支持USB 设备的控制传输、批量传输、中断传输。 5)自动检测USB 设备的连接和断开,提供设备连接和断开的事件通知。 6)内置控制传输的协议处理器,简化常用的控制传输。 7) 内置固件处理海量存储设备的专用通讯协议,支持Bulk-Only传输协议和SCSI、UFI、RBC 或等效命令集的USB 存储设备(包括USB 硬盘/USB 闪存盘/U 盘)。 8)通过U 盘文件级子程序库实现单
10、片机读写USB 存储设备中的文件。 9)并行接口包含8 位数据总线,4 线控制:读选通、写选通、片选输入、中断输出。 10)串行接口包含串行输入、串行输出、中断输出,支持通讯波特率动态调整。 11)支持5V 电源电压和3.3V 电源电压,CH375A 芯片还支持低功耗模式。 12)采用SOP-28 封装,可以提供SOP28 到DIP28 的转换板。 图1 CH375各引脚说明3.3 功能说明CH375 芯片可以工作于USB-HOST 主机方式或者USB 设备方式。CH375的USB 主机方式支持并行接口和串行接口。在USB主机方式下,CH375支持各种常用的USB全速设备,外部单片机需要编写固
11、件程序按照相应的USB协议与USB 设备通讯。但是对于USB存储设备,CH375 内置了相关协议,通常情况下,外部单片机不需要编写固件程序,就可以直接通讯。CH375 芯片在本地端提供了通用的被动并行接口和点对点的串行接口。图2 CH375芯片的电器参数3.4 CH375工作于串口模式下 串行接口只能用于USB 主机方式,CH375 芯片的USB 设备方式不支持串口。串口信号线包括:串行数据输入引脚RXD、串行数据输出引脚TXD、中断输出引脚INT#。通过串行接口,CH375 可以用最少的连线与单片机、DSP、MCU 进行较远距离的点对点连接。CH375芯片的RXD 和TXD可以分别连接到单片
12、机的串行数据输出引脚和串行数据输入引脚。INT#输出的中断请求是低电平有效,用于通知单片机。CH375 的串行数据格式是1个起始位、9个数据位、1个停止位,其中前8个数据位是一个字节数据,最后1个数据位是命令标志位。第9位为0时,前8位的数据被写入CH375芯片中,第9位为1时,前8位被作为命令码写入CH375芯片中。CH375的串行通讯波特率默认是9600bps,单片机可以随时通过SET_BAUDRATE 命令选择合适的通讯波特率。3.5 其它功能简介 在CH375 芯片的复位期间,TXD引脚用于选择通讯接口。如果CH375 在复位期间检测到TXD引脚为低电平则启用并行接口,否则启用串行接口
13、。如果启用串行接口,那么复位完成后TXD引脚将用于串行数据输出,并且CH375 芯片只能工作于USB 主机方式。 CH375芯片的ACT#引脚用于状态指示。在内置固件的USB设备方式下,当USB 设备尚未配置或者取消配置后,该引脚输出高电平;当USB 设备配置完成后,该引脚输出低电平。对于CH375A 芯片,在USB主机方式下,当USB 设备断开后,该引脚输出高电平;当USB设备连接后,该引脚输出低电平。CH375 的ACT#引脚可以外接串了限流电阻的发光二级管LED,用于指示相关的状态。CH375 芯片的UD+和UD-引脚是USB 信号线,工作于USB 设备方式时,应该直接连接到USB总线上
14、;工作于USB 主机方式时,可以直接连接到USB设备。如果为了芯片安全而串接保险电阻或者电感,那么交直流等效串联电阻应该在5之内。CH375芯片内置了电源上电复位电路,一般情况下,不需要外部提供复位。RSTI 引脚用于从外部输入异步复位信号;当RSTI 引脚为高电平时,CH375芯片被复位;当RSTI 引脚恢复为低电平后,CH375会继续延时复位20mS 左右,然后进入正常工作状态。为了在电源上电期间可靠复位并且减少外部干扰,可以在RSTI引脚与VCC 之间跨接一个容量为0.47uF 左右的电容。RST引脚和RST#引脚是复位状态输出引脚,分别是高电平有效和低电平有效;当CH375电源上电复位
15、或者被外部强制复位以及复位延时期间,RST 引脚和RST#引脚分别输出高电平和低电平;CH375复位完成后,RST 引脚和RST#引脚分别恢复到低电平和高电平。RST 和RST#引脚可以用于向外部单片机提供上电复位信号。 CH375芯片正常工作时需要外部为其提供12MHz 的时钟信号。一般情况下,时钟信号由CH375内置的反相器通过晶体稳频振荡产生。外围电路只需要在XI 和XO 引脚之间连接一个标称频率为12MHz的晶体,并且分别为XI 和XO 引脚对地连接一个高频振荡电容。如果从外部直接输入12MHz时钟信号,那么应该从XI 引脚输入,而XO 引脚悬空。CH375芯片支持5V电源电压或者3.
16、3V 电源电压。当使用5V 工作电压时,CH375 芯片的VCC引脚输入外部5V 电源,并且V3 引脚应该外接容量为0.01uF 左右的电源退耦电容。当使用3.3V 工作电压时,CH375 芯片的V3引脚应该与VCC引脚相连接,同时输入外部的3.3V 电源,并且与CH375 芯片相连接的其它电路的工作电压不能超过3.3V。3.6 内部结构 CH375 芯片内部集成了PLL 倍频器、主从USB 接口SIE、数据缓冲区、被动并行接口、异步串行接口、命令解释器、控制传输的协议处理器、通用的固件程序等。PLL 倍频器用于将外部输入的12MHz 时钟倍频到48MHz,作为USB 接口SIE 时钟。 主从
17、USB 接口SIE是USB主机方式和USB设备方式的一体式SIE,用于完成物理的USB数据接收和发送,自动处理位跟踪和同步、NRZI编码和解码、位填充、并行数据与串行数据之间的转换、CRC数据校验、事务握手、出错重试、USB 总线状态检测等。 数据缓冲区用于缓冲USB 接口SIE 收发的数据。 被动并行接口用于与外部单片机/DSP/MCU 交换数据。 异步串行接口用于代替被动并行接口与外部单片机/DSP/MCU 交换数据。 命令解释器用于分析并执行外部单片机/DSP/MCU 提交的各种命令。 控制传输的协议处理器用于自动处理常用的控制传输的多个阶段,简化外部固件编程。 通用的固件程序包含两组:
18、一组用于USB 设备方式,自动处理USB默认端点0 的各种标准事务等;另一组用于USB 主机方式,自动处理Mass-Storage 海量存储设备的专用通讯协议。 CH375 芯片内部具有7 个物理端点: 端点0 是默认端点,支持上传和下传,上传和下传缓冲区各是8 个字节; 端点1包括上传端点和下传端点,上传和下传缓冲区各是8个字节,上传端点的端点号是81H,下传端点的端点号是01H; 端点2 包括上传端点和下传端点,上传和下传缓冲区各是64 个字节,上传端点的端点号是82H,下传端点的端点号是02H; 主机端点包括输出端点和输入端点,输出和输入缓冲区各是64 个字节,主机端点与端点2合用同一组
19、缓冲区,主机端点的输出缓冲区就是端点2 的上传缓冲区,主机端点的输入缓冲区就是端点2 的下传缓冲区。 CH375 的端点0、1、2 只用于USB 设备方式,在USB 主机方式下只需要用到主机端点。在USB 主机方式下,CH375 支持各种常用的USB 全速设备。USB 设备的端点号可以是015,两个方向最多支持31 个端点,USB 设备的包长度可以是064 字节。 内置固件可以处理Mass-Storage 海量存储设备的通讯协议,要求USB 存储设备支持Bulk-Only传输协议,支持SCSI、UFI、RBC或者等效的命令集,并且数据端点的最大包长度是64 字节,但是默认端点0 的最大包长度可
20、以是8、16、32 或者64 字节。如果USB 存储设备不符合上述要求,则需要外部单片机通过控制传输以及ISSUE_TOKEN 命令或者ISSUE_TKN_X命令自行处理相关通讯协议。图3 CH375芯片内部中断逻辑图3.7 本地端的单片机软件 CH375芯片占用两个地址位,当A0 引脚为高电平时选择命令端口,可以写入命令;当A0引脚为低电平时选择数据端口,可以读写数据。单片机通过8 位并口对CH375 芯片进行读写,所有操作都是由一个命令码、若干个输入数据和若干个输出数据组成,部分命令不需要输入数据,部分命令没有输出数据。命令操作步骤如下:、在A0=1 时向命令端口写入命令代码;、如果该命令
21、具有输入数据,则在A0=0 时依次写入输入数据,每次一个字节;、如果该命令具有输出数据,则在A0=0 时依次读取输出数据,每次一个字节;、命令完成,可以暂停或者转到继续执行下一个命令。 CH375芯片专门用于处理USB 通讯,在检测到USB 总线的状态变化时或者命令执行完成后,CH375以中断方式通知单片机进行处理。3.8 单片机读写U盘文件 图4 单片机读写U 盘文件 一般情况下,单片机或嵌入式系统处理USB 存储设备的文件系统需要实现上图左边的4个层次,右边是USB 存储设备的内部结构层次。由于CH375 不仅是一个通用的USB-HOST 硬件接口芯片,还内置了相关的固件程序,包含了上图左
22、边的3 个层次(标为灰色部分),所以实际的单片机程序只需要处理FAT 文件系统层,并且即使这一层也可以由CH375 的U 盘文件级子程序库实现。 如果不需要处理文件系统,也就是不处理上图左边的最顶层,那么CH375 直接提供了数据块的读写接口,以512字节的物理扇区为基本读写单位,从而将USB存储设备简化为一种外部数据存储器,单片机可以自由读写USB 存储设备中的数据,也可以自由定义其数据结构。由于计算机将USB 存储设备组织为文件系统,为了方便单片机通过USB移动存储设备与计算机之间交换数据,单片机也可以将USB 存储设备组织为文件系统,也就是处理上图左边的最顶层。 CH375以C语言子程序
23、库提供了USB存储设备的文件级接口,这些应用层接口API包含了常用的文件级操作,可以移植并嵌入到各种常用的单片机程序中。 CH375 的U 盘文件级子程序库具有以下特性:支持常用的FAT12、FAT16 和FAT32 文件系统,磁盘容量可达100GB 以上,支持多级子目录,支持8.3 格式的大写字母和中文文件名,可以支持小写字母或者长文件名,支持文件打开、新建、删除、读写以及搜索等。 CH375 的文件级子程序库需要大约600 字节的随机存储器RAM 作为缓冲区。以普通的MCS-51 单片机为例,文件系统的全部子程序有4KB 到8KB 代码,并且需要大约80 字节的内部RAM 和512 字节的
24、外部RAM 作为缓冲区。 四,串口版U盘读写模块的说明 模块具有两个外部接口:P1 是USB 插座,可以直接插入U 盘或者通过USB 延长线连接U盘,当进行程序升级或者重新配置时应该通过USB 对连线连接计算机的USB 端口;P2 是16 脚的双排针或者插座,用于连接单片机系统。图5 串口版U盘模块正反外观图 在串口方式下,单片机与模块的P2 端口相连接,只需要使用高8 脚(第9 脚到第16脚),其余引脚可以不连接。模块可以通过串行输入SIN、串行输出SOUT 连接到单片机的异步串口,除此之外,启动输入STA#还应该连接到单片机的一个I/O 引脚,而中断输出INT#可以根据需要决定是否连接到单
25、片机的中断引脚。 模块的串口是1 位起始位、8 位数据位、1位停止位的异步串口,串口的通讯波特率可以在功能配置时设定,如果未设定那么默认是4800bps(与晶体X2 的频率有关),单片机系统可以根据需要通过CMD_BaudRate 命令设定更高的波特率。如果在功能配置时选择检查串口超时,那么在通过串口输入命令包时,模块会检查串口数据输入超时,如果连续两个数据字节之间的间隔大于串口输入超时时间,则模块将放弃该命令包。 4+1 线串口是指GND、SIN、SOUT、STA#和可选的INT#,P2 引脚定义如下:图6 模块引脚定义图 为了节约单片机的I/O 引脚,模块还支持三线制串口,在这种方式下,单
26、片机与模块之间只需要连接SIN 和SOUT 两根信号线及公共地线,单片机通过串口发送两个同步码字节(57H、ABH)代替原来向模块的STA#引脚提供的启动信号,实现与模块的命令同步。在通过串口输入两个同步码字节时,模块会检查串口数据输入超时,如果连续两个数据字节之间的间隔大于串口输入超时时间,则模块将放弃该同步码及命令包。图7 TTL电平转RS232电平经行通信的串口模块电路图 图8 串口版模块与单片机之间的电路连接图图9 单片机系统串口与RS232借口连接电路图图10 单片机系统和模块之间连接的实物图六,软件设计 为了使上位PC 机能够直接读取该读写器写入U 盘的数据,数据存储按照FAT32
27、 文件管理方式存储,其中涉及USB 和UFI 协议以及FAT32 文件存储格式。6.1 USB协议 USB(通用串行总线)用于将USB 接口的外围设备(device)连接到主机(host),实现二者之间数据传输的外部总线结构,是一种快速、灵活的总线接口,USB 的传输类型有控制(control)、批量(bulk)、中断(interrupt)和同步(synchronous)传输4 种,它最大的特点是易于使用,即插即用,主要是用在中速和低速的外设。 控制数据用于在USB 接入总线时对其进行配置,其他的驱动软件可以根据具体的应用来选择使用控制传输,这种数据传输不会丢失数据。 典型的批量数据包括象使用
28、打印机或扫描仪时所出现的大数据量的数据,这种批量数据是连续的,通过在硬件中实现差错检测功能,并且有选择地进行一定的应进重试操作,可以在硬件层次上保证数据的可靠交换。 由设备自发产生的数据传输是中断数据传输,这类数据传输可以由USB 设备在任意时刻发起,而且USB 总线以不低于设备说明的速率进行传输。 同步数据在产生、传送和处理过程中是连续的和实时的,在稳定的同步数据发送和接收速率中包含了相应的时钟信息,为了保持定时关系,同步数据必须按照接收的速率进行传输。6.2 BULK_ONLY 和UFI 协议 USB 设备分为5 大类,即显示器、通信设备、音频设备、人机输入和海量存储。通常所用的U 盘、移
29、动硬盘均属于海量存储类。海量存储类的规范中包括4 个独立的子规范,即CBI 传输、Bulk-Only 传输、ATA 命令块、UFI 命令规范。前两个协议定义了数据/命令/状态在USB 总线上的传输方法,Bulk-Only 传输协议仅仅使用Bulk 端点传送数据/命令/状态,CBI 传输协议则使用Control/bulk/interrupt 三种类型的端点进行数据/命令/状态的传送。后两个协议定义了存储介质的操作命令,ATA 协议用于硬盘,UFI 协议则针对USB 移动存储,U盘读写器的设计遵循Bulk-Only 传输协议和UFI 命令规范。UFI 命令块规范是针对USB 移动存储而制定的,它总
30、共定义了19 个12 字节长度的操作命令。 Bulk-Only 事务以主机向设备发送CBW(Command Block Warp)包,并以建立相应的数据传输开始的,设备接收到CBW 包,检查并解释它,试图满足主机的要求,并通过CSW(Command State Wrap)包向主机返回状态信息。 CBW 是主机通过Bulk-Out 端点向设备发送的命令块包,在CBW 中使用方向位和数据传输长度域指明期待的传输,CBW 必须起始于包边界,并且必须以31 字节的短包传输结束,相继的数据包和CSW 包必须开始于一个新的包边界,所有的CBW 包必须按低字节在前的次序传输。CBW包结构如图所示,各域含义如
31、下: 图10 CBW包结构1)命令块包标识。CBW 包标记,表明这是一个CBW 包,这个域的值为43425355H。2)命令块标记。当设备返回相应的CSW 包时,必须使命令状态标记域的值与此值相同。3)数据传输长度。指明命令执行期间在Bulk 端点上传数据的字节长度,如果这个域的值是0,则在CBW 和CSW 之间设备和主机不传输任何数据,并且设备将忽略在命令块标旗域中的方向位的值。4)命令块标旗。方向位规定了Bulk 端点数据传输的方向,其他位预留。5)逻辑单元号。指定命令块被发送到的逻辑单元号,如果设备不支持多个逻辑单元号,则主机将这个域设置为0。6)CBWCB 长度,定义了CBWCB 的有
32、效长度,合法值为1-16。7)CBWCB。由设备执行的命令,由设备解释。CSW 向主机表明来自于CBW 包的命令块的执行状态。设备收到CBW 包解析处理后将通过Bulk-In 端点发送一个CSW 包。CSW 开始于包边界,并以13 字节的短包结束,结构如图所示,各域含义如下: 图11 命令状态包结构1)命令状态包标识。CSW 包的标记,表明这是一个CSW 包,这个域的值为53425355H。2)命令状态标记。次域的值域CBW 包的命令块标记相同。3)数据残余。实际数据传输量与CBW 包中规定的数据传输长度的差值。4)命令执行状态,表明命令成功或失败信息,如果命令执行成功,则设备将设置此域的值为
33、0,非0 值;则表明失败或错误。 UFI 是针对USB 移动存储而制定的命令块协议,它规定了主机和设备进行信息交换所使用的命令块、数据和状态信息,Bulk-Only 传输协议定义了传输这些信息的方法,其中UFI 命令块是封装在CBW 包中的CBWCB,设备通过读取CBWCB 确定具体要执行何种操作命令(如读命令),如何完成这个命令(如从闪存的哪个地址读,需要读取的长度),设备将命令的执行状态封装成CSW 返回给主机。 UFI 用于大多数命令的12 字节命令块的描述,结构如图4 所示,其中各参数意义如下:1)操作命令代码。指明所需要执行的操作命令;2)逻辑单元号。指明命令将发送到哪个逻辑单元,如
34、果设备只有一个逻辑单元,则此域的值为0。3)逻辑块地址。命令操作的起始地址。4)传输长度,指明请求传输的数据量,通常以扇区作单位,但是有几个命令是以字节作单位的,对于这些命令,传输长度域可以以不同的名字标识,若此域的值为0,则表面没有数据需要传输。5)参数列表长度,用于指定发送到设备的字节数,这个域典型的应用于发送到设备的参数命令块(如模式参数、诊断参数等),若此域的值为0,则表面没有数据需要传输。6)分配长度,指明主机已经分配的用于返回数据的最大字节长度,若此值为0,则表明没有数据需要传输。6.3 FAT32 FAT 是Microsoft 较早推出的文件系统,具有高度的兼容性,目前仍然广泛应
35、用于个人电脑尤其是移动存储设备中,FAT 由引导扇区、FAT1 表、FAT2 表、目录和文件区组成(其中FAT2 表是FAT1 表的备份)。磁盘的管理是以扇区为单位的,而移动存储设备则是以块为单位的,FAT 将块映射成扇区,原理相同,FAT 将磁盘空间以一定数目的扇区为单位进行划分,这样的单位成为簇。通常情况下,每扇区512 字节的原则是不变的,簇的大小一般是2n(n 为整数)个扇区的大小。所以以簇为单位而不以扇区为单位进行磁盘的分配,是因为当区分容量较大时,采用512 字节的扇区管理,会增加FAT 表的项数和大文件存取的消耗,使文件系统效率不高。 引导扇区DBR(DOS Boot Recor
36、d)通常占用分区的第0 扇区,共512 字节,FAT 表紧随其后。DBR 的第一部分是一个x86 跳转指令、厂商标志和操作系统版本号,接下来的从偏移0x0B 开始的是一段描述能够使可执行引导代码找到相关参数的消息,通常称之为BPB。最后是引导程序代码以及扇区结束标志。BPB 中记录了扇区大小、簇的扇区数、保留扇区数、FAT 表大小和文件系统类型等重要参数,用于文件的索引和定位计算。7.4 软件系统模块 USB 读写器软件由主模块、USB 模块、BULK 模块、FAT 模块和中断处理模块组成。各模块之间相互协调调用,共同完成对U 盘文件的读写创建。 USB 模块负责检测USB 设备的移入/移出,
37、对插入的设备进行枚举,分配设备地址端点号,配置设备接口端点描述符,建立BULK_ONLY 输入/输出通道,BULK 模块则在已建立的BULK_ONLY 输入/输出通道发送CBW 数据包,并接收CSW 数据包,通过CBW 中嵌入的CBWCB 信息确定对U 盘读/写操作的扇区位置和大小,FAT 模块主要完成簇和扇区间的索引定位,即在U 盘内寻址,利用BPB 中的参数计算给定扇区的所在簇以及进入休眠状态,等待外部中断唤醒。 中断处理模块是在中断唤醒后根据中断类型进入不同功能子模块的,也是整个软件系统的核心部分。中断模块接收到串口或并口数据后,根据内部命令字要求进行解析。 串口或并口数据接收流程如图所
38、示。 图12 UFI结构 图13 命令与数据字结构七,总结 此次科研立项是我们从大学生活重要的一步。从最初的选题,开题到查资料、设计电路,编写程序直到完成设计。其间,查找资料,老师指导,与同学交流,反复修改电路和程序,每一个过程都是对自己能力的一次检验和充实。 通过这次实践,我了解了单片机读写U 盘的用途及工作原理,熟悉了单片机读写U 盘的设计步骤,锻炼了工程设计实践能力,培养了自己独立设计能力。此次科研立项是对我专业知识和专业基础知识一次实际检验和巩固,同时也是我为未来的单片机和嵌入式开发与应用的的一次热身。 通过这次科研立项收获很多,比如学会了查找相关资料相关标准,分析数据,提高了自己的电
39、路设计和程序设计的能力,懂得了许多经验公式的获得是前人不懈努力的结果。同时,仍有很多课题需要后来人去努力去完善。 但是这次科研立项也暴露出自己专业基础的很多不足之处。比如缺乏综合应用专业知识的能力,对集成芯片的不了解等等。这次科研立项是对自己到现在为止大学所学的一次大检阅,使我明白自己知识还很浅薄,虽然大学生活已经过了一大半,但是自己的求学之路还很长,以后更应该在有限的大学生活学习中,努力的学习好专业文化知识和动手能力,同时也要提高自己各方面的综合素质,努力使自己成为一个对社会有所贡献的人。参考文献:【1】基于单片机的智能系统设计与实现 沈红卫著,电子工业出版社【2】单片机技术应用朱运利著,机
40、械工业出版社【3】MCS-51 单片机开发与应用指南孙永浩著 黑龙江科学技术出版社【4】EZ-USB FX2单片机原理,编程及应用钱峰著,北京航空航天大学出版社【5】CH375中文技术手册【6】串口版U盘读写模块中文技术手册附录:以下程序可以演示单片机以字节的方式读写U盘,该程序实现的功能是:打开U盘中的一个文件EXAMBYTE.TXT,再新建一个文件NEWFILE.TXT,在NEWFILE.TXT文件中写入“Note:这个程序是以字节为单位进行U盘文件读写的示例程序,首先从原文件中读出前20个字符,然后写到本说明的后面:”然后从文件EXAMBYTE.TXT中读取前20字节的数据,写入文件NE
41、WFILE.TXT中。即可实现单片机以字节对U盘读和写的功能。#include #include #include #include #define MAX_PATH_LEN32#include unsigned charTempLength;unsigned char idataTempBuffer20;CMD_PARAMidatamCmdParam;sbitLED_OUT=P04;sbit p2_0=P20;voidmDelaymS( unsigned char delay )unsigned chari, j, c;for ( i = delay; i != 0; i - ) for (
42、 j = 200; j != 0; j - ) c += 3; for ( j = 200; j != 0; j - ) c += 3; voidmSendByte( unsigned char c )/* 发送一个字节数据给CH375模块 */TI = 0;SBUF = c;while ( TI = 0 );unsigned charmRecvByte( )/* 从CH375模块接收一个字节数据 */unsigned charc; while ( RI = 0 );c = SBUF; RI = 0;return( c );unsigned charExecCommand( unsigned
43、char cmd, unsigned char len )/* 命令函数 */unsigned chari, j, status; mSendByte( SER_SYNC_CODE1 ); mSendByte( SER_SYNC_CODE2 ); mSendByte( cmd ); mSendByte( len ); RI = 0; if ( len ) for ( i = 0; i != len; i + ) mSendByte( mCmdParam.Other.mBuffer i ); while ( 1 ) status = mRecvByte(); if ( status = ERR_
44、SUCCESS ) i = mRecvByte( ); LED_OUT = 0; if ( i ) j = 0; do mCmdParam.Other.mBuffer j = mRecvByte( ); j +; while ( - i ); break; else if ( status = USB_INT_DISK_READ | status = USB_INT_DISK_WRITE | status = USB_INT_DISK_RETRY ) break; else if ( status = ERR_DISK_DISCON | status = ERR_USB_CONNECT ) m
45、DelaymS( 100 ); break; return( status );voidmStopIfError( unsigned char iError )/*错误检测函数*/待添加的隐藏文字内容3 unsigned charled; if ( iError = ERR_SUCCESS ) return; led=0; while ( 1 ) LED_OUT = led&1; /* LED闪烁 */mDelaymS( 100 );led=1;main( ) unsigned chari; unsigned shortcount;unsigned char*pStr; mDelaymS( 500 );p2_0=0;LED_OUT = 0; mDelaymS( 100 ); mDelaymS( 100 );LE