当前位置:首页 > 智能硬件 > 智能硬件
[导读]阐述一个基于ARM7的U盘设计;详细描述基于LPC2132、USB接口芯片PDIUSBDl2和Flash ROM的硬件系统设计。软件设计主要包括D12驱动、Mass Storage类协议实现和Flash存储器的读写控制等。

摘要 阐述一个基于ARM7的U盘设计;详细描述基于LPC2132、USB接口芯片PDIUSBDl2和Flash ROM的硬件系统设计。软件设计主要包括D12驱动、Mass Storage类协议实现和Flash存储器的读写控制等。
关键词 LPC21 32 USB Mass Storage类协议 U盘


引 言
   
USB移动存储技术(U盘)把USB接口技术与Flash存储器技术结合在一起,构成了一种快速、大容量、方便的新型数据交换系统,主要构成有主控制器(MCU)、USB接口芯片和F1ash存储器。主控制器(MCU)是系统的核心,负责控制各种外围设备、实现各种算法、协调与主机通信;USB接口芯片负责USB通信;Flash(闪烁存储器)用来存储数据,它决定了U盘的容量。

1 硬件系统设计
    U盘设计结构框图如图1所示。使用Philips公司的ARM7芯片LPC2132,控制Philips的USBl.1接口芯片PDI-USBDl2,处理PMC公司的128 KB串行F1ash存储器作为数据存储设备实现U盘。

(1)ARM处理器
    LPC2132是基于一个支持实时仿真和跟踪的16/32位ARM7TDMI-S CPU,并带有64 KB嵌入的高速Flash存储器。LPC2132的实时仿真和跟踪功能方便了代码的调试,降低了开发成本。
(2) PDIUSB012
    PDIUSBDl2(简称为“D12”)是一款性价比很高的USB器件;通常用于微控制器系统中实现与微控制器进行通信的高速通用并行接口;支持本地的DMA传输。PDIUSBDl2所具有的低挂起功耗连同LazyClock输出可以满足使用ACPI、OnNOW和USB电源管理的要求。低功耗可以应用于使用USB总线供电的外设。
(3)Flash存储器
    存储器选用PMC公司的Pm25LV010。适合低功耗和低电压下工作的应用场合;具有完备的数据保护功能。通过设置芯片的状态寄存器,可以将存储空间的高1/4、高1/2或整片写保护。写使能和写禁止指令进一步保护数据。另外还提供WP引脚用于硬件数据保护,以防止对状态寄存器的意外修改。
    U盘电路原理如图2所示。

2 软件设计
   
软件设计主要包括D12驱动、Mass Storage类协议和Flash存储器的读/写控制。
2.1 D12驱动的实现
    在USB设备插入主机之前,主机对这个USB设备的情况一无所知,无法建立起通信;但USB协议规定了一些最基本的准则,如每个设备的端点0都是可用的,属于控制端点。有了这个基本的沟通途径,主机就开始通过端点0向设备提出一些问题,这些问题是有关设备基本情况的。这些基本情况可以反映usB设备所属的类别及子类,反映配置情况、接口情况和端点情况;一旦得知了这些信息,主机就大体了解了这个设备是个什么样的设备,按照USB协议中的相应规定,就逐步建立起了一条介于设备之间的高速数据通道,用于数据的传输。主机向设备提出的这些问题实际上就是USB协议中规定的各种标准请求,设备必须对这些问题进行回答;而回答的方式就是向主机传送相应的描述符,即设备描述符、配置描述符、接口描述符、端点描述符。
    为了使软件可移植性强、易维护,采用分层的方法编写PDIUSBDl2的驱动程序。USB驱动程序分层结构如表1所列。

    ①硬件提取层(D12HAL.c)包含最底层的函数。
    ②D12命令接口(D12CI.c)实现PDIUSBDl2的命令接口以简化器件的编程。该层的甬数及其功能如下:
    ◇读取芯片ID号,uintl6 D12_ReadChipID(void);
    ◇没置地址/使能,void D12_SetAddressEnable(UINT8bAddress,UINT8 bEnable);
    ◇设置端点使能,void D12_SetEndpointEnable(UINT8 bEnablc);
    ◇设置模式,void D12_SetMode(uint8 bConfig,uint8bClkDiv)。
    ③协议层(Chap_9.c)处理标准的USB设备请求,以及特殊的厂商请求,如DMA等。USB主机通过标准USB设备请求,可设定和获取USB设备的有关信息,完成USB设备的枚举。
    所有的请求都是通过端点0接收和发送SETUP包来完成的。接收主机SETUP包的函数为ep0_rxdone(),所有SETUP包都由函数control_handler()来处理,发送SETUP包的函数为ep0_txdone()。SETUP包的接收和发送通过控制传输结构仝局变量CONTROL_XFER ControlData来控制,它实现了以上3个函数之间的通信。


    上述几个函数及ControlData变量之问的关系如图3所示。

    ④应用层(D12Driver.c)实现PDIUSBD12的所有功能。USB设备控制驱动、USB接口控制驱动和协议层都在应用层的控制之中。应用层要实现的仟务包括:
    ◆初始化PDIUSBDl2。包括初始化PDIUSBD12的硬件连接、复位PDIUSBDl2、配置PDIUSBD12的中断服务程序地址、初始化应用层相关的全局变量。
    ◆编写PDIUSBD12中断服务程序。PDIUSBD12几乎所有功能都是通过PDIUSBDl2中断服务程序来完成的,因此中断服务程序是应用层的核心部分,也是本驱动程序的核心部分。它要完成以下任务:
    ◇控制端点数据接收与发送中断服务程序,负责处理控制传输的有关工作;
    ◇端点1和端点2数据接收与发送中断服务程序;
    ◇USB总线挂起、复位、DMA结束中断服务程序。
    ◆用户读写端点1和端点2的API函数。
    ◆传输控制处理任务。该任务用于处理枚举、标准任务请求、厂商请求等传输控制。
