梁宝娟,孙少波
(1.长安大学 电子与控制工程学院,陕西 西安 710064;2.西安文理学院 计算机系,陕西 西安 710065)
在USB的拓扑机构中居于核心地位的是主机(Host),任何一次USB的数据传输都必须由主机来发起和控制,所有USB设备都只能和主机建立连接,任何两个外设之间或是两个主机之间无法直接通信。而目前,大量扮演主机角色的是个人电脑PC。目前所买到和使用的USB设备基本都是只具备USB设备的功能而不具备主机功能,比如USB接口的移动硬盘、数码相机、打印机等。所有这些设备都只能在USB Host上使用,也就是通常只能通过PC来进行相互的文件和数据交换。没有了PC主机,这些设备是不能互联的[1]。
最简单的USB系统模型组成是以USB主机为核心,以外围的USB设备为特定功能的设备模块。即USB提供的是主机和设备中间的一种数据通信服务。此外,为了构建更复杂的USB系统,还需要加上USB集线器(Hub)[2]。
USB主机包括PC或嵌入式系统两种类型,每一次USB数据通信都必须是由USB主机来发起的 (远程唤醒模式除外),主机管理着每个USB设备。即使新兴的USB On-The-Go设备,其核心部分仍然是嵌入了USB主机的功能[3-4]。本方案主要是基于嵌入式USB主机的USB系统模型。
USB的拓扑体系由3种元素组成:主机、Hub和设备,通过Hub的级联,构成了层次化的星形结构。USB的拓扑结构如图1所示。
图1 USB总线拓扑结构Fig.1 USB bus topological structure
电源电路的组成如下:
系统采用双电压给电方式;触发器采用3.3 V给电;1284收发器采用5 V和3.3 V的双电压给电方式。在交流适配器中将干扰过滤后,提供5 V直流电压。3.3 V直流电压由固定输出电源模块来提供。电源系统结构如图2所示。
图2 电源部分电路系统结构图Fig.2 Structure diagram of the power control unit system
为了给USB总线安全的提供电源,采用电源管理芯片,利用MCU来管理USB总线的电源。系统reset时,为了使与其连接的USB设备不进行误操作,关闭 USB电源;总线电路异常而导致过流(over current)时,系统自动关闭电源并通知MCU。并且还采用压敏电阻(varistor)来防止静电(ESD);采用共模轭流线圈(Common Mode Choke Coil)来减少对总线差模数据的干扰[5-6]。USB Host接口部分的电路如图 3所示。
图3 USB接口电路图Fig.3 USB interface circuit
由RS232端口来下载MCU程序,对应的电路图如图4所示。
图4 MCU程序下载电路Fig.4 MCU program download circuit
DB9插座和MAX232置于单独的下载板上,利用8PIN插座和主板(SPP/USB转换主板)来连接。异步串行接口下载程序时,各管脚设置如下所示:
在 MB90F337内部有上电复位(power on reset)功能,在外部reset电路发生外部reset请求。外部reset电路的初步想法如图5所示。使用的复位芯片 (reset chip)是 PST9231。reset时间利用外部电容,设置为40~50 ms之间。
图5 上电复位电路Fig.5 Power on reset circuit
MiniHost部分负责USB Host部分的操作,它将完成如下功能:初始化MiniHost部分电路;支持USB 2.0高速和低速设备;注册回调函数;设备的枚举,包括BUS Reset、SET ADDRESS请求以及设定控制端点的最大包的大小;SETUP请求操作;Bulk传输请求操作[7]。
设置一个PWCTimer,使其再0.1ms中断一次,在这个中断处理程序中对记录时间的全局变量加1,也就是说系统中时间的单位是0.1ms。如果记录时间的全局变量溢出,则将这个变量的值设置为0。
初始化定时器代码如下:
MiniHost Module主流程图如图6所示。
当一个新的传输请求开始处理时,将会执行如图7所示流程。1)发送 SETUP阶段请求;
2)发送块请求(BULK Request);
当一个传输请求在一个阶段处理不完时,将会执行图8所示流程。比如控制传输(Control Transfer)需要3个阶段。
3)控制传输(Control Transfer)结束,向 EndPoint 结构体中写入传送完成的结果,并根据传输的类型做相应处理。
4)块传输(BULK Transfer)结束,向 EndPoint结构体中写入传送完成的结果,并向并口上发送ACK BUSY信号。
利用上述系统,设计一个能够把并口转换为USB接口的打印转换器,这个转换器只是把从并口收到的数据转发到USB接口上,然后根据USB接口规范,把数据重新包装后发送给USB打印机,转换器中并不需要对并口的数据内容进行解释,只是转发。
图6 MiniHost Module主流程图Fig.6 MiniHost module main flow chart
图7 新传输请求处理过程Fig.7 NEW request process flow chart
图8 CHECK处理过程Fig.8 CHECK process flow chart
并口打印机采用IEEE1284标准进行通讯。IEEE1284标准为PC和外设之间的通讯定义了双向通讯协议,通过该协议PC和外设之间的双向数据传输率可以比以前提高20到50倍,同时该协议保持了软件的向下兼容性。IEEE1284标准一共定义了5种数据传输模式,即正向传输模式 (兼容模式),两种反向传输模式(半字节模式和字节模式),两种双向传输模式(EPP模式-高速增强并行端口和ECP模式-扩展并行端口)。
打印电缆我们采用D25接口,并行口一般有25个引脚,其中包括8位数据线,5位打印机状态线,4位控制线。
打印设备它们能够把页面描述语言(PDL)转换为人们能够读懂的打印页面。因此需要制定打印机如何来接收这些PDL格式的数据,如何能够返回打印机的状态信息。常规的并口打印机用一个双向打印端口来只认识这些语言。USB用一个 Bulk OUT端点来发送这些数据到打印机,并用一个Bulk IN端点来发送状态信息或其他数据。 对于现已存在的方式来说,能够在主机中通过Bulk IN端点使用查询机制来检索并口的状态信息。一些 PDL允许打印机返回大量的数据,诸如一些字体定义等信息。 如果打印机实现了这个功能,它将使用用于传送回状态信息的Bulk IN端点来传送回这些数据[8]。
1)并口部分功能
①为了方便处理打印并口只支持IEEE 1284-1994 SPP模式。
②打印数据只支持单方向(数据:PC→转换器)。
③BUSY和ACK的信号时序类型为A-B(Ack-in-Busy)。
2)USB打印机接口功能
①支持USB Ver2.0 Full Speed。
②符合Universal Serial Bus Specification 2.0。
③符合Universal Serial Bus Device Class Definition for Printing Devices规范。
④控制传送的数据最大值为64字节。
⑤批量(Bulk)传送的数据最大值为64字节。
⑥不处理USB Hub。
3)内部功能
①定期取得打印机的状态(以1秒为单位),反映到并口信号线中(利用USB控制传送的GET_PORT_STATUS)。
②并口的收信缓冲存储为64字节,接收到64字节后由USB接口传送给打印机。
③并口的收信处理中设置了超时(1秒),一旦超时发生,接收到的数据由USB接口传送给打印机。
负责和并口相关的工作。从并口读取数据放入数据缓冲区。设置和读取并口状态和控制端口。通过读取时间,来生成并口的时序。使用中断(Interrupt)对并口的InputPrime信号进行相应的处理。使用中断(Interrupt)对并口的nStrobe信号进行相应的处理。
主模块负责初始化整个系统,包括Parallel Module,MiniHost Module以及整个系统的变量。编写一个回调函数,此函数在设备状态(连接或断开)改变时调用。在检测到设备连接后,调用 MiniHost Module枚举功能,枚举打印机,并把打印机设置为某种模式。 检查是否要发送的控制或批量传送。 如果要,则把它们发送出去。
本论文设计了一种嵌入式USB主机系统,并完成了该系统的硬件和固件的实现和调试。为了验证系统,实现了打印机IEEE 1284中的SPP模式协议到USB打印设备类协议转换器。在硬件设计中,系统采用富士通90330系列MCU中的MB90F337完成中央控制器和USB Host控制器,电路设计简洁。文章为其他嵌入式USB Host设备的开发提供了设计参考。
[1]李英伟,王成儒,练秋生,等.USB2.0原理与工程开发[M].2版.北京:国防工业出版社,2007.
[2]夏益民,王广君.基于USB总线的高速数据采集系统[J].国外电子元器件,2003(10):20-23.
XIA Yi-min,WANG Guang-jun.A high speed data collection system based on USB[J].International Electronic Elements,2003(10):20-23.
[3]董海涛,谢经明,陈冰,等.基于ARM9的CNC系统USB-HOST驱动实现[J].仪表技术与传感器,2011(7):44-46.
DONG Hai-tao,XIE Jing-ming,CHEN Bing,et al.Realization of USB-Host drive in CNC system based on ARM9[J].Instrument Technique and Sensor,2011(7):44-46.
[4]何苏勤,黄翠翠.基于USB2.0的异步数据传输和控制接口的设计[J].国外电子测量技术,2010,29(3):79-83.
HE Su-qin,HUANG Cui-cui.Design of asynchronous data transmission and control interface based on USB2.0[J].Foreign Electronic Measurement Technology,2010,29(3):79-83.
[5]陈英俊,张红兵.RS-232、RS-485/USB转换器的最简设计[J].航空精密制造技术,2003(6):17-20,24.
CHEN Ying-jun,ZHANG Hong-bing.The simplest solution for RS-232、RS-485/USB converter[J].Aviation Precision Manufacturing Technology,2003(6):17-20,24.
[6]何源,顾金良.USB与RS232接口转换器的设计[J].指挥控制与仿真,2006,28(5):114-117.
HE Yuan,GU Jin-liang.Design of USB/RS232 converter[J].Command Control&Simulation,2006,28(5):114-117.
[7]Michael Bar.C/C++嵌入式系统编程[M].于志宏,译.北京:中国水利出版社,2001.
[8]Universal Serial Bus Specification Revision 2.0[EB/OL].(2012-02-01)http://www.usb.org