第二十五篇:找微软的麻烦--在微软提供的MUTT中发现的软件与硬件问题

2024-08-29 17:08

本文主要是介绍第二十五篇:找微软的麻烦--在微软提供的MUTT中发现的软件与硬件问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Tools in the MUTT software package

http://msdn.microsoft.com/en-US/library/windows/hardware/dn376875(v=vs.85).aspx



这几天在用微软的MUTT USB Device测试针对于USB3.0高带宽(high bandwidth, 48KB/125us) ISO EP的测试用WDF USB功能驱动.
结果发现MUTT设备中的问题.

微软针对于USB3.0这个新生事物, 提供了四个测试设备, 分别是Super MUTT, MUTT, Super MUTT pack, MUTT pack.
Super MUTT是USB3.0的设备, MUTT是USB2.0
Super MUTT PACK则是一个复合设备, 包括了一个USB3.0的HUB与连在该SUPER SPEED HUB下面的一个USB2.0设备
MUTT Pack也是一个复合设备, 不同于Super MUTT PACK的是它包括一下USB2.0的HUB.

这个问题在Super MUTT上没有发生, 但在其它三种设备上均发生, 即所有的USB2.0设备均有相同的问题.

当我们将这些设备接到EHCI USB HOST上时, 可以看到设备的高带宽ISO EP的描述符:
其中, 它们的ISO IN EP是支持一个service interval (125us) 768*3 BYTES的数据传输的.
------------------------------
USB_ENDPOINT_DESCRIPTOR for Pipe04
bLength = 0x7
bDescriptorType = 0x5 ( USB_ENDPOINT_DESCRIPTOR_TYPE )
bEndpointAddress= 0x8 ( OUTPUT )
bmAttributes= 0x1 ( USB_ENDPOINT_TYPE_ISOCHRONOUS )
wMaxPacketSize= 0x300, decimal 768
High Bandwidth number= 0x2, decimal 2
bInterval = 0x1, decimal 1
------------------------------
USB_ENDPOINT_DESCRIPTOR for Pipe05
bLength = 0x7
bDescriptorType = 0x5 ( USB_ENDPOINT_DESCRIPTOR_TYPE )
bEndpointAddress= 0x86 ( INPUT )
bmAttributes= 0x1 ( USB_ENDPOINT_TYPE_ISOCHRONOUS )
wMaxPacketSize= 0x300, decimal 768
High Bandwidth number= 0x2, decimal 2
bInterval = 0x1, decimal 1
------------------------------

这一点, 在ISO OUT上是正确的行为: 即每一个SERVICE INTERVAL为3笔事务(TRANSACTION)


而在ISO IN上则不正确: 如下图:

这也就导致驱动方面出现数据接收数量为0的情况:

-----------------------------------------------------------------------------------------------------------------------
read-write irp failed with status C0000001

urb header status C0000B00

IsoPacket[0].offset = 0 IsoPacket[0].Length = 0 IsoPacket[0].Status = c0000011

IsoPacket[1].offset = 2304 IsoPacket[1].Length = 0 IsoPacket[1].Status = c0000011

IsoPacket[2].offset = 4608 IsoPacket[2].Length = 0 IsoPacket[2].Status = c0000011

IsoPacket[3].offset = 6912 IsoPacket[3].Length = 0 IsoPacket[3].Status = c0000011

IsoPacket[4].offset = 9216 IsoPacket[4].Length = 0 IsoPacket[4].Status = c0000011
 
IsoPacket[5].offset = 11520 IsoPacket[5].Length = 0 IsoPacket[5].Status = c0000011

IsoPacket[6].offset = 13824 IsoPacket[6].Length = 0 IsoPacket[6].Status = c0000011

IsoPacket[7].offset = 16128 IsoPacket[7].Length = 0 IsoPacket[7].Status = c0000011
-----------------------------------------------------------------------------------------------------------------------


正确的行为的USB TRACE(Lecory Advisor T3)为: (在SUPER MUTT 跑在USB2.0 EHCI HOST上的TRACE)

该问题已经提交给微软的USB TEAM.

第二个问题:
该问题是在2013年八月期间, 在测试USB3.0 XHCI HOST的时候发现的.
测试设备的TOPOLOGY为:

xhci host root hub --> SuperMutt Pack --> SuperMUTT device 1

                                                            --> MUTT device 2

