windows USB 设备驱动开发-USB带宽

本文讨论如何仔细管理 USB 带宽的指导。 每个 USB 客户端驱动程序都有责任最大程度地减少其使用的 USB 带宽,并尽快将未使用的带宽返回到可用带宽池。

在这里,我们认为USB 2.0 的速度是480Mbps、12Mbps、1.5Mbps,这分别对应高速、全速、低速三种,但实际上USB 2.0 的带宽非常紧张,这也是本文的前提之一,USB 3.0看起来缓解了带宽的问题,但是带宽的问题并不是上限不够而是调度芙蓉问题。

为什么我的 USB 驱动程序出现带宽不足错误?

USB 总线上带宽的竞争来自多个来源,包括硬件和软件。 很难准确预测 USB 客户端驱动程序的可用带宽量。 USB 主控制器需要一定数量的带宽来运行。 所需的量取决于控制器是否高速。 它因系统而异。 高速运行的 USB 集线器有时必须转换高速上游端口与下游低速设备之间的事务,并且此转换过程会消耗带宽。 但是,事务转换是否需要带宽取决于连接的设备类型和设备树的拓扑。

带宽资源最严重的压力通常来自垄断带宽的 USB 客户端驱动程序。 系统按先到先得的原则分配带宽。 如果加载的第一个 USB 驱动程序请求所有可用带宽,则以后加载的 USB 驱动程序不允许其设备的任何带宽。 系统无法配置设备,也无法枚举该设备。 由于枚举失败的原因不明显,因此用户体验不佳。

有时,客户端驱动程序会通过高速中断传输耗尽可用带宽。 但到目前为止,最常见的情况是客户端驱动程序为常量传输分配过多带宽,但无法及时释放带宽。 系统保留分配的带宽,直到请求它的驱动程序通过打开另一个端点关闭其端点,或者删除为其分配带宽的设备。 系统不为批量传输分配有保证的带宽,因此批量传输绝不是枚举失败的原因。 但是,大容量传输设备的性能取决于为定期 (常时等时等和中断) 传输的设备分配的带宽量。

USB 2.0 规范要求常量设备在其默认接口设置上具有零带宽端点。 这可确保在函数驱动程序打开非默认接口之前不会为设备保留任何带宽,这有助于防止在设备配置期间因带宽请求过多而导致的枚举失败。 它不会阻止客户端驱动程序在配置其设备后分配过多的带宽,从而阻止其他设备正常运行。

正确带宽管理的关键是,系统中执行常量传输的每个 USB 设备都必须为包含常量端点的每个接口提供多个备用 (Alt) 设置,并且客户端驱动程序必须明智地使用这些 Alt 设置。 客户端驱动程序应首先请求具有最高带宽的接口设置。 如果请求失败,客户端驱动程序应以越来越小的带宽请求接口设置,直到请求成功。

例如,假设网络摄像头设备具有以下接口:

接口 0 (默认接口设置:默认设置中没有具有非零常时等量带宽的端点)

常量端点 1:最大数据包大小 = 0 字节

常量端点 2:最大数据包大小 = 0 字节

接口 0 Alt 设置 1

常量端点 1:最大数据包大小 = 256 字节

常量端点2:最大数据包大小 = 256 字节

接口 0 Alt 设置 2

常量端点 1:最大数据包大小 = 512 字节

常量端点 2:最大数据包大小 = 512 字节

网络摄像头的驱动程序将网络摄像头配置为在初始化时使用默认接口设置。 默认设置没有常时常量带宽,因此在初始化期间使用默认设置可以避免网络摄像头由于常量带宽请求失败而无法枚举的危险。

当客户端驱动程序准备好执行常时等量传输时,它应尝试使用 Alt 设置 2,因为 Alt 设置 2 具有最大的数据包大小。 如果请求失败,驱动程序可以使用 Alt 设置 1 进行第二次尝试。 由于 Alt 设置 1 需要的带宽较少,因此即使第一个请求失败,此请求也可能成功。 多个 Alt 设置允许驱动程序在放弃之前进行多次尝试。

