| #pragma once |
| |
| #define _HUBBUSIF_ |
| |
| #include "usbdi.h" |
| |
| #if (NTDDI_VERSION >= NTDDI_WINXP) |
| |
| #if !defined(_USBBUSIF_) |
| typedef PVOID PUSB_DEVICE_HANDLE; |
| #endif |
| |
| typedef struct _ROOTHUB_PDO_EXTENSION { |
| ULONG Signature; |
| } ROOTHUB_PDO_EXTENSION, *PROOTHUB_PDO_EXTENSION; |
| |
| #define USBD_DEVHACK_SLOW_ENUMERATION 0x00000001 |
| #define USBD_DEVHACK_DISABLE_SN 0x00000002 |
| #define USBD_DEVHACK_SET_DIAG_ID 0x00000004 |
| |
| #ifndef USB_BUSIFFN |
| #if defined(_ARM_) |
| #define USB_BUSIFFN |
| #else |
| #define USB_BUSIFFN __stdcall |
| #endif |
| #endif |
| |
| #define CD_ERR_V1 0x00000001 |
| |
| #define ID_ERR_V1 0x00000001 |
| |
| #define USBD_KEEP_DEVICE_DATA 0x00000001 |
| #define USBD_MARK_DEVICE_BUSY 0x00000002 |
| |
| #define USB_IDLE_NOT_READY 0 |
| #define USB_IDLE_READY 1 |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_CREATE_USB_DEVICE ( |
| IN PVOID BusContext, |
| OUT PUSB_DEVICE_HANDLE *NewDeviceHandle, |
| IN PUSB_DEVICE_HANDLE HubDeviceHandle, |
| IN USHORT PortStatus, |
| IN USHORT PortNumber); |
| |
| typedef USB_BUSIFFN_CREATE_USB_DEVICE *PUSB_BUSIFFN_CREATE_USB_DEVICE; |
| |
| typedef enum _USBPORT_CREATEDEV_ERROR { |
| CreateDevErrNotSet = 0, |
| CreateDevBadHubDevHandle, |
| CreateDevFailedAllocDevHandle, |
| CreateDevFailedOpenEndpoint, |
| CreateDevFailedAllocDsBuff, |
| CreateDevFailedGetDs, |
| CreateDevTtNotFound, |
| CreateDevBadDevHandlePtr |
| } USBPORT_CREATEDEV_ERROR; |
| |
| typedef struct _USB_CD_ERROR_INFORMATION { |
| ULONG Version; |
| USBPORT_CREATEDEV_ERROR PathError; |
| ULONG UlongArg1; |
| ULONG UlongArg2; |
| NTSTATUS NtStatus; |
| UCHAR XtraInfo[64]; |
| } USB_CD_ERROR_INFORMATION, *PUSB_CD_ERROR_INFORMATION; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_CREATE_USB_DEVICE_EX ( |
| IN PVOID BusContext, |
| OUT PUSB_DEVICE_HANDLE *NewDeviceHandle, |
| IN PUSB_DEVICE_HANDLE HsHubDeviceHandle, |
| IN USHORT PortStatus, |
| IN USHORT PortNumber, |
| OUT PUSB_CD_ERROR_INFORMATION CdErrorInfo, |
| IN USHORT TtPortNumber); |
| |
| typedef USB_BUSIFFN_CREATE_USB_DEVICE_EX *PUSB_BUSIFFN_CREATE_USB_DEVICE_EX; |
| |
| typedef struct _USB_PORT_PATH { |
| ULONG PortPathDepth; |
| ULONG PortPath[6]; |
| } USB_PORT_PATH, *PUSB_PORT_PATH; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_CREATE_USB_DEVICE_V7 ( |
| IN PVOID BusContext, |
| OUT PUSB_DEVICE_HANDLE *NewDeviceHandle, |
| IN PUSB_DEVICE_HANDLE HsHubDeviceHandle, |
| IN USHORT PortStatus, |
| IN PUSB_PORT_PATH PortPath, |
| OUT PUSB_CD_ERROR_INFORMATION CdErrorInfo, |
| IN USHORT TtPortNumber, |
| IN PDEVICE_OBJECT PdoDeviceObject, |
| IN PUNICODE_STRING PhysicalDeviceObjectName); |
| |
| typedef USB_BUSIFFN_CREATE_USB_DEVICE_V7 *PUSB_BUSIFFN_CREATE_USB_DEVICE_V7; |
| |
| typedef enum _USBPORT_INITDEV_ERROR { |
| InitDevErrNotSet = 0, |
| InitDevFailedSetAddress, |
| InitDevFailedPokeEndpoint, |
| InitDevBadDeviceDescriptor |
| } USBPORT_INITDEV_ERROR; |
| |
| typedef struct _USB_ID_ERROR_INFORMATION { |
| ULONG Version; |
| USBPORT_INITDEV_ERROR PathError; |
| ULONG Arg1; |
| ULONG UsbAddress; |
| NTSTATUS NtStatus; |
| USBD_STATUS UsbdStatus; |
| UCHAR XtraInfo[64]; |
| } USB_ID_ERROR_INFORMATION, *PUSB_ID_ERROR_INFORMATION; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_INITIALIZE_USB_DEVICE ( |
| IN PVOID BusContext, |
| IN OUT PUSB_DEVICE_HANDLE DeviceHandle); |
| |
| typedef USB_BUSIFFN_INITIALIZE_USB_DEVICE *PUSB_BUSIFFN_INITIALIZE_USB_DEVICE; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_INITIALIZE_USB_DEVICE_EX ( |
| IN PVOID BusContext, |
| IN OUT PUSB_DEVICE_HANDLE DeviceHandle, |
| OUT PUSB_ID_ERROR_INFORMATION IdErrInfo); |
| |
| typedef USB_BUSIFFN_INITIALIZE_USB_DEVICE_EX *PUSB_BUSIFFN_INITIALIZE_USB_DEVICE_EX; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_REMOVE_USB_DEVICE ( |
| IN PVOID BusContext, |
| IN OUT PUSB_DEVICE_HANDLE DeviceHandle, |
| IN ULONG Flags); |
| |
| typedef USB_BUSIFFN_REMOVE_USB_DEVICE *PUSB_BUSIFFN_REMOVE_USB_DEVICE; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_GET_USB_DESCRIPTORS ( |
| IN PVOID BusContext, |
| IN OUT PUSB_DEVICE_HANDLE DeviceHandle, |
| OUT PUCHAR DeviceDescriptorBuffer, |
| IN OUT PULONG DeviceDescriptorBufferLength, |
| OUT PUCHAR ConfigDescriptorBuffer, |
| IN OUT PULONG ConfigDescriptorBufferLength); |
| |
| typedef USB_BUSIFFN_GET_USB_DESCRIPTORS *PUSB_BUSIFFN_GET_USB_DESCRIPTORS; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_RESTORE_DEVICE ( |
| IN PVOID BusContext, |
| IN OUT PUSB_DEVICE_HANDLE OldDeviceHandle, |
| IN OUT PUSB_DEVICE_HANDLE NewDeviceHandle); |
| |
| typedef USB_BUSIFFN_RESTORE_DEVICE *PUSB_BUSIFFN_RESTORE_DEVICE; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_GET_POTRTHACK_FLAGS ( |
| IN PVOID BusContext, |
| IN OUT PULONG Flags); |
| |
| typedef USB_BUSIFFN_GET_POTRTHACK_FLAGS *PUSB_BUSIFFN_GET_POTRTHACK_FLAGS; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_GET_DEVICE_INFORMATION ( |
| IN PVOID BusContext, |
| IN PUSB_DEVICE_HANDLE DeviceHandle, |
| OUT PVOID DeviceInformationBuffer, |
| IN ULONG DeviceInformationBufferLength, |
| IN OUT PULONG LengthOfDataCopied); |
| |
| typedef USB_BUSIFFN_GET_DEVICE_INFORMATION *PUSB_BUSIFFN_GET_DEVICE_INFORMATION; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_GET_CONTROLLER_INFORMATION ( |
| IN PVOID BusContext, |
| IN OUT PVOID ControllerInformationBuffer, |
| IN ULONG ControllerInformationBufferLength, |
| IN OUT PULONG LengthOfDataCopied); |
| |
| typedef USB_BUSIFFN_GET_CONTROLLER_INFORMATION *PUSB_BUSIFFN_GET_CONTROLLER_INFORMATION; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_CONTROLLER_SELECTIVE_SUSPEND ( |
| IN PVOID BusContext, |
| IN BOOLEAN Enable); |
| |
| typedef USB_BUSIFFN_CONTROLLER_SELECTIVE_SUSPEND *PUSB_BUSIFFN_CONTROLLER_SELECTIVE_SUSPEND; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_GET_EXTENDED_HUB_INFO ( |
| IN PVOID BusContext, |
| IN PDEVICE_OBJECT HubPhysicalDeviceObject, |
| IN PVOID HubInformationBuffer, |
| IN ULONG HubInformationBufferLength, |
| OUT PULONG LengthOfDataCopied); |
| |
| typedef USB_BUSIFFN_GET_EXTENDED_HUB_INFO *PUSB_BUSIFFN_GET_EXTENDED_HUB_INFO; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_GET_ROOTHUB_SYM_NAME ( |
| IN PVOID BusContext, |
| IN PVOID HubSymNameBuffer, |
| IN ULONG HubSymNameBufferLength, |
| OUT PULONG HubSymNameActualLength); |
| |
| typedef USB_BUSIFFN_GET_ROOTHUB_SYM_NAME *PUSB_BUSIFFN_GET_ROOTHUB_SYM_NAME; |
| |
| typedef |
| PVOID |
| USB_BUSIFFN |
| USB_BUSIFFN_GET_DEVICE_BUSCONTEXT ( |
| IN PVOID HubBusContext, |
| IN PVOID DeviceHandle); |
| |
| typedef USB_BUSIFFN_GET_DEVICE_BUSCONTEXT *PUSB_BUSIFFN_GET_DEVICE_BUSCONTEXT; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_INITIALIZE_20HUB ( |
| IN PVOID BusContext, |
| IN PUSB_DEVICE_HANDLE HubDeviceHandle, |
| IN ULONG TtCount); |
| |
| typedef USB_BUSIFFN_INITIALIZE_20HUB *PUSB_BUSIFFN_INITIALIZE_20HUB; |
| |
| typedef |
| BOOLEAN |
| USB_BUSIFFN |
| USB_BUSIFFN_IS_ROOT ( |
| IN PVOID BusContext, |
| IN PVOID DeviceObject); |
| |
| typedef USB_BUSIFFN_IS_ROOT *PUSB_BUSIFFN_IS_ROOT; |
| |
| typedef |
| VOID |
| USB_BUSIFFN |
| USB_BUSIFFN_ACQUIRE_SEMAPHORE ( |
| IN PVOID BusContext); |
| |
| typedef USB_BUSIFFN_ACQUIRE_SEMAPHORE *PUSB_BUSIFFN_ACQUIRE_SEMAPHORE; |
| |
| typedef |
| VOID |
| USB_BUSIFFN |
| USB_BUSIFFN_RELEASE_SEMAPHORE ( |
| IN PVOID BusContext); |
| |
| typedef USB_BUSIFFN_RELEASE_SEMAPHORE *PUSB_BUSIFFN_RELEASE_SEMAPHORE; |
| |
| typedef |
| VOID |
| __stdcall |
| RH_INIT_CALLBACK ( |
| IN PVOID CallBackContext); |
| |
| typedef RH_INIT_CALLBACK *PRH_INIT_CALLBACK; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_ROOTHUB_INIT_NOTIFY ( |
| IN PVOID BusContext, |
| IN PVOID CallbackContext, |
| IN PRH_INIT_CALLBACK CallbackRoutine); |
| |
| typedef USB_BUSIFFN_ROOTHUB_INIT_NOTIFY *PUSB_BUSIFFN_ROOTHUB_INIT_NOTIFY; |
| |
| typedef |
| VOID |
| USB_BUSIFFN |
| USB_BUSIFFN_FLUSH_TRANSFERS ( |
| IN PVOID BusContext, |
| IN PVOID DeviceHandle); |
| |
| typedef USB_BUSIFFN_FLUSH_TRANSFERS *PUSB_BUSIFFN_FLUSH_TRANSFERS; |
| |
| typedef |
| ULONG |
| USB_BUSIFFN |
| USB_BUSIFFN_CALC_PIPE_BANDWIDTH ( |
| IN PVOID BusContext, |
| IN PUSBD_PIPE_INFORMATION PipeInfo, |
| IN USB_DEVICE_SPEED DeviceSpeed); |
| |
| typedef USB_BUSIFFN_CALC_PIPE_BANDWIDTH *PUSB_BUSIFFN_CALC_PIPE_BANDWIDTH; |
| |
| typedef |
| VOID |
| USB_BUSIFFN |
| USB_BUSIFFN_SET_BUS_WAKE_MODE ( |
| IN PVOID BusContext, |
| IN ULONG Mode); |
| |
| typedef USB_BUSIFFN_SET_BUS_WAKE_MODE *PUSB_BUSIFFN_SET_BUS_WAKE_MODE; |
| |
| typedef |
| VOID |
| USB_BUSIFFN |
| USB_BUSIFFN_SET_DEVICE_FLAG ( |
| IN PVOID BusContext, |
| IN GUID *DeviceFlagGuid, |
| IN PVOID ValueData, |
| IN ULONG ValueLength); |
| |
| typedef USB_BUSIFFN_SET_DEVICE_FLAG *PUSB_BUSIFFN_SET_DEVICE_FLAG; |
| |
| typedef |
| VOID |
| USB_BUSIFFN |
| USB_BUSIFFN_SET_DEVHANDLE_DATA ( |
| IN PVOID BusContext, |
| IN PVOID DeviceHandle, |
| IN PDEVICE_OBJECT UsbDevicePdo); |
| |
| typedef USB_BUSIFFN_SET_DEVHANDLE_DATA *PUSB_BUSIFFN_SET_DEVHANDLE_DATA; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_TEST_POINT ( |
| IN PVOID BusContext, |
| IN PVOID DeviceHandle, |
| IN ULONG Opcode, |
| IN PVOID TestData); |
| |
| typedef USB_BUSIFFN_TEST_POINT *PUSB_BUSIFFN_TEST_POINT; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_GET_DEVICE_PERFORMANCE_INFO ( |
| IN PVOID BusContext, |
| IN PUSB_DEVICE_HANDLE DeviceHandle, |
| OUT PVOID DeviceInformationBuffer, |
| IN ULONG DeviceInformationBufferLength, |
| IN OUT PULONG LengthOfDataCopied); |
| |
| typedef USB_BUSIFFN_GET_DEVICE_PERFORMANCE_INFO *PUSB_BUSIFFN_GET_DEVICE_PERFORMANCE_INFO; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_WAIT_ASYNC_POWERUP ( |
| IN PVOID BusContext); |
| |
| typedef USB_BUSIFFN_WAIT_ASYNC_POWERUP *PUSB_BUSIFFN_WAIT_ASYNC_POWERUP; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_GET_DEVICE_ADDRESS ( |
| IN PVOID BusContext, |
| IN PUSB_DEVICE_HANDLE DeviceHandle, |
| OUT PUSHORT DeviceAddress); |
| |
| typedef USB_BUSIFFN_GET_DEVICE_ADDRESS *PUSB_BUSIFFN_GET_DEVICE_ADDRESS; |
| |
| typedef |
| VOID |
| USB_BUSIFFN |
| USB_BUSIFFN_DEREF_DEVICE_HANDLE ( |
| IN PVOID BusContext, |
| IN PUSB_DEVICE_HANDLE DeviceHandle, |
| IN PVOID Object, |
| IN ULONG Tag); |
| |
| typedef USB_BUSIFFN_DEREF_DEVICE_HANDLE *PUSB_BUSIFFN_DEREF_DEVICE_HANDLE; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_REF_DEVICE_HANDLE ( |
| IN PVOID BusContext, |
| IN PUSB_DEVICE_HANDLE DeviceHandle, |
| IN PVOID Object, |
| IN ULONG Tag); |
| |
| typedef USB_BUSIFFN_REF_DEVICE_HANDLE *PUSB_BUSIFFN_REF_DEVICE_HANDLE; |
| |
| typedef |
| ULONG |
| USB_BUSIFFN |
| USB_BUSIFFN_SET_DEVICE_HANDLE_IDLE_READY_STATE ( |
| IN PVOID BusContext, |
| IN PUSB_DEVICE_HANDLE DeviceHandle, |
| IN ULONG NewIdleReadyState); |
| |
| typedef USB_BUSIFFN_SET_DEVICE_HANDLE_IDLE_READY_STATE *PUSB_BUSIFFN_SET_DEVICE_HANDLE_IDLE_READY_STATE; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_GET_CONTAINER_ID_FOR_PORT ( |
| IN PVOID BusContext, |
| IN USHORT PortNumber, |
| OUT LPGUID ContainerId); |
| |
| typedef USB_BUSIFFN_GET_CONTAINER_ID_FOR_PORT *PUSB_BUSIFFN_GET_CONTAINER_ID_FOR_PORT; |
| |
| typedef |
| VOID |
| USB_BUSIFFN |
| USB_BUSIFFN_SET_CONTAINER_ID_FOR_PORT ( |
| IN PVOID BusContext, |
| IN USHORT PortNumber, |
| IN LPGUID ContainerId); |
| |
| typedef USB_BUSIFFN_SET_CONTAINER_ID_FOR_PORT *PUSB_BUSIFFN_SET_CONTAINER_ID_FOR_PORT; |
| |
| typedef |
| NTSTATUS |
| USB_BUSIFFN |
| USB_BUSIFFN_ABORT_ALL_DEVICE_PIPES ( |
| IN PVOID BusContext, |
| IN PUSB_DEVICE_HANDLE DeviceHandle); |
| |
| typedef USB_BUSIFFN_ABORT_ALL_DEVICE_PIPES *PUSB_BUSIFFN_ABORT_ALL_DEVICE_PIPES; |
| |
| #define ERRATA_FLAG_RESET_TT_ON_CANCEL 1 |
| #define ERRATA_FLAG_NO_CLEAR_TT_BUFFER_ON_CANCEL 2 |
| |
| #define USB_BUSIF_HUB_VERSION_0 0x0000 |
| #define USB_BUSIF_HUB_VERSION_1 0x0001 |
| #define USB_BUSIF_HUB_VERSION_2 0x0002 |
| #define USB_BUSIF_HUB_VERSION_3 0x0003 |
| #define USB_BUSIF_HUB_VERSION_4 0x0004 |
| #define USB_BUSIF_HUB_VERSION_5 0x0005 |
| #define USB_BUSIF_HUB_VERSION_6 0x0006 |
| #define USB_BUSIF_HUB_VERSION_7 0x0007 |
| |
| #define USB_BUSIF_HUB_MIDUMP_VERSION_0 0x0000 |
| |
| #define USB_BUSIF_HUB_SS_VERSION_0 0x0000 |
| |
| typedef |
| VOID |
| USB_BUSIFFN |
| USB_BUSIFFN_SET_DEVICE_ERRATA_FLAG ( |
| IN PVOID BusContext, |
| IN PUSB_DEVICE_HANDLE DeviceHandle, |
| IN ULONG DeviceErrataFlag); |
| |
| typedef USB_BUSIFFN_SET_DEVICE_ERRATA_FLAG *PUSB_BUSIFFN_SET_DEVICE_ERRATA_FLAG; |
| |
| DEFINE_GUID(USB_BUS_INTERFACE_HUB_GUID, |
| 0xb2bb8c0a, 0x5ab4, 0x11d3, 0xa8, 0xcd, 0x0, 0xc0, 0x4f, 0x68, 0x74, 0x7a); |
| |
| typedef struct _USB_BUS_INTERFACE_HUB_V0 { |
| USHORT Size; |
| USHORT Version; |
| PVOID BusContext; |
| PINTERFACE_REFERENCE InterfaceReference; |
| PINTERFACE_DEREFERENCE InterfaceDereference; |
| } USB_BUS_INTERFACE_HUB_V0, *PUSB_BUS_INTERFACE_HUB_V0; |
| |
| typedef struct _USB_BUS_INTERFACE_HUB_V1 { |
| USHORT Size; |
| USHORT Version; |
| PVOID BusContext; |
| PINTERFACE_REFERENCE InterfaceReference; |
| PINTERFACE_DEREFERENCE InterfaceDereference; |
| PUSB_BUSIFFN_CREATE_USB_DEVICE CreateUsbDevice; |
| PUSB_BUSIFFN_INITIALIZE_USB_DEVICE InitializeUsbDevice; |
| PUSB_BUSIFFN_GET_USB_DESCRIPTORS GetUsbDescriptors; |
| PUSB_BUSIFFN_REMOVE_USB_DEVICE RemoveUsbDevice; |
| PUSB_BUSIFFN_RESTORE_DEVICE RestoreUsbDevice; |
| PUSB_BUSIFFN_GET_POTRTHACK_FLAGS GetPortHackFlags; |
| PUSB_BUSIFFN_GET_DEVICE_INFORMATION QueryDeviceInformation; |
| } USB_BUS_INTERFACE_HUB_V1, *PUSB_BUS_INTERFACE_HUB_V1; |
| |
| typedef struct _USB_BUS_INTERFACE_HUB_V2 { |
| USHORT Size; |
| USHORT Version; |
| PVOID BusContext; |
| PINTERFACE_REFERENCE InterfaceReference; |
| PINTERFACE_DEREFERENCE InterfaceDereference; |
| PUSB_BUSIFFN_CREATE_USB_DEVICE CreateUsbDevice; |
| PUSB_BUSIFFN_INITIALIZE_USB_DEVICE InitializeUsbDevice; |
| PUSB_BUSIFFN_GET_USB_DESCRIPTORS GetUsbDescriptors; |
| PUSB_BUSIFFN_REMOVE_USB_DEVICE RemoveUsbDevice; |
| PUSB_BUSIFFN_RESTORE_DEVICE RestoreUsbDevice; |
| PUSB_BUSIFFN_GET_POTRTHACK_FLAGS GetPortHackFlags; |
| PUSB_BUSIFFN_GET_DEVICE_INFORMATION QueryDeviceInformation; |
| PUSB_BUSIFFN_GET_CONTROLLER_INFORMATION GetControllerInformation; |
| PUSB_BUSIFFN_CONTROLLER_SELECTIVE_SUSPEND ControllerSelectiveSuspend; |
| PUSB_BUSIFFN_GET_EXTENDED_HUB_INFO GetExtendedHubInformation; |
| PUSB_BUSIFFN_GET_ROOTHUB_SYM_NAME GetRootHubSymbolicName; |
| PUSB_BUSIFFN_GET_DEVICE_BUSCONTEXT GetDeviceBusContext; |
| PUSB_BUSIFFN_INITIALIZE_20HUB Initialize20Hub; |
| } USB_BUS_INTERFACE_HUB_V2, *PUSB_BUS_INTERFACE_HUB_V2; |
| |
| typedef struct _USB_BUS_INTERFACE_HUB_V3 { |
| USHORT Size; |
| USHORT Version; |
| PVOID BusContext; |
| PINTERFACE_REFERENCE InterfaceReference; |
| PINTERFACE_DEREFERENCE InterfaceDereference; |
| PUSB_BUSIFFN_CREATE_USB_DEVICE CreateUsbDevice; |
| PUSB_BUSIFFN_INITIALIZE_USB_DEVICE InitializeUsbDevice; |
| PUSB_BUSIFFN_GET_USB_DESCRIPTORS GetUsbDescriptors; |
| PUSB_BUSIFFN_REMOVE_USB_DEVICE RemoveUsbDevice; |
| PUSB_BUSIFFN_RESTORE_DEVICE RestoreUsbDevice; |
| PUSB_BUSIFFN_GET_POTRTHACK_FLAGS GetPortHackFlags; |
| PUSB_BUSIFFN_GET_DEVICE_INFORMATION QueryDeviceInformation; |
| PUSB_BUSIFFN_GET_CONTROLLER_INFORMATION GetControllerInformation; |
| PUSB_BUSIFFN_CONTROLLER_SELECTIVE_SUSPEND ControllerSelectiveSuspend; |
| PUSB_BUSIFFN_GET_EXTENDED_HUB_INFO GetExtendedHubInformation; |
| PUSB_BUSIFFN_GET_ROOTHUB_SYM_NAME GetRootHubSymbolicName; |
| PUSB_BUSIFFN_GET_DEVICE_BUSCONTEXT GetDeviceBusContext; |
| PUSB_BUSIFFN_INITIALIZE_20HUB Initialize20Hub; |
| PUSB_BUSIFFN_ROOTHUB_INIT_NOTIFY RootHubInitNotification; |
| } USB_BUS_INTERFACE_HUB_V3, *PUSB_BUS_INTERFACE_HUB_V3; |
| |
| typedef struct _USB_BUS_INTERFACE_HUB_V4 { |
| USHORT Size; |
| USHORT Version; |
| PVOID BusContext; |
| PINTERFACE_REFERENCE InterfaceReference; |
| PINTERFACE_DEREFERENCE InterfaceDereference; |
| PUSB_BUSIFFN_CREATE_USB_DEVICE CreateUsbDevice; |
| PUSB_BUSIFFN_INITIALIZE_USB_DEVICE InitializeUsbDevice; |
| PUSB_BUSIFFN_GET_USB_DESCRIPTORS GetUsbDescriptors; |
| PUSB_BUSIFFN_REMOVE_USB_DEVICE RemoveUsbDevice; |
| PUSB_BUSIFFN_RESTORE_DEVICE RestoreUsbDevice; |
| PUSB_BUSIFFN_GET_POTRTHACK_FLAGS GetPortHackFlags; |
| PUSB_BUSIFFN_GET_DEVICE_INFORMATION QueryDeviceInformation; |
| PUSB_BUSIFFN_GET_CONTROLLER_INFORMATION GetControllerInformation; |
| PUSB_BUSIFFN_CONTROLLER_SELECTIVE_SUSPEND ControllerSelectiveSuspend; |
| PUSB_BUSIFFN_GET_EXTENDED_HUB_INFO GetExtendedHubInformation; |
| PUSB_BUSIFFN_GET_ROOTHUB_SYM_NAME GetRootHubSymbolicName; |
| PUSB_BUSIFFN_GET_DEVICE_BUSCONTEXT GetDeviceBusContext; |
| PUSB_BUSIFFN_INITIALIZE_20HUB Initialize20Hub; |
| PUSB_BUSIFFN_ROOTHUB_INIT_NOTIFY RootHubInitNotification; |
| PUSB_BUSIFFN_FLUSH_TRANSFERS FlushTransfers; |
| } USB_BUS_INTERFACE_HUB_V4, *PUSB_BUS_INTERFACE_HUB_V4; |
| |
| typedef struct _USB_BUS_INTERFACE_HUB_V5 { |
| USHORT Size; |
| USHORT Version; |
| PVOID BusContext; |
| PINTERFACE_REFERENCE InterfaceReference; |
| PINTERFACE_DEREFERENCE InterfaceDereference; |
| PUSB_BUSIFFN_CREATE_USB_DEVICE CreateUsbDevice; |
| PUSB_BUSIFFN_INITIALIZE_USB_DEVICE InitializeUsbDevice; |
| PUSB_BUSIFFN_GET_USB_DESCRIPTORS GetUsbDescriptors; |
| PUSB_BUSIFFN_REMOVE_USB_DEVICE RemoveUsbDevice; |
| PUSB_BUSIFFN_RESTORE_DEVICE RestoreUsbDevice; |
| PUSB_BUSIFFN_GET_POTRTHACK_FLAGS GetPortHackFlags; |
| PUSB_BUSIFFN_GET_DEVICE_INFORMATION QueryDeviceInformation; |
| PUSB_BUSIFFN_GET_CONTROLLER_INFORMATION GetControllerInformation; |
| PUSB_BUSIFFN_CONTROLLER_SELECTIVE_SUSPEND ControllerSelectiveSuspend; |
| PUSB_BUSIFFN_GET_EXTENDED_HUB_INFO GetExtendedHubInformation; |
| PUSB_BUSIFFN_GET_ROOTHUB_SYM_NAME GetRootHubSymbolicName; |
| PUSB_BUSIFFN_GET_DEVICE_BUSCONTEXT GetDeviceBusContext; |
| PUSB_BUSIFFN_INITIALIZE_20HUB Initialize20Hub; |
| PUSB_BUSIFFN_ROOTHUB_INIT_NOTIFY RootHubInitNotification; |
| PUSB_BUSIFFN_FLUSH_TRANSFERS FlushTransfers; |
| PUSB_BUSIFFN_SET_DEVHANDLE_DATA SetDeviceHandleData; |
| } USB_BUS_INTERFACE_HUB_V5, *PUSB_BUS_INTERFACE_HUB_V5; |
| |
| typedef struct _USB_BUS_INTERFACE_HUB_V6 { |
| USHORT Size; |
| USHORT Version; |
| PVOID BusContext; |
| PINTERFACE_REFERENCE InterfaceReference; |
| PINTERFACE_DEREFERENCE InterfaceDereference; |
| PUSB_BUSIFFN_CREATE_USB_DEVICE_EX CreateUsbDevice; |
| PUSB_BUSIFFN_INITIALIZE_USB_DEVICE_EX InitializeUsbDevice; |
| PUSB_BUSIFFN_GET_USB_DESCRIPTORS GetUsbDescriptors; |
| PUSB_BUSIFFN_REMOVE_USB_DEVICE RemoveUsbDevice; |
| PUSB_BUSIFFN_RESTORE_DEVICE RestoreUsbDevice; |
| PUSB_BUSIFFN_GET_POTRTHACK_FLAGS GetPortHackFlags; |
| PUSB_BUSIFFN_GET_DEVICE_INFORMATION QueryDeviceInformation; |
| PUSB_BUSIFFN_GET_CONTROLLER_INFORMATION GetControllerInformation; |
| PUSB_BUSIFFN_CONTROLLER_SELECTIVE_SUSPEND ControllerSelectiveSuspend; |
| PUSB_BUSIFFN_GET_EXTENDED_HUB_INFO GetExtendedHubInformation; |
| PUSB_BUSIFFN_GET_ROOTHUB_SYM_NAME GetRootHubSymbolicName; |
| PUSB_BUSIFFN_GET_DEVICE_BUSCONTEXT GetDeviceBusContext; |
| PUSB_BUSIFFN_INITIALIZE_20HUB Initialize20Hub; |
| PUSB_BUSIFFN_ROOTHUB_INIT_NOTIFY RootHubInitNotification; |
| PUSB_BUSIFFN_FLUSH_TRANSFERS FlushTransfers; |
| PUSB_BUSIFFN_SET_DEVHANDLE_DATA SetDeviceHandleData; |
| PUSB_BUSIFFN_IS_ROOT HubIsRoot; |
| PUSB_BUSIFFN_ACQUIRE_SEMAPHORE AcquireBusSemaphore; |
| PUSB_BUSIFFN_RELEASE_SEMAPHORE ReleaseBusSemaphore; |
| PUSB_BUSIFFN_CALC_PIPE_BANDWIDTH CaculatePipeBandwidth; |
| PUSB_BUSIFFN_SET_BUS_WAKE_MODE SetBusSystemWakeMode; |
| PUSB_BUSIFFN_SET_DEVICE_FLAG SetDeviceFlag; |
| PUSB_BUSIFFN_TEST_POINT HubTestPoint; |
| PUSB_BUSIFFN_GET_DEVICE_PERFORMANCE_INFO GetDevicePerformanceInfo; |
| PUSB_BUSIFFN_WAIT_ASYNC_POWERUP WaitAsyncPowerUp; |
| PUSB_BUSIFFN_GET_DEVICE_ADDRESS GetDeviceAddress; |
| PUSB_BUSIFFN_REF_DEVICE_HANDLE RefDeviceHandle; |
| PUSB_BUSIFFN_DEREF_DEVICE_HANDLE DerefDeviceHandle; |
| PUSB_BUSIFFN_SET_DEVICE_HANDLE_IDLE_READY_STATE SetDeviceHandleIdleReadyState; |
| } USB_BUS_INTERFACE_HUB_V6, *PUSB_BUS_INTERFACE_HUB_V6; |
| |
| typedef struct _USB_BUS_INTERFACE_HUB_V7 { |
| USHORT Size; |
| USHORT Version; |
| PVOID BusContext; |
| PINTERFACE_REFERENCE InterfaceReference; |
| PINTERFACE_DEREFERENCE InterfaceDereference; |
| PUSB_BUSIFFN_CREATE_USB_DEVICE_EX CreateUsbDevice; |
| PUSB_BUSIFFN_INITIALIZE_USB_DEVICE_EX InitializeUsbDevice; |
| PUSB_BUSIFFN_GET_USB_DESCRIPTORS GetUsbDescriptors; |
| PUSB_BUSIFFN_REMOVE_USB_DEVICE RemoveUsbDevice; |
| PUSB_BUSIFFN_RESTORE_DEVICE RestoreUsbDevice; |
| PUSB_BUSIFFN_GET_POTRTHACK_FLAGS GetPortHackFlags; |
| PUSB_BUSIFFN_GET_DEVICE_INFORMATION QueryDeviceInformation; |
| PUSB_BUSIFFN_GET_CONTROLLER_INFORMATION GetControllerInformation; |
| PUSB_BUSIFFN_CONTROLLER_SELECTIVE_SUSPEND ControllerSelectiveSuspend; |
| PUSB_BUSIFFN_GET_EXTENDED_HUB_INFO GetExtendedHubInformation; |
| PUSB_BUSIFFN_GET_ROOTHUB_SYM_NAME GetRootHubSymbolicName; |
| PUSB_BUSIFFN_GET_DEVICE_BUSCONTEXT GetDeviceBusContext; |
| PUSB_BUSIFFN_INITIALIZE_20HUB Initialize20Hub; |
| PUSB_BUSIFFN_ROOTHUB_INIT_NOTIFY RootHubInitNotification; |
| PUSB_BUSIFFN_FLUSH_TRANSFERS FlushTransfers; |
| PUSB_BUSIFFN_SET_DEVHANDLE_DATA SetDeviceHandleData; |
| PUSB_BUSIFFN_IS_ROOT HubIsRoot; |
| PUSB_BUSIFFN_ACQUIRE_SEMAPHORE AcquireBusSemaphore; |
| PUSB_BUSIFFN_RELEASE_SEMAPHORE ReleaseBusSemaphore; |
| PUSB_BUSIFFN_CALC_PIPE_BANDWIDTH CaculatePipeBandwidth; |
| PUSB_BUSIFFN_SET_BUS_WAKE_MODE SetBusSystemWakeMode; |
| PUSB_BUSIFFN_SET_DEVICE_FLAG SetDeviceFlag; |
| PUSB_BUSIFFN_TEST_POINT HubTestPoint; |
| PUSB_BUSIFFN_GET_DEVICE_PERFORMANCE_INFO GetDevicePerformanceInfo; |
| PUSB_BUSIFFN_WAIT_ASYNC_POWERUP WaitAsyncPowerUp; |
| PUSB_BUSIFFN_GET_DEVICE_ADDRESS GetDeviceAddress; |
| PUSB_BUSIFFN_REF_DEVICE_HANDLE RefDeviceHandle; |
| PUSB_BUSIFFN_DEREF_DEVICE_HANDLE DerefDeviceHandle; |
| PUSB_BUSIFFN_SET_DEVICE_HANDLE_IDLE_READY_STATE SetDeviceHandleIdleReadyState; |
| PUSB_BUSIFFN_CREATE_USB_DEVICE_V7 CreateUsbDeviceV7; |
| PUSB_BUSIFFN_GET_CONTAINER_ID_FOR_PORT GetContainerIdForPort; |
| PUSB_BUSIFFN_SET_CONTAINER_ID_FOR_PORT SetContainerIdForPort; |
| PUSB_BUSIFFN_ABORT_ALL_DEVICE_PIPES AbortAllDevicePipes; |
| PUSB_BUSIFFN_SET_DEVICE_ERRATA_FLAG SetDeviceErrataFlag; |
| } USB_BUS_INTERFACE_HUB_V7, *PUSB_BUS_INTERFACE_HUB_V7; |
| |
| DEFINE_GUID(USB_BUS_INTERFACE_HUB_MINIDUMP_GUID, |
| 0xc5485f21, 0x4e81, 0x4a23, 0xa8, 0xf9, 0xd8, 0x51, 0x8a, 0xf4, 0x5c, 0x38); |
| |
| typedef VOID |
| (USB_BUSIFFN *PUSB_BUSIFFN_SET_MINIDUMP_FLAGS) ( |
| IN PVOID); |
| |
| typedef struct _USB_BUS_INTERFACE_HUB_MINIDUMP { |
| USHORT Size; |
| USHORT Version; |
| PVOID BusContext; |
| PINTERFACE_REFERENCE InterfaceReference; |
| PINTERFACE_DEREFERENCE InterfaceDereference; |
| PUSB_BUSIFFN_SET_MINIDUMP_FLAGS SetUsbPortMiniDumpFlags; |
| } USB_BUS_INTERFACE_HUB_MINIDUMP, *PUSB_BUS_INTERFACE_HUB_MINIDUMP; |
| |
| DEFINE_GUID(USB_BUS_INTERFACE_HUB_SS_GUID, |
| 0xbfc3f363, 0x8ba1, 0x4c7b, 0x97, 0xba, 0x9b, 0x12, 0xb1, 0xca, 0x13, 0x2f); |
| |
| typedef NTSTATUS |
| (USB_BUSIFFN *PUSB_BUSIFFN_SUSPEND_HUB) ( |
| PDEVICE_OBJECT Pdo); |
| |
| typedef NTSTATUS |
| (USB_BUSIFFN *PUSB_BUSIFFN_RESUME_HUB) ( |
| PDEVICE_OBJECT Pdo); |
| |
| typedef struct _USB_BUS_INTERFACE_HUB_SELECTIVE_SUSPEND { |
| USHORT Size; |
| USHORT Version; |
| PVOID BusContext; |
| PINTERFACE_REFERENCE InterfaceReference; |
| PINTERFACE_DEREFERENCE InterfaceDereference; |
| PUSB_BUSIFFN_SUSPEND_HUB SuspendHub; |
| PUSB_BUSIFFN_RESUME_HUB ResumeHub; |
| } USB_BUS_INTERFACE_HUB_SELECTIVE_SUSPEND, *PUSB_BUS_INTERFACE_HUB_SELECTIVE_SUSPEND; |
| |
| #include <pshpack1.h> |
| |
| typedef struct _USB_PIPE_INFORMATION_0 { |
| USB_ENDPOINT_DESCRIPTOR EndpointDescriptor; |
| UCHAR ED_Pad[1]; |
| ULONG ScheduleOffset; |
| } USB_PIPE_INFORMATION_0, *PUSB_PIPE_INFORMATION_0; |
| |
| typedef struct _USB_LEVEL_INFORMATION { |
| ULONG InformationLevel; |
| ULONG ActualLength; |
| } USB_LEVEL_INFORMATION, *PUSB_LEVEL_INFORMATION; |
| |
| typedef struct _USB_DEVICE_INFORMATION_0 { |
| ULONG InformationLevel; |
| ULONG ActualLength; |
| ULONG PortNumber; |
| USB_DEVICE_DESCRIPTOR DeviceDescriptor; |
| UCHAR DD_pad[2]; |
| UCHAR CurrentConfigurationValue; |
| UCHAR ReservedMBZ; |
| USHORT DeviceAddress; |
| ULONG HubAddress; |
| USB_DEVICE_SPEED DeviceSpeed; |
| USB_DEVICE_TYPE DeviceType; |
| ULONG NumberOfOpenPipes; |
| USB_PIPE_INFORMATION_0 PipeList[1]; |
| } USB_DEVICE_INFORMATION_0, *PUSB_DEVICE_INFORMATION_0; |
| |
| typedef struct _USB_CONTROLLER_INFORMATION_0 { |
| ULONG InformationLevel; |
| ULONG ActualLength; |
| BOOLEAN SelectiveSuspendEnabled; |
| BOOLEAN IsHighSpeedController; |
| } USB_CONTROLLER_INFORMATION_0, *PUSB_CONTROLLER_INFORMATION_0; |
| |
| typedef struct _USB_CONTROLLER_INFORMATION_1 { |
| ULONG InformationLevel; |
| ULONG ActualLength; |
| BOOLEAN SelectiveSuspendEnabled; |
| BOOLEAN IsHighSpeedController; |
| ULONG HcBusNumber; |
| ULONG HcBusDevice; |
| ULONG HcBusFunction; |
| } USB_CONTROLLER_INFORMATION_1, *PUSB_CONTROLLER_INFORMATION_1; |
| |
| typedef struct _USB_EXTPORT_INFORMATION_0 { |
| ULONG PhysicalPortNumber; |
| ULONG PortLabelNumber; |
| USHORT VidOverride; |
| USHORT PidOverride; |
| ULONG PortAttributes; |
| } USB_EXTPORT_INFORMATION_0, *PUSB_EXTPORT_INFORMATION; |
| |
| typedef struct _USB_EXTHUB_INFORMATION_0 { |
| ULONG InformationLevel; |
| ULONG NumberOfPorts; |
| USB_EXTPORT_INFORMATION_0 Port[255]; |
| } USB_EXTHUB_INFORMATION_0, *PUSB_EXTHUB_INFORMATION_0; |
| |
| typedef struct _USB_DEVICE_PERFORMANCE_INFO_0 { |
| ULONG InformationLevel; |
| ULONG ActualLength; |
| ULONG BulkBytes; |
| ULONG BulkUrbCount; |
| ULONG ControlDataBytes; |
| ULONG ControlUrbCount; |
| ULONG IsoBytes; |
| ULONG IsoUrbCount; |
| ULONG InterruptBytes; |
| ULONG InterruptUrbCount; |
| ULONG AllocedInterrupt[6]; |
| ULONG AllocedIso; |
| ULONG Total32secBandwidth; |
| ULONG TotalTtBandwidth; |
| ULONG TotalIsoLatency; |
| ULONG DroppedIsoPackets; |
| ULONG TransferErrors; |
| } USB_DEVICE_PERFORMANCE_INFO_0, *PUSB_DEVICE_PERFORMANCE_INFO_0; |
| |
| #include <poppack.h> |
| |
| #endif /* NTDDI_VERSION >= NTDDI_WINXP */ |
| |