USB2.0协议概述

USB发展到现在,主要流行1.1、2.0、3.0这几个版本,而3.1暂时只有少量笔记本在用。

主流版本区别:

USB1.1,支持全速12Mbps和低速1.5Mbps。

USB2.0,兼容1.1,增加了高速480Mbps。

USB3.0,兼容2.0,增加了超速5Gbps。

在用户的角度,使用USB设备是非常方便的。但是,在开发人员的角度,可是谈USB色变。

这是因为,USB硬件接口非常简单,导致上层协议非常复杂。


由上图所示,自下而上,USB硬件接口提供物理的通信链路,EHCI等主机控制器负责调度各端点的数据流,USB驱动协助操作系统和USB设备交换数据同时能烧写固件到USB设备,GUI则让用户轻松操纵USB设备,服务器云端数据库提供各种各样的USB驱动。

USB协议,是一个主从式的协议,所有的通信都由主机发起,设备不能发起。下图,展示了USB家族的主要成员。


USB Host,即USB主机,一般是PC机。

USB Device,即USB设备,有USB键盘、U盘等,而USB Hub集线器是一种特殊的USB设备。

USB OTG,OTG即On-The-Go,同时具备USB主机和USB设备的功能,数码相机就带有OTG的功能。

以下,细说USB2.0的方方面面。

一、USB硬件接口

1.1 接插件。


由上图所示,USB座有很多种类型,主要分为:公/母、直插、贴片、单/双层、扁/方,等几种类型。

可以看到它只有四根线,分别是VBUS、DP(或D+)、DM(或D-)、GND。此外,还有屏蔽罩,一般屏蔽罩是通过一个100nF的电容连到GND的。

1.2 连接线。

USB线,也分几种:公对公/公对母,带磁环,带屏蔽等。

注意:USB线不能太长,否则设备可能无法正确工作。

1.3 热插拔。

热插拔。它能让你在不断电的情况下,插拔USB设备。

如果要支持热插拔,必须在VBUS、DP、DM三根线上,加上过压、过流保护,在未上电时DP和DM要保持高阻态。

另外,要利用金手指长短来控制上电顺序,插入时首先让电源线接通,让电源稳定之后,再接通信号线,拔出时顺序正好相反。这样有效防护接口被损坏。


1.4 上下拉电阻。

一般,在USB主机的DP、DM都接了下拉15K欧电阻。

对于低速设备,DM接了上拉1.5K欧电阻。

对于全速设备,DP接了上拉1.5K欧电阻。

对于高速设备,一接在主机的时候DP接了上拉1.5K欧电阻,后面经过握手协议之后,DP上断开1.5K欧电阻。

1.5 ESD防护。

一般支持USB接口的芯片ESD防护做得不够好,这个时候要另外加ESD芯片。如下图的USBLC6。


1.6 端接。

端接,目的是做阻抗匹配,特别是高速480Mbps对信号质量要求较高。

一般使用串联端接,在DP、DM上串联22欧电阻。

1.7 UTMI+和ULPI接口。

有一些不带USB接口的处理芯片,比如,51单片机、FPGA等。它们都不能直接处理USB总线上的DP、DM的差模信号。

所以,芯片厂商开发了一些USB PHY芯片,可以把DP、DM上的差模信号转成共模信号。

其中,成为业界标准的接口,有UTMI+和ULPI。

如下图所示,UTMI+接口一共有31根信号线。


如下图所示,ULPI接口一共有12根信号线。


UTMI+和ULPI,在功能上是等价的。

UTMI+和ULPI区别在于,ULPI需要读写寄存器,而UTMI+只需直接拉高或拉低信号线。

如下图所示,ULPI是在UTMI+的基础上封装了一层。


显然,UTMI+接口的信号线太多,占用大量的PCB空间,才需要推出ULPI接口。

市场上,大多数的USB PHY芯片都是ULPI接口。

1.8 检测USB设备速度的流程描述。

对于低速设备,在DM引脚上拉1.5K。

对于全速设备,在DP引脚上拉1.5K。

对于高速设备,则需要握手协议。

a、USB主机检测到全速设备,即:DP引脚上拉1.5K。

b、USB主机复位总线,即向总线发送SE0,此SE0持续时间不得小于2.5us。

c、高速设备检测到SE0持续时间不小于2.5us后,向总线发送Chirp K信号,此Chirp信号持续时间不小于1ms且不大于7ms。

d、总线回复到SE0状态。如果USB主机支持高速模式,则必须在Chipr K信号结束后100us内做出响应。

e、USB主机在Chipr K信号结束后100us内做出响应,向总线发送连续的Chirp K/J对,每个Chirp K信号或Chirp J信号的宽度不小于40us且不大于60us,每2个相邻的Chirp K和Chirp J信号之间的间隔不应大于2.5us。

f、高速设备在检测到连续的最少3对Chirp K/J对后,在500us内必须断开DP上的上拉电阻,并连接D+和D-上的对地高速端接电阻,完成高速握手,进入高速传输模式。

高速模式的握手协议,反应在USB3300的时序,如下图所示。





附录:相关资料。

1、USB2.0官方手册

2、USB设备类手册

3、USB3.0官方手册

4、USB3.1官方手册

5、EHCI官方手册

6、USB3300数据手册

7、USB3500数据手册

8、UTMI官方手册

9、ULPI官方手册

10、《Linux设备驱动程序》(内附Linux下的USB驱动教程)

11、深入浅出Windows驱动开发》(内附Windows下的USB驱动教程)



  • 27
    点赞
  • 162
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
USB识别握手协议涉及到USB设备与主机之间的通信,目的是确保设备能够正确被主机识别和通信。USB识别握手协议波形通常由以下几个阶段组成: 1. 建立Vbus电压:首先,主机会向USB设备提供一定的电压,通常为5V,这是通过主机上的电源线提供给设备的。 2. 设备响应:一旦设备感知到Vbus电压,它会开始响应主机发送的消息。设备会发送一个“零”值以表示它已准备好进行握手通信。 3. 主机确认:主机检测到设备的响应后,会发送一个“零”值来确认设备的状态正常。 4. 设备描述符:设备描述符是设备在握手过程中向主机发送的自我描述信息,它包含设备的身份和能力信息,主机通过解析这些信息来了解设备的类型和功能。 5. 主机确认:一旦主机成功解析设备描述符,它会发送一个“零”值来确认设备描述符的接收。 6. 配置描述符:如果设备有多个配置,设备将发送配置描述符,其中包含有关设备配置和功能的详细信息。 7. 主机确认:主机再次发送一个“零”值来确认配置描述符的接收。 8. 握手完成:一旦主机成功接收设备的配置描述符,设备和主机之间的识别握手过程就完成了,设备就可以开始与主机进行进一步的通信。 通过上述握手协议波形,USB设备和主机能够进行有效的识别和通信,确保设备能够正常工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值