网络摄像头变为空闲后,可以通过再次选择默认设置,将分配的带宽返回到可用带宽池。

用户可以通过在 Windows 设备管理器 中检查控制器的属性来查看 USB 控制器分配了多少带宽。 选择控制器的属性,然后在“高级”选项卡下查看。此读数并不指示 USB 集线器为事务转换分配了多少带宽。

报告 USB 控制器带宽使用情况的设备管理器功能在 Windows XP 中无法正常工作。

USB 传输和数据包大小
最大传输大小

最大传输大小指定 USB 驱动程序堆栈中的硬编码限制。 低于这些限制的传输大小可能会因为系统资源限制而失败。 若要避免这些类型的故障并确保所有 Windows 版本的兼容性,请避免使用大型传输大小进行 USB 传输。

USBD_PIPE_INFORMATION 结构的 MaximumTransferSize 成员已过时。 USB 驱动程序堆栈忽略复合和非复合设备的 MaximumTransferSize 中的值。

在 Windows 2000 中,USB 驱动程序堆栈将 MaximumTransferSize 初始化为 USBD_DEFAULT_MAXIMUM_TRANSFER_SIZE。 客户端驱动程序可以在配置设备时设置较小的值。 对于复合设备,每个函数的客户端驱动程序只能更改非默认接口设置中管道的 MaximumTransferSize 。

USB 传输大小受以下限制:

使用 MaximumTransferSize 限制传输大小不会直接影响设备消耗的带宽。 客户端驱动程序必须更改接口设置或限制USBD_PIPE_INFORMATION的 MaximumPacketSize 成员中设置的最大数据包大小。

最大数据包大小

最大数据包大小由端点描述符的 wMaxPacketSize 字段定义。 客户端驱动程序可以在对设备的选择接口请求中调节 USB 数据包大小。 更改此值不会更改设备上的 wMaxPacketSize 。

在请求的 URB 中是管道 的USBD_PIPE_INFORMATION 结构。 在该结构中,

  • 修改 USBD_PIPE_INFORMATION 结构的 MaximumPacketSize 成员。 将其设置为小于或等于设备固件中为当前接口设置定义的 wMaxPacketSize 的值。
  • 在 PipeFlags 成员USBD_PIPE_INFORMATION结构中设置 USBD_PF_CHANGE_MAX_PACKET 标志。
读取传输缓冲区的最大数据包大小限制

当客户端驱动程序发出读取请求时,传输缓冲区必须是最大数据包大小的倍数。 即使驱动程序所需的数据小于最大数据包大小,它仍必须请求整个数据包。 当设备发送的数据包小于最大大小 (短数据包) 时,表示传输已完成。

在较旧的控制器上,客户端驱动程序可以重写该行为。 在数据传输 URB 的 TransferFlags 成员中,客户端驱动程序必须设置 USBD_SHORT_TRANSFER_OK 标志。 该标志允许设备发送小于 wMaxPacketSize 的数据包。

在 xHCI 主控制器上,USBD_SHORT_TRANSFER_OK忽略批量端点和中断端点。 在 EHCI 控制器上传输短数据包不会导致错误情况。

在 EHCI 主控制器上,对于批量端点和中断端点,将忽略USBD_SHORT_TRANSFER_OK。

在 UHCI 和 OHCI 主机控制器上,如果未为批量传输或中断传输设置USBD_SHORT_TRANSFER_OK,则短数据包传输将停止端点,并返回传输的错误代码。

使用短数据包分隔写入传输

USB 驱动程序堆栈驱动程序在写入设备时对数据包大小施加的限制与从设备读取时施加的限制不同。 某些客户端驱动程序必须频繁传输少量的控制数据,以管理其设备。 在这种情况下,将数据传输限制为统一大小的数据包是不切实际的。 因此,在数据写入期间,驱动程序堆栈不会为大小小于端点最大大小的数据包分配任何特殊意义。 这允许客户端驱动程序将设备的大型传输分解为多个大小小于或等于最大值的多个 URB。

