0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

USB总线上的情形是怎样的

xCb1_yikoulinux 来源:一口Linux 作者:一口Linux 2022-07-07 14:10 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

0. 基本概念

一个【传输】(控制、批量、中断、等时):由多个【事务】组成;

一个【事务】(IN、OUT、SETUP):由一多个【Packet】组成。

USB数据在【主机软件】与【USB设备特定的端点】间被传输。【主机软件】与【USB设备特定的端点】间的关联叫做【pipes】。一个USB设备可以有多个管道(pipes)。

1. 包(Packet)

包(Packet)是USB系统中信息传输的基本单元,所有数据都是经过打包后在总线上传输的。数据在 USB总线上的传输以包为单位,包只能在帧内传输。高速USB 总线的帧周期为125us,全速以及低速 USB 总线的帧周期为 1ms。帧的起始由一个特定的包(SOF 包)表示,帧尾为 EOF。EOF不是一个包,而是一种电平状态,EOF期间不允许有数据传输。

注意:虽然高速USB总线和全速/低速USB总线的帧周期不一样,但是SOF包中帧编号的增加速度是一样的,因为在高速USB系统中,SOF包中帧编号实际上取得是计数器的高11位,最低三位作为微帧编号没有使用,因此其帧编号的增加周期也为 1mS

USB总线上的情形是怎样的?

6fe9b8a4-fda8-11ec-ba43-dac502259ad0.png

包是USB总线上数据传输的最小单位,不能被打断或干扰,否则会引发错误。若干个数据包组成一次事务传输,一次事务传输也不能打断,属于一次事务传输的几个包必须连续,不能跨帧完成。一次传输由一次到多次事务传输构成,可以跨帧完成。

USB包由五部分组成,即同步字段(SYNC)、包标识符字段(PID)、数据字段、循环冗余校验字段(CRC)和包结尾字段(EOP),包的基本格式如下图:

700dcfdc-fda8-11ec-ba43-dac502259ad0.png

1.1 PID类型(即包类型)

701e57ee-fda8-11ec-ba43-dac502259ad0.png

702f24c0-fda8-11ec-ba43-dac502259ad0.png

1.2 Token Packets

704635ac-fda8-11ec-ba43-dac502259ad0.png

此格式适用于IN、OUT、SETUP、PING。

PID 数据传输方向

IN Device-》Host

OUT Host-》Device

SETUP Host-》Device

PING Device-》Host

1.3 Start-of-Frame(SOF) Packets

SOF包由Host发送给Device。

对于full-speed总线,每隔1.00 ms ±0.0005 ms发送一次;

对于high-speed总线,每隔125 μs ±0.0625 μs发送一次;

SOF包构成如下图所示

7051c52a-fda8-11ec-ba43-dac502259ad0.png

705f6a2c-fda8-11ec-ba43-dac502259ad0.png

1.4 Data Packets

7072b01e-fda8-11ec-ba43-dac502259ad0.png

有四种类类型的数据包:DATA0, DATA1, DATA2,and MDATA,且由PID来区分。DATA0和DATA1被定义为支持数据切换同步(data toggle synchronization)。

1.5 Handshake Packets

7086d1e8-fda8-11ec-ba43-dac502259ad0.png

ACK: 对于IN事务,它将由host发出;对于OUT、SETUP和PING事务,它将由device发出。

NAK: 在数据阶段,对于IN事务,它将由device发出;在握手阶段,对于OUT和PING事务,它也将由device发出;host从不发送NAK包。

2. 事务(Transaction)

在USB上数据信息的一次接收或发送的处理过程称为事务处理(Transaction)即:The delivery of service to an endpoint。一个事务由一系统packet组成,具体由哪些packet组成,它取决于具体的事务。可能由如下包组成:

一个token packet

可选的data pcket

可选的handshake packet

可选的special packet

2.1 输入(IN)事务处理

输入事务处理:表示USB主机从总线上的某个USB设备接收一个数据包的过程。

【正常】的输入事务处理

70985b20-fda8-11ec-ba43-dac502259ad0.png

【设备忙】时的输入事务处理

70ac4072-fda8-11ec-ba43-dac502259ad0.png

【设备出错】时的输入事务处理

70b94f6a-fda8-11ec-ba43-dac502259ad0.png

2.2. 输出(OUT)事务处理

输出事务处理:表示USB主机把一个数据包输出到总线上的某个USB设备接收的过程。

【正常】的输出事务处理

70c6b6c8-fda8-11ec-ba43-dac502259ad0.png

【设备忙时】的输出事务处理

