目录
声明:前面和后续提到的OUT和IN都是对主机而言的。
1.前言
前面讲过USB一个传输由多个事务组成,一个事务由多个包实体组成。传输又分为控制传输、同步传输、批量传输、中断传输四种,上一节我们讲了同步传输细节及事务组成,今天我们主要讲解批量传输及事务组成,批量传输也叫大容量传输。
批量传输和同步传输类似,是使用批量事务(Bulk Transactions)来传输数据。批量读使用批量输入事务,批量写使用批量输出事务。批量传输通常在数据量大、对数据的实时性要求不高的场合,例如USB打印机、扫描仪、大容量存储设备等,批量传输可以占用任意可用的数据带宽。
批量传输主要包括批量读传输、批量写传输两种,传输事务如下图。
2.批量传输的结构
批量传输的事务和同步传输一样,都有只有1个阶段,数据阶段。
主机如果是批量读数据请求,则数据阶段为一个或者多个IN事务(批量传输事务,事务到后面讲解);
主机如果是批量写数据请求,则数据阶段为一个或者多个OUT事务;
数据阶段是由一到多个IN/OUT事务组成。这是由于有时候存在一个事务传不完的数据,所以可能存在多个连续IN/OUT事务的情况,在同一次数据传输阶段中事务类型(读写)必定相同。
注:批量传输的事务和同步传输类似,都有只有1个数据阶段,都是使用IN事务或者OUT事务进行传输,只是两种传输的事务的组成有很小的区别,后期详细讲解。
3.抓包分析
3.1批量读传输抓包分析
因为是设备给主机传输数据,所以是数据阶段是IN事务。
3.2批量写传输抓包分析
因为是主机给设备传输数据,所以是数据阶段是OUT事务,如下图。
4.批量传输各速率下支持最大包长度
批量传输不支持在低速下,高速最大包长度为512字节,全速下为64字节。
5.批量传输事务组成
6.传输、事务、包组成学习架构图
本架构图后期再学习中会一步一步更新,每一节之后也会逐步完善并更新,最后会完整的展示出来传输、事务、包的结构,让大家在学习过程中对协议框架不混乱。
1.本文部分素材来源网络,版权归原作者所有,如涉及作品版权问题,请与我联系删除。
2.未经原作者允许不得转载本文内容,否则将视为侵权;
3.转载或者引用本文内容请注明来源及原作者;
4.对于不遵守此声明或者其他违法使用本文内容者,本人依法保留追究权等。
下面是我的个人微信公众号,关注【一个早起的程序员】精彩系列文章每天不断。