通用串行总线(USB)接口具有简单灵活、高带宽、易于扩展和热插拔等优点,它目前已成为数码设备的标准接口之一,小到U盘、MP3,大到数码相机、打印机,USB接口的身影无处不在。但我们目前所使用的USB移动设备多为USB的外设(DEVICE) , 比如USB的移动硬盘、USB接口的数码相机,一般只能在PC上使用,即只能通过PC实现文件和数据的交换。 业界和用户的需求呼唤USB主机的嵌入式化,因此在嵌入式系统中实现USB主机功能成了USB设计领域的热点之一。 迄今为止,嵌入式USB主机的最大市场和增长点在移动消费电子设备领域, 比如PDA与USB记忆棒传递数据、MP3之间传递歌曲、数码相机连接打印机等。 嵌入式USB主机也逐渐用于工业测控领域,用来实现数据的采集和交换。原来数据采集和交换大多是使用软盘、串行接口(RS232/RS485)或以太网等方式。软盘存储容量小、可靠性差,而串行接口或以太网都需要布线施工,接入成本大,而且不具备移动性。现在,越来越多的嵌入式系统采用通过USB总线连接的测控设备。 USB控制器ISP1161简介 一个USB系统一般由一个USB主机(HOST)、一个或多个USB集线器(HUB)和一个或多个USB设备节点(NODE)组成。USB协议规定了USB主机与USB设备的主从关系,所以USB接口产品的应用离不开USB主机的开发。USB主机是包含USB软件驱动和USB主机硬件功能接口的计算机系统实体。USB主机硬件是指USB主机控制器,它规定了USB主机硬件接口,因而在设计USB协议栈时必须了解相关的USB主机控制器规范。 针对嵌入式系统应用的USB主机控制器规范是康柏、微软、松下等公司提出的OHCI(开放式主机控制器接口)标准。 飞利普公司的ISP1161芯片支持OHCI标准,它是一个符合USB2.0全速规范的单片主机控制器和设备控制器。ISP1161可以仅作为主机控制器或设备控制器使用,也可以同时作为主机和设备控制器使用。 ISP1161可分为四大功能模块: 1)主机控制器模块:实现主机控制器的功能。提供两个下行端口,每个下行端口都有自己的过流检测输入管脚和电源转换控制输出管脚。 2)设备控制器模块:实现设备控制器的功能。提供一个上行端口,有其自身的VBUS检测输入管脚。 3)微处理器接口模块:两个USB控制器共用一个微处理器总线接口,它们有相同的数据总线,I/O地址不同。它们也有各自的中断请求输出管脚和独立的DMA通道。 4)电源调整和上电复位模块:除了可以软件复位外,还可以通过RESET_N管脚实现硬件复位。ISP1161只接受5V或3.3V的电压,当输入5V电压时,电源调整器会将其调整为3.3V。 ISP1161 主机控制器子模块的功能框图示于图1,主机控制器的下行端口可与任意一个符合USB 规范的USB 设备和包含USB 上行端口的USB 集线器相连。类似地,设备控制器的上行端口可与任意一个符合USB 规范的USB主机和包含USB 下行端口的USB 集线器相连。
相关嵌入式应用系统的架构 本文涉及的嵌入式系统是一个指纹验证系统,其总体结构如图2所示。系统采用英特尔公司的32位400MHz微处理器PXA255以满足指纹识别系统计算量大的需要,PXA255具有丰富的外围接口,如:LCD控制器、串口、CF卡接口、USB客户端口,但 没有USB 主机控制器。此外,硬件平台还包括存储模块、数据采集模块、USB模块、网络通信模块和调试及下载接口模块,系统总体结构框图如图2所示。
对于PXA255处理器而言,ISP1161类似于一个具有16位数据总线的存储设备。ISP1161工作在并行I/O(PIO)模式,只占用两个I/O端口和微处理器两个内存空间。微处理器用两根地址线A0和A1来读写ISP1161内部寄存器和FIFO缓冲RAM。地址线A0用来选择传输命令数据:A0=1,处理器访问ISP1161的命令端口;A0=0,处理器访问ISP1161的数据端口。地址线A1用来选择主机控制器或设备控制器模式:A1=0,切换至主机控制器模式;A1=1,切换至设备控制器模式。本系统中ISP1161和PXA255的硬件接口如图3所示。用可编程I/O模式实现数据通信,即ISP1161的数据总线经总线驱动接到PXA255的数据总线D[0:15],A0和A1分别接到PXA255的A1和A2以实现主机和设备、命令和数据端口的选择。I/O口地址的完全解码包括芯片选择信号CS及地址线A1和A0。I/O口的访问方向由RD及WR信号控制:当RD为低时,微处理器从ISP1161A1 数据口读取数据;当WR为低时,微处理器向指令端口写入一个指令,或向数据端口写入数据。
USB主机软件设计 系统的软件平台是微软公司的Windows CE。 ISP1161软件模型 USB主机软件系统包括通用串行总线驱动程序(USBD)、主机控制器驱动程序(HCD)和客户端软件。客户端软件是应用代码或USB类驱动程序。USBD和HCD共同用作USB主机堆栈。USBD以I/O请求包的形式指定某一特定通道传输数据,并把请求分解成多个事务。HCD与ISP1161之间以PTD(PHILIPS Transfer Description)的形式进行通信。I/O请求包的数据在底层被打包成PTD的格式后再与ISP1161进行通信。 ISP1161只提供了一部分符合OHCI标准的寄存器,而其硬件是支持OHCI标准的。所以为使它完全符合OHCI标准,我们设计时在系统内存中定义一套完全符合OHCI规范的操作寄存器和HCCA控制器通信区,软件读写其中数据,以软件模拟硬件来实现完整的OHCI规范,并按照OHCI规范的要求,在系统内存中维护了一套完整的数据结构,以完成对主机控制器初始化、状态读取并收集USB主机与设备通信的详细信息。 ISP1161的数据传输模式 ISP1161提供了HC控制和状态寄存器、ATL缓冲区和ITL缓冲区。其中HC控制和状态寄存器包括一套可操作的符合OHCI的寄存器(32位)和一套ISP1161特定的寄存器(16位)。通过对相应寄存器的操作,主机控制器驱动程序就可以完成对主机控制器初始化和配置工作。ATL缓冲区和ITL缓冲区用来实现USB系统支持的四种不同数据传输:控制传输、批量传输、中断传输和实时传输。ITL是实时传输的缓冲的FIFO,而ATL是USB其它三种类型传输的缓冲FIFO。 ISP1161数据传输的具体过程为:硬件初始化完成后,调用HCD的MakePTDdata函数在系统存储器中以PTD数据结构定义一块数据缓冲区。再调用S
endPTD函数发送PTD数据,其中的WritePTDtoATL函数将数据复制到ATL或ITL缓冲区。通过ISP1161硬件扫描ATL或ITL缓冲区以实现与USB终端设备进行通信。 硬件扫描过程就是把数据发送到总线上,以硬件扫描ATL缓冲区为例:当HCD通过HcTransferCounter寄存器向ATL缓冲区写入HcATLBufferPort寄存器指定的字节数时,主机控制器硬件开始扫描ATL缓冲区;当操作完成后,HcBufferStatusPort寄存器中的位ATLBufferFull被置位,ATLBufferFull位从逻辑0到逻辑1的跳变使硬件开始扫描ATL缓冲区内的PTD;当ATLInt中断产生时,表明硬件停止扫描ATL缓冲区,HcBufferStatus寄存器中的位ATLBufferDone被置位,HCD又可以访问ATL缓冲区了。相关的部分伪代码如下:
数据结构链表的处理 在HCD将PTD从系统内存复制到ATL或ITL缓冲区之前,HCD必须通过集合数据结构来建立和追踪PTD。HCD的责任是追踪所有已连接设备的每个端点的属性,如端点最大封包大小、端点地址和该端点从属的设备地址。另外,HCD必须管理每个端点新的PTD的产生和已经完成的PTD的处理。所以使用一个有效的数据结构体系可以加快主机控制器的操作。本设计实现的数据结构类似于OHCI中定义的数据结构,如图4所示。此数据结构由三部分组成:三种类型端点的队列(控制传输端点、批量传输端点和中断传输端点)、每种端点的一个PTD列和一个完成队列。每个列队由一个全局指针指定,这个全局指针保持队列中第一个端点(EP)队列头的地址。每个EP队列头指向一个PTD列。一个PTD列保留着等待被主机控制器处理的PTD。在控制、批量和中断传输中,PTD被复制到ATL缓冲区。一旦PTD被放入ATL缓冲区,主机控制器就在下一帧中处理该PTD。
结束语 在USB主机端功能实现后,我们又开发了USB设备——指纹传感器MBF200的驱动程序,并按照规定要求实现了指纹数据的采集和传输。
点击看原图 |
共1条
1/1 1 跳转至页
嵌入式系统中USB主机控制器的实现
关键词: 嵌入式 系统 主机 控制器 实现 接口 设备 数据
共1条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
vscode+cmake搭建雅特力AT32L021开发环境被打赏30分 | |
【换取逻辑分析仪】自制底板并驱动ArduinoNanoRP2040ConnectLCD扩展板被打赏47分 | |
【分享评测,赢取加热台】RISC-V GCC 内嵌汇编使用被打赏38分 | |
【换取逻辑分析仪】-基于ADI单片机MAX78000的简易MP3音乐播放器被打赏48分 | |
我想要一部加热台+树莓派PICO驱动AHT10被打赏38分 | |
【换取逻辑分析仪】-硬件SPI驱动OLED屏幕被打赏36分 | |
换逻辑分析仪+上下拉与多路选择器被打赏29分 | |
Let'sdo第3期任务合集被打赏50分 | |
换逻辑分析仪+Verilog三态门被打赏27分 | |
换逻辑分析仪+Verilog多输出门被打赏24分 |