驱动程序必须使用小于最大大小的数据包结束传输,或使用零长度的数据包分隔传输结束。 在驱动程序发送小于 wMaxPacketSize 的数据包之前,传输才完成。 如果传输大小正好是最大值的倍数,驱动程序必须发送零长度分隔数据包才能显式终止传输。

根据 USB 规范的要求,客户端驱动程序负责使用零长度数据包分隔数据传输。 USB 驱动程序堆栈不会自动生成这些数据包。

使用小于 wMaxPacketSize 的数据包分隔 USB 数据传输

合规的 USB 2.0 和 USB 1.1 驱动程序必须传输最大大小的数据包 (wMaxPacketSize) ,然后以小于最大大小的数据包结束传输,或使用零长度数据包分隔传输结束。 在驱动程序发送小于 wMaxPacketSize 的数据包之前,传输才完成。 如果传输大小正好是最大值的倍数,驱动程序必须发送零长度分隔数据包才能显式终止传输

设备驱动程序负责根据 USB 规范的要求使用零长度数据包分隔数据传输。 系统 USB 堆栈不会自动生成这些数据包。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/43971.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python面试宝典第9题:买卖股票

题目 给定一个整型数组,它的第i个元素是一支给定股票第i天的价格。如果最多只允许完成一笔交易(即买入和卖出一支股票一次),设计一个算法来计算你所能获取的最大利润。注意:你不能在买入股票前卖出股票。 示例 1&#…

LabVIEW平台从离散光子到连续光子的光子计数技术

光子计数技术用于将输入光子数转换为离散脉冲。常见的光子计数器假设光子是离散到达的,记录到来的每一个光子。但是,当两个或多个光子同时到达时,计数器会将其记录为单个脉冲,从而只计数一次。当连续光子到达时,离散光…

python学习-容器类型

列表 列表(list)是一种有序容器,可以向其中添加或删除任意元素. 列表数据类型是一种容器类型,列表中可以存放不同数据类型的值,代码示例如下: 列表中可以实现元素的增、删、改、查。 示例代码如下: 增 …

基于Unity3D的Rokid AR Glass项目开发环境搭建

初识Rokid AR 一、SDK简介二、准备工作1.软件环境2.硬件环境 三、快速接入SDK1.配置Package Manager2.安装UXR2.0 SDK 四、导入官方Demo进行模拟器测试五、Rokid AR系列教程 一、SDK简介 UXR2.0 SDK是Rokid为Unity开发者提供的AR开发工具包,提供空间定位跟踪、双目…

Windows 网络重置及重置网络可能出现的问题( WIFI 没有了 / WLAN 图标消失)

netsh int ip reset 命令是用于重置 Windows 操作系统中的网络设置和配置的命令。 在网络故障排除、修复网络连接问题以及清除可能存在的网络配置冲突时非常有用。 命令详解: netsh: 用于配置各种网络设置 int: 用于管理网络接口 ip: 用于管理网络接口的 IP 配…

学习嵌入式对于学历有要求吗?

学习嵌入式系统开发通常并不对学历有严格的要求,尤其是在技术行业中,实际的技能和经验往往比学历更为重要。我收集归类了一份嵌入式学习包,对于新手而言简直不要太棒,里面包括了新手各个时期的学习方向编程教学、问题视频讲解、毕…

Swift 中 map 和 flatMap 的区别 (入门版)

在 Swift 中,map 和 flatMap 是用于处理集合类型(如数组、字典、集合等)的两个重要方法。尽管它们看起来相似,但它们在处理集合中的元素和结果时有着不同的行为。 map 方法 map 方法会对集合中的每一个元素应用一个变换&#xff…

Ubuntu 24.04 LTS (Linux) 安装二维码生成工具 QRencode 二维码生成和识别

1 Ubuntu 安装 sudo apt update sudo apt-get install qrencode 2 查看版本 qrencode -V 3 生成二维码 qrencode -o test.png http://www.baidu.com 可以下载test.png图片,用手机浏览器扫描下看(⊙﹏⊙)

FPGA 项目菜单功能比较