70d5d4c8-fda8-11ec-ba43-dac502259ad0.png

【设备出错】的输出事务处理

70e2fca2-fda8-11ec-ba43-dac502259ad0.png

2.3 设置(SETUP)事务处理

【正常】的设置事务处理

70f14d48-fda8-11ec-ba43-dac502259ad0.png

【设备忙时】的设置事务处理

70fd9e86-fda8-11ec-ba43-dac502259ad0.png

【设备出错】的设置事务处理

710ccf50-fda8-11ec-ba43-dac502259ad0.png

3. USB传输类型

在USB的传输中,定义了4种传输类型:

控制传输 (Control Transfer)

中断传输 (Interrupt Transfer)

批量传输 (Bulk Transfer)

同步传输 (Isochronous)

3.1 控制传输 (Control Transfer)

控制传输由2~3个阶段组成:

建立阶段(Setup)

数据阶段(无数据控制没有此阶段)(DATA)

状态阶段(Status)

每个阶段都由一次或多次(数据阶段)事务传输组成(Transaction)。

控制数据由USB系统软件用于配置设备(在枚举时),其它的驱动软件可以选择使用control transfer实现具体的功能,数据传输是不可丢失的。

3.1.1 建立阶段

主机从USB设备获取配置信息,并设置设备的配置值。建立阶段的数据交换包含了SETUP令牌封包、紧随其后的DATA0数据封包以及ACK握手封包。它的作用是执行一个设置(概念含糊)的数据交换,并定义此控制传输的内容(即:在Data Stage中IN或OUT的data包个数,及发送方向,在Setup Stage已经被设定)。

711d5ece-fda8-11ec-ba43-dac502259ad0.png

3.1.2 数据阶段

根据数据阶段的数据传输的方向,控制传输又可分为3种类型:

控制读取(读取USB描述符)

控制写入(配置USB设备)

无数据控制

数据传输阶段:用来传输主机与设备之间的数据。

控制读取

是将数据从设备读到主机上,读取的数据USB设备描述符。该过程如下图的【Control Read】所示。对每一个数据信息包而言,首先,主机会发送一个IN令牌信息包,表示要读数据进来。然后,设备将数据通过DATA1/DATA0数据信息包回传给主机。最后,主机将以下列的方式加以响应:当数据已经正确接收时,主机送出ACK令牌信息包;当主机正在忙碌时,发出NAK握手信息包;当发生了错误时,主机发出STALL握手信息包。

控制写入

是将数据从主机传到设备上,所传的数据即为对USB设备的配置信息,该过程如下的图【Control Wirte】所示。对每一个数据信息包而言,主机将会送出一个OUT令牌信息包,表示数据要送出去。紧接着,主机将数据通过DATA1/DATA0数据信息包传递至设备。最后,设备将以下列方式加以响应:当数据已经正确接收时,设备送出ACK令牌信息包;当设备正在忙碌时,设备发出NAK握手信息包;当发生了错误时,设备发出STALL握手信息包。

712b0790-fda8-11ec-ba43-dac502259ad0.png

3.1.3 状态阶段

状态阶段:用来表示整个传输的过程已完全结束。

状态阶段传输的方向必须与数据阶段的方向相反,即原来是IN令牌封包,这个阶段应为OUT令牌封包;反之,原来是OUT令牌封包,这个阶段应为IN令牌封包。

对于【控制读取】而言,主机会送出OUT令牌封包,其后再跟着0长度的DATA1封包。而此时,设备也会做出相对应的动作,送ACK握手封包、NAK握手封包或STALL握手封包。

相对地对于【控制写入】传输,主机会送出IN令牌封包,然后设备送出表示完成状态阶段的0长度的DATA1封包,主机再做出相对应的动作:送ACK握手封包、NAK握手封包或STALL握手封包。

3.2 批量传输 (Bulk Transfer)

用于传输大量数据,要求传输不能出错,但对时间没有要求,适用于打印机、存储设备等。

批量传输是可靠的传输,需要握手包来表明传输的结果。若数据量比较大,将采用多次批量事务传输来完成全部数据的传输,传输过程中数据包的PID 按照 DATA0-DATA1-DATA0-…的方式翻转,以保证发送端和接收端的同步。

USB 允许连续 3次以下的传输错误,会重试该传输,若成功则将错误次数计数器清零,否则累加该计数器。超过三次后,HOST 认为该端点功能错误(STALL),放弃该端点的传输任务。

一次批量传输(Transfer)由 1 次到多次批量事务传输(Transaction)组成。