问题的表现形式为, USB3.0的SUPER MUTT device 1在正确的状态下, 是运行在SUPER SPEED MODE下的, 但在运行MUTT TOOL中的 runTest.bat的时候, 会导致SUPER MUTT DEVICE 1降到USB2.0 HIGH SPEED MODE下去.

将该问题提交给微软USB TEAM后, 他们很快给了我回复, 并在几天后, 发现了软件中的问题.
这也就是大家看到的, 在最新版的

Tools in the MUTT software package页面, 更新的内容:

Changes for version 1.9.1

  • In version 1.9 and earlier, on some systems, the SuperMutt device enumerated at high speed (when connected to an xHCI controller) after the system resumed from S4. Version 1.9.1 corrects that issue.
从这两个问题上来看, 微软在软件方面确实非常强悍, 光从一个WDM驱动模型来讲, 就设计得非常完美;在WDDM, AVSTREAM这些DEVICE PORT驱动架构上来讲, 也是非常精妙.

但从微软的硬件方面来讲(虽然这些MUTT设备并非使用微软自己的USB3.0 DEVICE CONTROLLER芯片, 而是CYPRESS的FX3, FX2), 但出现这两个问题,  至少, 在测试方面, 就是不及格的, 即使硬件不是微软自己的东西, 但作为打上MICROSOFT LOGO的测试设备,  实在与微软这样的高大上公司的形象不符.



这篇关于第二十五篇:找微软的麻烦--在微软提供的MUTT中发现的软件与硬件问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1118452

相关文章

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题

《如何解决mysql出现Incorrectstringvalueforcolumn‘表项‘atrow1错误问题》:本文主要介绍如何解决mysql出现Incorrectstringv... 目录mysql出现Incorrect string value for column ‘表项‘ at row 1错误报错

如何解决Spring MVC中响应乱码问题

《如何解决SpringMVC中响应乱码问题》:本文主要介绍如何解决SpringMVC中响应乱码问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring MVC最新响应中乱码解决方式以前的解决办法这是比较通用的一种方法总结Spring MVC最新响应中乱码解

pip无法安装osgeo失败的问题解决

《pip无法安装osgeo失败的问题解决》本文主要介绍了pip无法安装osgeo失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 进入官方提供的扩展包下载网站寻找版本适配的whl文件注意:要选择cp(python版本)和你py

SpringCloud之consul服务注册与发现、配置管理、配置持久化方式

《SpringCloud之consul服务注册与发现、配置管理、配置持久化方式》:本文主要介绍SpringCloud之consul服务注册与发现、配置管理、配置持久化方式,具有很好的参考价值,希望... 目录前言一、consul是什么?二、安装运行consul三、使用1、服务发现2、配置管理四、数据持久化总

解决Java中基于GeoTools的Shapefile读取乱码的问题

《解决Java中基于GeoTools的Shapefile读取乱码的问题》本文主要讨论了在使用Java编程语言进行地理信息数据解析时遇到的Shapefile属性信息乱码问题,以及根据不同的编码设置进行属... 目录前言1、Shapefile属性字段编码的情况:一、Shp文件常见的字符集编码1、System编码

Spring MVC使用视图解析的问题解读

《SpringMVC使用视图解析的问题解读》:本文主要介绍SpringMVC使用视图解析的问题解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring MVC使用视图解析1. 会使用视图解析的情况2. 不会使用视图解析的情况总结Spring MVC使用视图

Redis解决缓存击穿问题的两种方法

《Redis解决缓存击穿问题的两种方法》缓存击穿问题也叫热点Key问题,就是⼀个被高并发访问并且缓存重建业务较复杂的key突然失效了,无数的请求访问会在瞬间给数据库带来巨大的冲击,本文给大家介绍了Re... 目录引言解决办法互斥锁(强一致,性能差)逻辑过期(高可用,性能优)设计逻辑过期时间引言缓存击穿:给

Java程序运行时出现乱码问题的排查与解决方法

《Java程序运行时出现乱码问题的排查与解决方法》本文主要介绍了Java程序运行时出现乱码问题的排查与解决方法,包括检查Java源文件编码、检查编译时的编码设置、检查运行时的编码设置、检查命令提示符的... 目录一、检查 Java 源文件编码二、检查编译时的编码设置三、检查运行时的编码设置四、检查命令提示符