2.2 Mass Storage类协议的实现
    完整的Mass Storage类协议需要实现如下儿部分:在枚举时,提供Mass Storage类协议描述符;实现BulkOnly批量传输协议;实现SCSI命令集。
2.2.1 Mass Storage类协议描述符

    USB采用设备类的方式对设备进行管理。要让主机识别设备,设备就必须提供正确的描述符:
    ◇设备描述符;
    ◇配置描述符;
    ◇接口描述符;
    ◇端点描述符。
2.2.2 Bulk-Only批量传输协议实现
    Bulk-Only协议包括两部分:类特定请求命令和Bulk-Only传输。
(1)类特定请求命令
    ①批量传输的大容量存储器复位。要发送批量传输的大容量存储器复位请求,主机将在默认管道发送一个设备请求:
    ◇bmRequestType——类、接口、主机到设备;
    ◇bRequest字段设置为255(FFh);
    ◇wValue字段设置为0;
    ◇wIndex字段设置为接口编号;
    ◇wLength字段设置为O。
    批量传输的大容量存储器复位请求如下:

   
    ②获取最大逻辑单元号(专用类清求)。Get MaxLUN设备请求用于确定设备支持的逻辑单元编号。设备的逻辑单元编号可以从LUN为O到LUN的最大值15(Fh)。
    要发送Get Max LUN设备请求,主机应在以下默认管道发送一个设备请求:
    ◇bmRequestType——类、接口、设备到主机;
    ◇bRequest范围设置为254(FEh);
    ◇wValue字段设置为0;
    ◇wIndex字段设置为接口编号;
    ◇wLength字段设置为1。
   获得最大逻辑单元字如下:

   
    设备应返回1字节包含设备支持的最大逻辑单元数。例如,如果设备支持4个LUN,则LUN的编号应从0~3,则返回值为3。如果设备没有相关的LUN,则返回值为0。主机不应向一个不存在的LUN发送命令块包(CBW)。
    不支持多LUN的设备会返回STALL。
(2)Bulk—Only传输
    Bulk—Only传输协议没有使用中断和控制端点,仅使用Bulk批量端点来进行命令块、数据和命令块状态的传输。控制端点(默认)管道仅用来请求批量端点上的STALL停止的状态和执行类特定请求命令。
    Bulk—Only传输的流程如图4所示。

2.2.3 SCSI命令集实现
    SCSI命令集是SCSI设备通用命令集。SCSI有3种字长的命令:6字节、10字节和12字节。Microsoft Win—dows环境下支持12字节长的命令。图5给出了通用的UFI命令块的格式。请注意,这些字节就是CBW封包中CBWCB字段的内容。

    对不同的命令只需根据SCSI命令集白皮书作出适当的回应。Pm25LV010的最小擦除单位为扇区(4 KB),故在程序中定义一个4 KB的缓冲区Cache_STRUC Flash-Cache,把每次收到的数据放入缓冲区中,到缓冲区满数据接收完毕时再将其写入Flash存储器中,流程如图6所示。

2.3 Flash存储器的读写控制
    Flash存储器读写程序由SPI控制和Pm25LV010控制两部分组成。
    Pm25LV010 Flash存储器采用的是SPI串行接口,其SPI有两种工作模式——模式O和模式3。SPI.c完成SPI底层操作,给Pm25LV010控制程序提供一个读写1字节数据函数。该函数使用SPI模式0。
    Pm25LV010控制程序完成Pm25LV010器件的所有操作,其向高层提供的函数及功能如表2所列。

    Pm25LV010的最小擦除单位是扇区(每扇区4 KB),在改写扇区内任意一字节数据时都需要将该扇区擦除。针对这种情况,在程序中定义了一个4 KB大小的缓冲区,当上层调用函数WriteToFlash()向Flash写数据时,并不直接写入Flash,而是先写到数据缓冲区,其流程如图7所示。

3 结论
    基于LPC2132微控制器的硬件平台上实现了USB驱动、Bulk-Only传输协议、SCSI命令集,实现了完整的U盘功能。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