翻转同步:发送端按照 DATA0-DATA1-DATA0-…的顺序发送数据包,只有成功的事务传输才会导致 PID 翻转,也就是说发送端只有在接收到 ACK 后才会翻转 PID,发送下一个数据包,否则会重试本次事务传输。同样,若在接收端发现接收到到的数据包不是按照此顺序翻转的,比如连续收到两个 DATA0,那么接收端认为第二个 DATA0 是前一个 DATA0 的重传。

它通过在硬件级执行“错误检测”和“重传”来确保host与device之间“准确无误”地传输数据,即可靠传输。它由三种包组成(即IN事务或OUT事务):

token

data

handshake

71481484-fda8-11ec-ba43-dac502259ad0.png

For IN Token (即:IN Transaction)

ACK: 表示host正确无误地接收到数据

NAK: 指示设备暂时不能返回或接收数据 (如:设备忙)

STALL:指示设备永远停止,需要host软件的干预 (如:设备出错)

For OUT Token (即:OUT Transaction)

如果接收到的数据包有误,如:CRC错误,Device不发送任何handshake包

ACK: Device已经正确无误地接收到数据包,且通知Host可以按顺序发送下一个数据包

NAK: Device 已经正确无误地接收到数据包,且通知Host重传数据,由于Device临时状况(如buffer满)

STALL: 指示Device endpoint已经停止,且通知Host不再重传

Bulk读写序列

715dccd4-fda8-11ec-ba43-dac502259ad0.png

即由一系统IN事务或OUT事务组成。

3.3 中断传输(Interrupt Transfer)

中断传输由IN或OUT事务组成。

中断传输在流程上除不支持PING 之外,其他的跟批量传输是一样的。他们之间的区别也仅在于事务传输发生的端点不一样、支持的最大包长度不一样、优先级不一样等这样一些对用户来说透明的东西。

主机在排定中断传输任务时,会根据对应中断端点描述符中指定的查询间隔发起中断传输。中断传输有较高的优先级,仅次于同步传输。

同样中断传输也采用PID翻转的机制来保证收发端数据同步。下图为中断传输的流程图。

中断传输方式总是用于对设备的查询,以确定是否有数据需要传输。因此中断传输的方向总是从USB设备到主机。

71797b96-fda8-11ec-ba43-dac502259ad0.png

DATA0或DATA1中的包含的是中断信息,而不是中断数据。

3.4 同步传输(Isochronous Transfer)

它由两种包组成:

token

data

同步传输不支持“handshake”和“重传能力”,所以它是不可靠传输。

同步传输是不可靠的传输,所以它没有握手包,也不支持PID翻转。主机在排定事务传输时,同步传输有最高的优先级。

同步传输适用于必须以固定速率抵达或在指定时刻抵达,可以容忍偶尔错误的数据上。实时传输一般用于麦 克风、喇叭、UVC Camera等设备。实时传输只需令牌与数据两个信息包阶段,没有握手包,故数据传错时不会重传。

718c4ee2-fda8-11ec-ba43-dac502259ad0.png

原文标题:USB通信协议深入理解

文章出处:【微信公众号:一口Linux】欢迎添加关注!文章转载请注明出处。

审核编辑:彭静
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据传输
    +关注

    关注

    9

    文章

    2230

    浏览量

    67750
  • USB总线
    +关注

    关注

    1

    文章

    71

    浏览量

    37977
  • 计数器
    +关注

    关注

    32

    文章

    2321

    浏览量

    98621

原文标题:USB通信协议深入理解

