引言
USB是近年来应用在PC领域的新型接口技术,是一些PC 大厂商,如Microsoft、Intel 等为了解决日益增加的PC 外设与有限的主板插槽和端口之间的矛盾而制定的一种串行通信的标准,自1995年在Comdex上亮相以来,至今已广泛地为各PC厂家所支持现在生产的PC 几乎都配备了USB 接口。Microsoft 的Windows98、NT以及MacOS、Linux、FreeBSD 等流行操作系统都增加了对USB 的支持。
USB 的主要优点:
使用方便。连接外设不必再打开机箱允许外设热插拔而不必关闭主机电源;
速度快。USB接口的最高传输率可达12 Mb/s;
提供低速方式,速率为1.5 Mb/s 扣除用于总线状态控制和错误检测等数据传输,最大理论速度也能达到1.2 Mb/s 和9.6 Mb/s。
连接灵活。一个USB 口理论上可以连接127个USB设备,连接的方式也十分灵活,既可以使用串行连接,也可以使用集线器Hub,把多个设备连接在一起,再同PC 机的USB 口相接。
独立供电。USB 接口提供了内置电源。
现在的USB生产厂商很多,几乎所有的硬件厂商都有USB 的产品。USB控制器一般有两种类型:一种是MCU 集成在芯片里面的如Intel 的
8X930AX、CYPRESS的EZ-USB、SIEMENS的C541U以及MOTOLORA、National Semiconductors 等公司的产品。另一种就是纯粹的USB接口芯片仅处理USB 通信如PHILIPS 的PDIUSBD11(I2C 接口)、PDIUSBP11A、PDIUSBD12(并行接口)、National Semiconductor的USBN9602、USBN9603、USBN9604等、前一种由于开发时需要单独的开发系统,因此开发成本较高;而后一种只是一个芯片与MCU接
口实现USB通信功能,因此成本较低,而且可靠性高。本文主要介绍PHILIPS公司的PDIUSBD12器件。
1 PDIUSBD12 芯片特点和内部结构
PDIUSBD12 是一个性能优化的USB器件。通常用于基于微控制器的系统并与微控制器通过高速通用并行接口进行通信,也支持本地DMA。传输该器件采用模块化的方法实现一个USB接口,允许在众多可用的微控制器中选择最合适的作为系统微控制器,允许使用现存的体系结构并使固件投资减到最小。这种灵活性减少了开发时间、风险和成本。是开发低成本且高效的USB 外围设备解决方案的一种最快途径。PDIUSBD12完全符合USB1.1规范,也能适应大多数设备类规范的设计如成像类、大容量存储类、通信类、打印类和人工输入设备等。因此,PDIUSBD12非常适合做很多外围设备,如打印机、扫描仪、外部大容量存储器(Zip驱动器)和数码相机等现在用SCSI 实现的很多设备如果用USB 来实现可以直接降低成本。
PDIUSBD12 挂起时的低功耗以及LazyClock 输出符合ACPI、OnNOW和USB电源管理设备的要求。低功耗工作允许实现总线供电的外围设备。
PDIUSBD12还集成了像SoftConnect、GoodLink、可编程时钟输出、低频晶振和终端电阻等特性。所有这些特性都能在系统实现时节省成本,同时在外围设备上很容易实现更高级的USB 功能。
1.1 主要特性
符合USB 1.1 协议规范;
集成了SIE FIFO 存储器收发器和电压调整器的高性能USB 接口芯片;
适应大多数设备类规范的设计;
与任何微控制器/微处理器有高速2MB/s的并行接口;
完全自动DMA 操作;
集成了320 B 的多配置FIFO存储器;
主端点有双缓存配置,增加吞吐量,容易实现实时数据传输;
在块传输模式下有1MB/s的数据传输率,在同步传输模式下有1Mb/s 的数据传输率;
具有总线供电能力,有非常好的EMI性能;
在挂起时有可控制的LazyClock 输出;
可通过软件控制USB总线连接SoftConnect;
在USB 传输时有闪亮的USB 连接指示灯GoodLink;
时钟频率输出可编程;
符合ACPI、OnNOW和USB 电源管理要求;
具有内部上电复位和低电压复位电路;
有SO18 和TSSOP28 封装;
能在-40~ +85℃工业级工作;
片内8kV静电保护;
双电压工作(3.3±0.3 V)或扩大的5 V电压范围(3.6~5.5 V);
多中断模式,方便块传输和同步传输。
1.2 内部结构
PDIUSBD12 的内部框图如图1 所示。
模拟收发器。集成的收发器直接通过终端电阻与USB 电缆接口。
电压调整器。片上集成的1 个3.3 V电压调整器为模拟收发器供电,也提供连接到外部1.5 k上拉电阻的输出电压。作为选择,PDIUSBD12提供集成1.5 k 上拉电阻的SoftConnect 技术。
PLL。 片上集成1个6~48 MHz的倍频PLL(锁相环)允许使用6 MHz 的晶振,EMI也由于使用低频晶振而减小。PLL 的工作不需要外部器件。
位时钟恢复。位时钟恢复电路用4倍过采样原理从输入的USB数据流中恢复时钟,能跟踪USB规范中指出的信号抖动和频率漂移。
PHILIPS 串行接口引擎PSIE、PHILIPS 的SIE完全实现USB协议层。考虑到速度,它是全硬件的,不需要固件微程序介入。这个模块的功能包括:同步模式识别、并/ 串转换、位填充/不填充、CRC校验、PID 确认、地址识别以及握手鉴定。
SoftConnect 高速设备与USB的连接是靠把D+通过1个1.5 k 的上拉电阻接到高电平来建立的。在PDIUSBD12中这个上拉电阻是集成在芯片内的,缺省是没有连接到VDD,这个连接是靠外部MCU 发一个命令来建立的。这使得系统微处理器可以在决定建立USB连接之前完成初始化。重新初始化USB 总线连接也可以不用拔掉电缆来完成。
GoodLink。GoodLink是靠一个引脚接发光二极管实现的。在USB设备枚举时LED指示灯将立即闪亮;当PDIUSBD12被成功枚举并配置时,LED指示灯将会始终亮;经过PDIUSBD12 的USB 数据传输过程中,LED将一闪一闪;传输成功后,LED熄灭;在挂起期间LED熄灭;这种特性可以使我们知道PDIUSBD12 的状态方便电路调试。
存储器管理单元MMU 和集成RAM。MMU和集成RAM能缓冲USB(工作在12Mb/s)数据传输和微控制器之间并行接口之间的速度差异,这允许微控制器以自己的速度读写USB 包。
并行和DMA接口。并行接口容易使用,速度快并且能直接与主微控制器接口。对于微控制器,PDIUSBD12可以看成是一个有8位数据总线和1 位地址线的存储设备,PDIUSBD12支持多路复用和非多路复用的地址和数据总线。在主端点(端点2)和局部共享存储器之间也可使用DMA(直接存储器存取)传输。它支持单周期模式和块传送模式两种DMA 传输。
2 PDIUSBD12 的引脚说明及典型连接
2.1 PDIUSBD12 引脚说明
PDIUSBD12 引脚如图2所示,引脚如表1所列。
2.2 PDIUSBD12 的典型连接
PDIUSBD1 与80C51的连接电路如图3所示。在这个例子中,ALE始终接低电平,说明采用单独地址和数据总线配置。A0脚接80C51的任何I/O引脚,控制是命令还是数据输入到PDIUSBD12。80C51的P0 口直接与PDIUSBD12 的数据总线相连接。CLKOUT时钟输出为80C51提供时钟输入。
3 软件设计
3.1 单片机方面软件设计
对于单片机控制程序,目前没有任何厂商提供自动生成固件firmware 的工具,因此所有程序都要由自己手工编制。USB单片机控制程序通常由三部分组成:第一、初始化单片机和所有的外围电路(包括PDIUSBD12);第二、主循环部分。其任务是可以中断的;第三、中断服务程序,其任务是对时间敏感的,必须马上执行。根据USB 协议,任何传输都是由主机host 开始的,这样,单片机作它的前台工作,等待中断,主机首先要发令牌包给USB 设备(这里是PDIUSBD12),PDIUSBD12 接收到令牌包后就给单片机发中断,单片机进入中断服务程序,首先读PDIUSBD12 的中断寄存器,判断USB 令牌包的类型,然后执行相应的操作。因此,USB单片机程序主要就是中断服务程序的编写,在USB单片机程序中要完成对各种令牌包的响应,其中比较难处理的是SETUP包,主要是端口0的编程。
单片机与PDIUSBD12 的通信主要是靠单片机给PDIUSBD12发命令和数据来实现的。PDIUSBD12的命令字分为三种:初始化命令字、数据流命令字和通用命令字。PDIUSBD12给出了各种命令的代码和地址。单片机先给PDIUSBD12 的命令地址发命令,根据不同命令的要求再发送或读出不同的数据。因此可以将每种命令做成函数,用函数实现各个命令,以后直接调用函数即可。
在编写USB 的单片机程序时,需要注意:
单片机的中断应设置为电平触发:中断后一定要读上次传输状态寄存器(命令40-45H) ,以清除中断寄存器中的中断标志,这样,PDIUSBD12的中断输出才能变回高电平,这一点非常重要。
在接收到Setup包后,一定要调用ACK setup命令重新使能端口0。
在向IN端点写完数据后,一定调用Validate Buffer (命令FAH)指明缓冲区中的数据有效,可以发送到主机。
当读完数据后,一定调用Clear Buffer(命令F2H)以保证可以接收新的包。
可以通过调用Read Chip ID(命令FDH)检查PDIUSBD12 是否工作。该命令要读两个字节数据
USB 初始化过程为
Set Address Enable;
Set Endpoint Enable(此时LED亮);
Disconnect;
delay (1~2 s);
Connect(即用43h 参数调用Set Mode,此时LED灭);
Read Interrupt Register。
完成初始化工作后,就可作其它的前台工作了,并在前台判断是否有Setup 包(通过一个变量,当中断服务程序检测到有Setup 包时,设置该变量)。然后执行响应的控制传输。在调试USB 单片机程序时,还要特别注意Windows 对USB 设备的枚举顺序。
GetDeviceDescriptor。主机主要对Length 域感兴趣,发送内容一定要正确,特别是第2字节type一定为0x01,即Device;否则,主机将不响应,或者再重复2次后放弃,可检查一下对EP0的RX、TX的设置次序。
SetAddress。一般为02 或03;
连续3次GetDeviceDescriptor。读取全部设备描述符,一般为18 B,分为多次传输,如果不正确主机将不响应或重复2 次后放弃。
GetConfigDescriptor。注意第2 字节一定为0x02,即config。
GetStringDescriptor(可能没有)。根据在设备描述符中是否有String 索引而定,一般先读取LanguageID,再读取product string。
读取全部ConfigDescriptor。次数根据描述符的大小决定(端点个数不同,描述符大小不同),如果不正确,主机将不响应或再重复2 次后放弃。
如果以上步骤都正确,主机将找到新设备,提示安装驱动程序;否则找到未知设备,不可用。安装驱动程序后,以后的每次PlugIn,枚举次序与以上步骤略有不同,之后会有SetConfiguration、GetConfiguration 和GetInterface等调用。
3.2 主机方面软件设计
Windows98 提供了多种USB 设备的驱动程序,但好像还没有一种是专门针对数据采集系统的,所以必须针对特定的设备来编制驱动程序。尽管系统已经提供了很多标准接口函数,但编制驱动程序仍然是USB 开发中最困难的一件事情,通常采用Windows DDK来实现。目前有许多第三方软件厂商提供了各种各样的生成工具,像Compuware的driverworks,Blue Waters 的Driver Wizard 等,它们能够很容易地在几分钟之内生成高质量的USB的驱动程序。作为WIN98 和WIN2K推荐的一项新技术来说,USB 的驱动程序和以往的直接跟硬件打交道的WIN95 的VXD方式的驱动程序不同,它是WDM类型的。
在调试USB 设备时,可使用UsbView程序检测设备是否能被Windows 枚举并配置,如果成功,还可在该程序中查看设备描述符、配置描述符和端点描述符是否正确。之后可以使用Driver Wizard生成一个通用驱动程序,在Windows提示安装驱动程序时,选择Driver Wizard 生成的驱动程序。其实Driver Wizard 生成的仅是一个Windows控制台的应用程序,它会调用安装Driver Wizard时安装在系统中的通用USB驱动程序。使用该程序就可测试设备是否能够正确传输数据以及传输速度,该程序也可作为最终产品USB传输部分的框架;如果不能满足要求,也可用WDM 重新编制驱动程序,用调试好的USB 设备来开发、调试主机软件。
4 应用实例
本文介绍一个高速数据采集系统,以AD公司的ADuC812为系统控制器。该单片机本身就是高度集成的高精度12 位数据采集系统,在其片内不仅组合了可重新编程非易失性闪速/电擦除程序存储器的高性能8位(与8051兼容MCU)还包含了高性能的自校准多通道(8 个输入通道)12 位ADC 和两个12 位DAC,且内核与8051 指令集兼容。PDIUSBD12 作为ADuC812 的存储器外设,接口比较简单。需要注意的地方是DMACK引脚必须接高电平,否则将不能接收任何命令和数据;EOT_N必须通过电阻接到USB的+5 V,以正确检测到USB 连接;INT_N引脚加1个上拉电阻,+5 V 接到VDD 引脚;在VOUT3. 3 引脚加1uF 电解电容和0.1uF 两个退耦电容。
结束语
PDIUSBD12 是一个性能优化的USB器件,它的SoftConnect 和GoodLink 技术使开发和调试USB 设备时非常方便,在性能、速度、方便性以及成本上都具有很大的优势。因此使用PHILIPS 公司的PDIUSBD12可以快速开发出高性能的USB设备。