为了帮助您更好地理解每个FPGA功能模块的实用场合、区别和特点,以下是详细的比较: 功能模块实用场合区别特点FPGA I/O自动控制系统、数据采集系统直接与FPGA板卡上的物理端口交互,配置和使用外部I/O设备灵活配置输入输出端口,支持…

Day62 单调栈part01

LC739每日温度(未掌握) 暴力解法:两层for循环,时间复杂度O(n^2),会超时未掌握原因分析:只想到了从栈顶到栈底是递减的情况,忽略了从栈顶到栈底是递增的情况 因为需要找到一个元素右边第一个更大元素,只有…

寂静孤独的404页面源码

寂静孤独的404页面源码,灯光闪烁动态效果,源码由HTMLCSSJS组成,记事本打开源码文件可以进行内容文字之类的修改,双击html文件可以本地运行效果,也可以上传到服务器里面,重定向这个界面 寂静孤独的404页面源…

【深度学习】PyTorch深度学习笔记01-Overview

参考学习:B站视频【《PyTorch深度学习实践》完结合集】-刘二大人 ------------------------------------------------------------------------------------------------------- 1. 基于规则的深度学习 2. 经典的机器学习——手动提取一些简单的特征 3. 表示学习…

深入理解 LXC (Linux Containers)

目录 引言LXC 的定义LXC 的架构LXC 的工作原理LXC 的应用场景LXC 在 CentOS 上的常见命令实验场景模拟总结 1. 引言 在现代 IT 基础设施中,容器技术已经成为一种重要的应用和部署方式。与虚拟机相比,容器具有更高的效率、更轻量的特性和更快的启动速度…

AI应用观:从“卷模型”到“卷应用”的时代跨越

在2024年世界人工智能大会的舞台上,百度创始人李彦宏的发言如同一股清流,为当前如火如荼的人工智能领域注入了深刻的思考。他提出的“大家不要卷模型,要卷应用”的观点,不仅是对当前AI技术发展趋势的精准洞察,更是对未…

【PB案例学习笔记】-30动态打开窗口

写在前面 这是PB案例学习笔记系列文章的第30篇,该系列文章适合具有一定PB基础的读者。 通过一个个由浅入深的编程实战案例学习,提高编程技巧,以保证小伙伴们能应付公司的各种开发需求。 文章中设计到的源码,小凡都上传到了gite…

Mosh|内连接、外连接、左连接、右连接(未完)

下图取自菜鸟教程,侵权删~ 一、内连接:Inner Joins 模版:SELECT * FROM A JOIN B ON 条件 含义:返回A与B的交集,列为AB列之和 练习:将order_items表和products表连接,返回产品id和…

【普中】基于51单片机的矩阵电子密码锁LCD1602液晶显示 proteus仿真+程序+设计报告+讲解视频

【普中】基于51单片机的矩阵电子密码锁LCD1602液晶显示设计 1.主要功能:讲解视频:2.仿真3. 程序代码4. 设计报告5. 设计资料内容清单&&下载链接资料下载链接: 【普中】基于51单片机的矩阵电子密码锁LCD1602液晶显示设计 ( proteus仿真…

Androidstudio开发,天气预报APP

1.项目功能思维导图 2. 项目涉及到的技术点 数据来源:和风天气API使用okhttp网络请求框架获取api数据使用gson库解析json数据使用RecyclerViewadapter实现未来7天列表展示和天气指数使用PopupMenu 实现弹出选项框使用动画定时器实现欢迎页倒计时和logo动画使用Text…

web 网络安全

Web网络安全是网络安全的一个重要分支,专注于保护Web应用程序、服务和网站免受各种网络威胁。学习Web网络安全涉及多个层面的知识和技能,以下是一些主要的学习领域: 一、XSS攻击 全称::Cross Site Script (跨站脚本&a…

在vue3中,手写父子关联,勾选子级父级关联,取消只取消当前子级,父节点不动

树形控件选择子级勾选父级,以及所有子级, 取消勾选仅取消子级 在项目中,可能会遇到这种场景,比如权限配置的时候,页面权限和菜单权限以tree的形式来配置,而且不用半选,菜单在页面的下面&#xf…