文章出处:【微信号:yikoulinux,微信公众号:一口Linux】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    如何评估PCB板的USB、MIPI总线的差分阻抗?

    在现代电子设备中,高速数据传输接口,如USB、MIPI总线已成为关键组件。为确保信号完整性,评估其差分阻抗至关重要。本文将深入探讨PCB板上USB差分阻抗和MIPI总线差分阻抗的评估方
    的头像 发表于 04-29 10:56 163次阅读
    如何评估PCB板的<b class='flag-5'>USB</b>、MIPI<b class='flag-5'>总线</b>的差分阻抗?

    瑞芯微(EASY EAI)RV1126B USB摄像头

    1.USB简介USB:UniversalSerialBus(通用串行总线)。是一种常用于电子设备间通讯的通用标准接口。USB总线作为一种高速
    的头像 发表于 12-16 13:54 6592次阅读
    瑞芯微(EASY EAI)RV1126B <b class='flag-5'>USB</b>摄像头

    I2C的总线协议

    I2C 总线使用两根信号线(数据线 SDA 和时钟线 SCL)在设备间传输数据。SCL 为单向时钟线,固定由主机驱动。SDA 为双向数据线,在数据传输过程中由收发两端分时驱动。 I2C 总线上可以
    发表于 12-15 08:07

    LIN总线相关知识

    )包含主任务和从任务; (3)从节点(slave)只包含从任务; (4)主任务(master)决定总线上的报文,从任务发送数据; (5)LIN网络中的所有节点(包括主机节点)都具有从机任务,当接到主机任务的报文信息时,它们中的某一个要对报文做出响应。
    发表于 12-10 08:14

    如何将SD卡驱动模块挂载至外设总线

    我们的队伍编号是CICC2962,这是我们第五次分享,接下来我将分享一下如何将SD卡驱动模块挂载至外设总线上,并且发送一条读指令。 这是外设总线上被保留的接口信号,我们将所写的代码与之相连接
    发表于 10-30 06:12

    关于ICB总线的应用

    ICB总线总的可以分为命令通道和响应通道,主机通过ICB总线向从机发送命令,从机通过ICB总线响应主机,如下图所示 如下是往ICB总线上挂载AXI Peripheral的例程,通过
    发表于 10-29 07:44

    基于hbirdv2的APB总线添加外设(一)

    了icb2apb模块,即完成了ICB总线到APB总线的转换,然后再将APB接口对应的外设挂在了APB总线上。其余的GPIO、SPI、IIC等外设均采用了该实现方式。 再反观ICB总线上
    发表于 10-29 07:26

    三格电子CAN总线通信原理及在消防领域中的应用

    多个节点(最多可达110个),实现设备间稳定、高效的双向通信。在消防系统中,烟感、温感、报警器、灭火设备等都可以挂载在CAN总线上,形成可靠的火灾监控和联动控制网络。  CAN转光纤原理及应用 CAN转光纤设备将CAN总线上的电信号通过光电
    的头像 发表于 09-02 15:11 1490次阅读
    三格电子CAN<b class='flag-5'>总线</b>通信原理及在消防领域中的应用

    如何使用 M460 系列微控制器 (MCU) 接收和打印 CANFD 总线上的所有消息?

    使用 M460 系列微控制器 (MCU) 接收和打印 CANFD 总线上的所有消息
    发表于 08-20 06:17

    高速信号抗浪涌“神器”,适用于USB 2.0、USB 3.X(Gen1/Gen2)、HDMI

    usb
    jf_15747056
    发布于 :2025年07月23日 19:08:12

    FPGA外接FT232H配置FIFO实现USB通信回环测试

    USB英文全称 Universal Serial Bus,即通用串行总线,是一个外部总线标准,用于规范电脑与外部设备的连接和通讯。
    的头像 发表于 07-17 11:30 4931次阅读
    FPGA外接FT232H配置FIFO实现<b class='flag-5'>USB</b>通信回环测试

    CYT2B93CAE怎样才能接收特定 ID 的中断?

    你好,我正在使用 CYT2B93CAE 使用设备配置器 5.3,我选择 RX 缓冲区来接受特定的 ID(例如,0x020)。然而,问题是我在总线上的所有帧上都收到了中断,而不仅仅是专用 ID。 当其他所有 ID 均未发生中断时,我怎样才能接收特定 ID 的中断?
    发表于 07-15 07:09

    如何评估CAN总线信号质量

    网络中,数据通过双绞线上的差分信号传输。信号质量直接影响节点正确解读数据的能力。信号质量差可能表现为: 位错误 :由于噪声或信号失真导致的位误判。 帧错误 :CAN帧结构错误,导致接收节点拒绝。 总线
    发表于 06-07 08:46

    GPIB通用总线串口USB互转模块介绍

    总线控制系统中,至少需要一组听、讲、控三种仪器装置在里面才可以组成完整的操作控制系统。目前市面上多数仪器没有GPIB通用总线的通信功能,在实际系统搭建里需要将其通信接口转换为GPIB的形式进行连接,这时候就需要用到可以将RS485/RS232C/
    的头像 发表于 06-06 13:51 1045次阅读

    是否有关于如何通过 I2C 总线上的 uProcessor 或 FPGA 与芯片通信的文档?

    我们正在做一个项目,我们想回读电缆中的eMarker芯片。 浏览不同的评估板和数据表,看来我们需要为芯片编译代码。 1. 芯片是否预配置了默认固件? 2. 是否有关于如何通过 I2C 总线上
    发表于 05-29 06:13