!usb3kd.device_info_from_pdo
!usb3kd.device_info_from_pdo 命令显示有关 USB 3.0 树中 USB 设备的信息。
!usb3kd.device_info_from_pdo DeviceObject
参数
DeviceObject
USB 设备或中心的物理设备对象 (PDO) 的地址。
DLL
Usb3kd.dll
注解
!device_info_from_pdo 和 !ucx_device 都显示有关设备的信息,但显示的信息不同。 !device_info_from_pdo 输出来自 USB 3.0 中心驱动程序的视角,而 !ucx_device 输出来自 USB 主机控制器扩展驱动程序的视角。 例如,!device_info_from_pdo 输出包括有关配置和接口描述符的信息,而 !ucx_device 输出包含有关终结点的信息。
示例
可以从 !usb_tree 输出或各种其他调试器命令中获取 PDO 的地址。 例如,!devnode 命令显示 PDO 的地址。 在以下示例中,USBSTOR 设备节点是 USBHUB3 节点的直接子节点。 USBSTOR 节点的 PDO 地址为 0xfffffa80059c3800。
3: kd> !devnode 0 1 usbhub3
Dumping IopRootDeviceNode (= 0xfffffa8003609cc0)
DevNode 0xfffffa8005981730 for PDO 0xfffffa8004ffc550
InstancePath is "USB\ROOT_HUB30\5&11db9684&0&0"
ServiceName is "USBHUB3"
State = DeviceNodeStarted (0x308)
Previous State = DeviceNodeEnumerateCompletion (0x30d)
DevNode 0xfffffa8005a546a0 for PDO 0xfffffa80059c3800
InstancePath is "USB\VID_125F&PID_312A\09021000000000000342192873"
ServiceName is "USBSTOR"
State = DeviceNodeStarted (0x308)
Previous State = DeviceNodeEnumerateCompletion (0x30d)
DevNode 0xfffffa8005a09730 for PDO 0xfffffa8005b3a650
InstancePath is "USBSTOR\Disk&Ven ...
ServiceName is "disk"
State = DeviceNodeStarted (0x308)
Previous State = DeviceNodeEnumerateCompletion (0x30d)
现在,可以将 PDO 的地址传递给 !usb3kd.device_info_from_pdo 命令。
3: kd> !device_info_from_pdo 0xfffffa80059c3800
## Dumping Device Information fffffa80059c3800
-------------------------------------------
!devobj 0xfffffa8004ffc550 (Root HUB)
!device_info 0xfffffa8005abd0c0 (dt usbhub3!_DEVICE_CONTEXT 0xfffffa8005abd0c0)
dt USBHUB3!_DEVICE_CONTEXT 0xfffffa8005abd0c0
dt USBHUB3!_HUB_PDO_CONTEXT 0xfffffa8005b118d0
!idle_info 0xfffffa8005b11920 (dt USBHUB3!_ISM_CONTEXT 0xfffffa8005b11920)
Parent !hub_info 0xfffffa8005ad92d0 (dt USBHUB3!_HUB_FDO_CONTEXT 0xfffffa8005ad92d0)
!port_info 0xfffffa8005abe0c0 (dt USBHUB3!_PORT_CONTEXT 0xfffffa8005abe0c0)
!ucx_device 0xfffffa8005992840 !xhci_deviceslots 0xfffffa80051d1940 1
LPMState: U1IsEnabledForUpStreamPort U2IsEnabledForUpStreamPort U1Timeout: 38, U2Timeout: 3
DeviceFlags: HasContainerId NoBOSContainerId Removable HasSerialNumber MsOsDescriptorNotSupported NoWakeUpSupport DeviceIsSuperSpeedCapable
DeviceHackFlags: WillDisableOnSoftRemove SkipSetIsochDelay WillResetOnResumeS0 DisableOnSoftRemove
Descriptors:
dt _USB_CONFIGURATION_DESCRIPTOR 0xfffffa80053f9250
dt _USB_INTERFACE_DESCRIPTOR 0xfffffa80053f9259
ProductId: ...
DeviceDescriptor: VID ...
UcxRequest: !wdfrequest 0x57ffa662948,
ControlRequest: !wdfrequest 0x57ffa667798, !irp 0xfffffa8005997650 !urb 0xfffffa8005abd1c0, NumberOfBytes 0
Device working at SuperSpeed
Current Device State: ConfiguredInD0
Device State History: <Event> NewState (<Operation>(),..) :
[16] <Yes> ConfiguredInD0
...
Device Event History:
[10] TransferSuccess
...
下面的示例显示了 !usb_tree 命令的一些输出。 可以看到其中一个子设备节点的 PDO 地址作为 !devstack 命令的参数。 (!devstack fffffa80059c3800)
3: kd> !usb_tree
## Dumping HUB Tree - !drvObj 0xfffffa800597f770
--------------------------------------------
Topology
--------
1) !xhci_info 0xfffffa80051d1940 ... - PCI: VendorId ...
!hub_info 0xfffffa8005ad92d0 (ROOT)
!port_info 0xfffffa8005a5ca80 !device_info 0xfffffa8005b410c0 Desc: <none> Speed: High
...
## Enumerated Device List
----------------------
...
2) !device_info 0xfffffa8005abd0c0, !devstack fffffa80059c3800
Current Device State: ConfiguredInD0
Desc: ... Flash Drive
USB\VID_...
!ucx_device 0xfffffa8005992840 !xhci_deviceslots 0xfffffa80051d1940 1