|
|
/*++
Copyright (c) 1996 Microsoft Corporation
Module Name:
usbhub.h
Abstract:
This header define structures and macros for USB Hub driver.
Author:
JohnLee
Environment:
Kernel mode
Revision History:
2-2-96 : created 11-18-96 : jdunn -- added composite device support
--*/
#include <wdmwarn4.h>
#include <usb.h> // usbdi.h has been replaced by usb.h
#include <usbdlib.h>
#include <msosdesc.h> // contains internal definitions for MS OS Desc.
#ifdef USB2
#include "hubbusif.h" // hub service bus interface
#include "usbbusif.h" // usb client service bus interface
#else
#include <hcdi.h>
#include <usbdlibi.h>
#endif
#include <usbioctl.h>
#include <wmidata.h>
#include <enumlog.h>
//enable pageable code
#ifndef PAGE_CODE
#define PAGE_CODE
#endif
#define MULTI_FUNCTION_SUPPORT
#define EARLY_RESOURCE_RELEASE
#define RESUME_PERF
#define USBH_MAX_FUNCTION_INTERFACES 4
#define BcdNibbleToAscii( byte ) (byte)+ '0'
//
// fail reason codes
//
// "Device Failed Enumeration"
// indicates the device failed some part of the enumeration process
// when this happens we cannot tell enough about the device to load
// the appropriate driver.
#define USBH_FAILREASON_ENUM_FAILED 1
// "Device General Failure"
// this is our 'if it does not fit any other catagory' error
#define USBH_FAILREASON_GEN_DEVICE_FAILURE 2
// "Device Caused Overcurrent"
// if a hub supports per port power switching and the device
// causes an overcurrent condition (over-current is like blowing
// a fuse) the we report this error.
#define USBH_FAILREASON_PORT_OVERCURRENT 3
// "Not Enough Power"
// indicates that the device requested a configuration that requires
// more power than the hub can provide.
#define USBH_FAILREASON_NOT_ENOUGH_POWER 4
// "Hub General failure"
// if the hub starts failing transfer requests the driver will
// disable it and report this error.
#define USBH_FAILREASON_HUB_GENERAL_FAILURE 5
// "Cannot connect more than five hubs"
#define USBH_FAILREASON_MAXHUBS_CONNECTED 6
// "An overcurrent condition has disabled the hub"
// if a device generates overcurrent and the hub implements
// gang power switching the entire hub will be disabled and
// this error reported.
#define USBH_FAILREASON_HUB_OVERCURRENT 7
//
// Struc definitions
//
//
// Work item
//
#define USBH_WKFLAG_REQUEST_RESET 0x00000001
typedef struct _USBH_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; ULONG Flags; PVOID Context; struct _DEVICE_EXTENSION_HUB *DeviceExtensionHub; KDPC Dpc; KTIMER Timer; UCHAR Data[0]; } USBH_WORK_ITEM, *PUSBH_WORK_ITEM;
typedef struct _USBH_RESET_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; struct _DEVICE_EXTENSION_PORT *DeviceExtensionPort; PIRP Irp; } USBH_RESET_WORK_ITEM, *PUSBH_RESET_WORK_ITEM;
typedef struct _USBH_COMP_RESET_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; struct _DEVICE_EXTENSION_PARENT *DeviceExtensionParent; } USBH_COMP_RESET_WORK_ITEM, *PUSBH_COMP_RESET_WORK_ITEM;
typedef struct _USBH_BANDWIDTH_TIMEOUT_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; struct _DEVICE_EXTENSION_PORT *DeviceExtensionPort; } USBH_BANDWIDTH_TIMEOUT_WORK_ITEM, *PUSBH_BANDWIDTH_TIMEOUT_WORK_ITEM;
typedef struct _USBH_COMP_RESET_TIMEOUT_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; struct _DEVICE_EXTENSION_PARENT *DeviceExtensionParent; } USBH_COMP_RESET_TIMEOUT_WORK_ITEM, *PUSBH_COMP_RESET_TIMEOUT_WORK_ITEM;
typedef struct _USBH_SET_POWER_D0_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; struct _DEVICE_EXTENSION_HUB *DeviceExtensionHub; PIRP Irp; } USBH_SET_POWER_D0_WORK_ITEM, *PUSBH_SET_POWER_D0_WORK_ITEM;
typedef struct _USBH_HUB_ESD_RECOVERY_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; struct _DEVICE_EXTENSION_HUB *DeviceExtensionHub; } USBH_HUB_ESD_RECOVERY_WORK_ITEM, *PUSBH_HUB_ESD_RECOVERY_WORK_ITEM;
typedef struct _USBH_HUB_IDLE_POWER_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; struct _DEVICE_EXTENSION_HUB *DeviceExtensionHub; NTSTATUS ntStatus; } USBH_HUB_IDLE_POWER_WORK_ITEM, *PUSBH_HUB_IDLE_POWER_WORK_ITEM;
typedef struct _USBH_PORT_IDLE_POWER_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; struct _DEVICE_EXTENSION_HUB *DeviceExtensionHub; PIRP Irp; } USBH_PORT_IDLE_POWER_WORK_ITEM, *PUSBH_PORT_IDLE_POWER_WORK_ITEM;
typedef struct _USBH_COMPLETE_PORT_IRPS_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; struct _DEVICE_EXTENSION_HUB *DeviceExtensionHub; LIST_ENTRY IrpsToComplete; NTSTATUS ntStatus; } USBH_COMPLETE_PORT_IRPS_WORK_ITEM, *PUSBH_COMPLETE_PORT_IRPS_WORK_ITEM;
typedef struct _USBH_HUB_ASYNC_POWER_WORK_ITEM { WORK_QUEUE_ITEM WorkQueueItem; struct _DEVICE_EXTENSION_PORT *DeviceExtensionPort; PIRP Irp; UCHAR MinorFunction; } USBH_HUB_ASYNC_POWER_WORK_ITEM, *PUSBH_HUB_ASYNC_POWER_WORK_ITEM;
typedef struct _HUB_TIMEOUT_CONTEXT { PIRP Irp; KEVENT Event; KDPC TimeoutDpc; KTIMER TimeoutTimer; KSPIN_LOCK TimeoutSpin; BOOLEAN Complete; } HUB_TIMEOUT_CONTEXT, *PHUB_TIMEOUT_CONTEXT;
typedef struct _PORT_TIMEOUT_CONTEXT { KDPC TimeoutDpc; KTIMER TimeoutTimer; struct _DEVICE_EXTENSION_PORT *DeviceExtensionPort; BOOLEAN CancelFlag; } PORT_TIMEOUT_CONTEXT, *PPORT_TIMEOUT_CONTEXT;
typedef struct _COMP_RESET_TIMEOUT_CONTEXT { KDPC TimeoutDpc; KTIMER TimeoutTimer; struct _DEVICE_EXTENSION_PARENT *DeviceExtensionParent; BOOLEAN CancelFlag; } COMP_RESET_TIMEOUT_CONTEXT, *PCOMP_RESET_TIMEOUT_CONTEXT;
typedef struct _HUB_ESD_RECOVERY_CONTEXT { KDPC TimeoutDpc; KTIMER TimeoutTimer; struct _DEVICE_EXTENSION_HUB *DeviceExtensionHub; } HUB_ESD_RECOVERY_CONTEXT, *PHUB_ESD_RECOVERY_CONTEXT;
typedef struct _USB_DEVICE_UI_FIRMWARE_REVISION { USHORT Length; WCHAR FirmwareRevisionString[1];
} USB_DEVICE_UI_FIRMWARE_REVISION, *PUSB_DEVICE_UI_FIRMWARE_REVISION;
typedef struct _HUB_STATE { USHORT HubStatus; USHORT HubChange; } HUB_STATE, *PHUB_STATE;
typedef struct _PORT_STATE { USHORT PortStatus; USHORT PortChange; } PORT_STATE, *PPORT_STATE;
//
// Hub and Port status defined below also apply to StatusChnage bits
//
#define HUB_STATUS_LOCAL_POWER 0x01
#define HUB_STATUS_OVER_CURRENT 0x02
#define PORT_STATUS_CONNECT 0x001
#define PORT_STATUS_ENABLE 0x002
#define PORT_STATUS_SUSPEND 0x004
#define PORT_STATUS_OVER_CURRENT 0x008
#define PORT_STATUS_RESET 0x010
#define PORT_STATUS_POWER 0x100
#define PORT_STATUS_LOW_SPEED 0x200
#define PORT_STATUS_HIGH_SPEED 0x400
//
// Port data to describe relevant info about a port
//
// values for PortFlags
// #define PORTFLAG_ 0x00000001
typedef struct _PORT_DATA { PORT_STATE PortState; // the status & change bit mask of the port
PDEVICE_OBJECT DeviceObject; // the PDO
USB_CONNECTION_STATUS ConnectionStatus; // extended port attributes as defined in USB.H
ULONG PortAttributes; // revised port data structure
ULONG PortFlags; } PORT_DATA, *PPORT_DATA;
//
// Define the various device type values. Note that values used by Microsoft
// Corporation are in the range 0-32767, and 32768-65535 are reserved for use
// by customers.
//
#define FILE_DEVICE_USB_HUB 0x00008600
#define USBH_MAX_ENUMERATION_ATTEMPTS 3
//
// Common fields for Pdo and Fdo extensions
//
#define EXTENSION_TYPE_PORT 0x54524f50 // "PORT"
#define EXTENSION_TYPE_HUB 0x20425548 // "HUB "
#define EXTENSION_TYPE_PARENT 0x50525400 // "PRT "
#define EXTENSION_TYPE_FUNCTION 0xfefefeff // ""
typedef struct _USBH_POWER_WORKER { PIRP Irp; WORK_QUEUE_ITEM WorkQueueItem; } USBH_POWER_WORKER, *PUSBH_POWER_WORKER;
typedef struct _DEVICE_EXTENSION_HEADER { ULONG ExtensionType; } DEVICE_EXTENSION_HEADER, *PDEVICE_EXTENSION_HEADER;
typedef struct _DEVICE_EXTENSION_COMMON { PDEVICE_OBJECT FunctionalDeviceObject; // points back to owner device object
PDEVICE_OBJECT PhysicalDeviceObject; // the PDO for this device
PDEVICE_OBJECT TopOfStackDeviceObject; // to of stack passed to adddevice
} DEVICE_EXTENSION_COMMON, *PDEVICE_EXTENSION_COMMON;
// common to FDO for hub and generic parent
typedef struct _DEVICE_EXTENSION_FDO { DEVICE_EXTENSION_HEADER; DEVICE_EXTENSION_COMMON; KEVENT PnpStartEvent; PIRP PowerIrp; #ifdef WMI_SUPPORT
WMILIB_CONTEXT WmiLibInfo; #endif /* WMI_SUPPORT */
} DEVICE_EXTENSION_FDO, *PDEVICE_EXTENSION_FDO;
//
// Device_Extension for HUB
//
typedef struct _DEVICE_EXTENSION_HUB { //
// *** NOTE the first four fields must match
// DEVICE_EXTENSION_FDO
//
DEVICE_EXTENSION_HEADER; DEVICE_EXTENSION_COMMON; KEVENT PnpStartEvent; PIRP PowerIrp; #ifdef WMI_SUPPORT
WMILIB_CONTEXT WmiLibInfo; #endif /* WMI_SUPPORT */
//
// Pdo created by HCD for the root hub
//
PDEVICE_OBJECT RootHubPdo; //
// top of the host controller stack
// typically this is the FDO for the HCD
//
PDEVICE_OBJECT TopOfHcdStackDeviceObject;
ULONG HubFlags;
//
// we use the hub mutex to serialize access to the
// hub ports between ioctls and pnp events
//
ULONG PendingRequestCount; ULONG ErrorCount; HUB_STATE HubState; PIRP Irp;
PIRP PendingWakeIrp; LONG NumberPortWakeIrps; PUCHAR TransferBuffer; ULONG TransferBufferLength; PKEVENT Event;
PUSB_HUB_DESCRIPTOR HubDescriptor; PPORT_DATA PortData; USBD_CONFIGURATION_HANDLE Configuration; PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor;
DEVICE_POWER_STATE DeviceState[PowerSystemMaximum]; SYSTEM_POWER_STATE SystemWake; DEVICE_POWER_STATE DeviceWake; DEVICE_POWER_STATE CurrentPowerState; LONG MaximumPowerPerPort; PORT_STATE PortStateBuffer;
LONG ResetPortNumber; PUSBH_WORK_ITEM WorkItemToQueue;
KEVENT AbortEvent; KEVENT PendingRequestEvent;
//
// we use the hub mutex to serialize access to the
// hub ports between ioctls and pnp events
//
KSEMAPHORE HubMutex; KSEMAPHORE HubPortResetMutex; KSEMAPHORE ResetDeviceMutex;
USB_DEVICE_DESCRIPTOR DeviceDescriptor; USBD_PIPE_INFORMATION PipeInformation; URB Urb;
LONG InESDRecovery;
#ifdef USB2
USB_BUS_INTERFACE_HUB_V5 BusIf; USB_BUS_INTERFACE_USBDI_V2 UsbdiBusIf; #endif
PIRP PendingIdleIrp; USB_IDLE_CALLBACK_INFO IdleCallbackInfo; KEVENT SubmitIdleEvent;
LONG ChangeIndicationWorkitemPending;
LONG WaitWakeIrpCancelFlag; LONG IdleIrpCancelFlag;
KEVENT CWKEvent;
// Only used for the Root Hub!
SYSTEM_POWER_STATE CurrentSystemPowerState;
KSPIN_LOCK CheckIdleSpinLock;
// revised extension
// deleted Pdo list, we use this list to handle
// async deletion of PDOs. Basically these are
// PDO we have not reported gone to PnP yet.
LIST_ENTRY DeletePdoList;
} DEVICE_EXTENSION_HUB, *PDEVICE_EXTENSION_HUB;
#define HUBFLAG_NEED_CLEANUP 0x00000001
#define HUBFLAG_ENABLED_FOR_WAKEUP 0x00000002
#define HUBFLAG_DEVICE_STOPPING 0x00000004
#define HUBFLAG_HUB_FAILURE 0x00000008
#define HUBFLAG_SUPPORT_WAKEUP 0x00000010
#define HUBFLAG_HUB_STOPPED 0x00000020
#define HUBFLAG_HUB_BUSY 0x00000040
#define HUBFLAG_PENDING_WAKE_IRP 0x00000080
#define HUBFLAG_PENDING_PORT_RESET 0x00000100
#define HUBFLAG_HUB_HAS_LOST_BRAINS 0x00000200
#define HUBFLAG_SET_D0_PENDING 0x00000400
#define HUBFLAG_DEVICE_LOW_POWER 0x00000800
#define HUBFLAG_PENDING_IDLE_IRP 0x00001000
#define HUBFLAG_CHILD_DELETES_PENDING 0x00002000
#define HUBFLAG_HUB_GONE 0x00004000
#define HUBFLAG_USB20_HUB 0x00008000
#define HUBFLAG_NEED_IDLE_CHECK 0x00010000
#define HUBFLAG_WW_SET_D0_PENDING 0x00020000
#define HUBFLAG_USB20_MULTI_TT 0x00040000
#define HUBFLAG_POST_ESD_ENUM_PENDING 0x00080000
#define HUBFLAG_OK_TO_ENUMERATE 0x00100000
#define HUBFLAG_IN_IDLE_CHECK 0x00200000
#define HUBFLAG_HIBER 0x00400000
typedef struct _DEVICE_EXTENSION_PARENT { DEVICE_EXTENSION_HEADER; DEVICE_EXTENSION_COMMON;
KEVENT PnpStartEvent; PIRP PowerIrp; #ifdef WMI_SUPPORT
WMILIB_CONTEXT WmiLibInfo; #endif /* WMI_SUPPORT */
PIRP PendingWakeIrp; LONG NumberFunctionWakeIrps; ULONG FunctionCount; PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor; SINGLE_LIST_ENTRY FunctionList; DEVICE_POWER_STATE DeviceState[PowerSystemMaximum]; SYSTEM_POWER_STATE SystemWake; DEVICE_POWER_STATE DeviceWake; DEVICE_POWER_STATE CurrentPowerState; ULONG ParentFlags; BOOLEAN NeedCleanup; UCHAR CurrentConfig; UCHAR Reserved[2]; USB_DEVICE_DESCRIPTOR DeviceDescriptor;
PCOMP_RESET_TIMEOUT_CONTEXT CompResetTimeoutContext; KSEMAPHORE ParentMutex; KSPIN_LOCK ParentSpinLock;
} DEVICE_EXTENSION_PARENT, *PDEVICE_EXTENSION_PARENT;
typedef struct _FUNCTION_INTERFACE { PUSBD_INTERFACE_INFORMATION InterfaceInformation; PUSB_INTERFACE_DESCRIPTOR InterfaceDescriptor; ULONG InterfaceDescriptorLength; } FUNCTION_INTERFACE, *PFUNCTION_INTERFACE;
typedef struct _DEVICE_EXTENSION_FUNCTION { DEVICE_EXTENSION_HEADER;
PDEVICE_EXTENSION_PARENT DeviceExtensionParent; PDEVICE_OBJECT FunctionPhysicalDeviceObject; PIRP WaitWakeIrp; PIRP ResetIrp; ULONG InterfaceCount; ULONG FunctionPdoFlags; SINGLE_LIST_ENTRY ListEntry; USBD_CONFIGURATION_HANDLE ConfigurationHandle; WCHAR UniqueIdString[4]; // room for three unicode digits plus
// NULL
FUNCTION_INTERFACE FunctionInterfaceList[USBH_MAX_FUNCTION_INTERFACES]; } DEVICE_EXTENSION_FUNCTION, *PDEVICE_EXTENSION_FUNCTION;
//
// Device Extension for Port
//
typedef struct _DEVICE_EXTENSION_PORT { DEVICE_EXTENSION_HEADER; PDEVICE_OBJECT PortPhysicalDeviceObject; PDEVICE_EXTENSION_HUB DeviceExtensionHub; USHORT PortNumber; // port you are on on your parent hub.
USHORT SerialNumberBufferLength; PVOID DeviceData; DEVICE_POWER_STATE DeviceState; PIRP WaitWakeIrp; // these flags describe the state of the PDO and
// the capabilities of the device connected
ULONG PortPdoFlags; ULONG DeviceHackFlags;
PWCHAR SerialNumberBuffer;
WCHAR UniqueIdString[4]; // room for three unicode digits plus NULL
UNICODE_STRING SymbolicLinkName; USB_DEVICE_DESCRIPTOR DeviceDescriptor; USB_DEVICE_DESCRIPTOR OldDeviceDescriptor; USB_CONFIGURATION_DESCRIPTOR ConfigDescriptor; USB_INTERFACE_DESCRIPTOR InterfaceDescriptor;
// information returned through WMI
//
ULONG FailReasonId; ULONG PowerRequested; ULONG RequestedBandwidth; ULONG EnumerationFailReason;
PPORT_TIMEOUT_CONTEXT PortTimeoutContext;
UCHAR FeatureDescVendorCode; PIRP IdleNotificationIrp; KSPIN_LOCK PortSpinLock;
DEVICE_CAPABILITIES DevCaps; PDEVICE_EXTENSION_HUB HubExtSave; #ifdef WMI_SUPPORT
WMILIB_CONTEXT WmiLibInfo; #endif /* WMI_SUPPORT */
// revised extension
// Storage for MS Extended Config Descriptor Compatible IDs
UCHAR CompatibleID[8]; UCHAR SubCompatibleID[8];
ULONG PnPFlags;
LIST_ENTRY DeletePdoLink;
} DEVICE_EXTENSION_PORT, *PDEVICE_EXTENSION_PORT;
// values for PNP flags
// #define PDO_PNPFLAG_
#define PDO_PNPFLAG_DEVICE_PRESENT 0x00000001
typedef struct _SERIAL_NUMBER_ENTRY { ULONG Vid; ULONG Pid; PVOID Pdo; } SERIAL_NUMBER_ENTRY, *PSERIAL_NUMBER_ENTRY;
typedef struct _SERIAL_NUMBER_TABLE { ULONG NumEntries; ULONG MaxEntries; PSERIAL_NUMBER_ENTRY Entries; FAST_MUTEX Mutex; } SERIAL_NUMBER_TABLE, * PSERIAL_NUMBER_TABLE;
//
// values for PortPdoFlags
//
#define PORTPDO_DEVICE_IS_HUB 0x00000001
#define PORTPDO_DEVICE_IS_PARENT 0x00000002
#define PORTPDO_DEVICE_ENUM_ERROR 0x00000004
#define PORTPDO_LOW_SPEED_DEVICE 0x00000008
#define PORTPDO_REMOTE_WAKEUP_SUPPORTED 0x00000010
#define PORTPDO_REMOTE_WAKEUP_ENABLED 0x00000020
#define PORTPDO_DELETED_PDO 0x00000040
// revised
// set when the device for a PDO is removed from bus
// (physically detached from hub)
// PnP may or may not know the device is gone.
#define PORTPDO_DELETE_PENDING 0x00000080
#define PORTPDO_NEED_RESET 0x00000100
#define PORTPDO_STARTED 0x00000200
#define PORTPDO_USB20_DEVICE_IN_LEGACY_HUB 0x00000400
#define PORTPDO_SYM_LINK 0x00000800
#define PORTPDO_DEVICE_FAILED 0x00001000
#define PORTPDO_USB_SUSPEND 0x00002000
#define PORTPDO_OVERCURRENT 0x00004000
#define PORTPDO_DD_REMOVED 0x00008000
#define PORTPDO_NOT_ENOUGH_POWER 0x00010000
// revised not used
//#define PORTPDO_PDO_RETURNED 0x00020000
#define PORTPDO_NO_BANDWIDTH 0x00040000
#define PORTPDO_RESET_PENDING 0x00080000
#define PORTPDO_OS_STRING_DESC_REQUESTED 0x00100000
#define PORTPDO_MS_VENDOR_CODE_VALID 0x00200000
#define PORTPDO_IDLE_NOTIFIED 0x00400000
#define PORTPDO_HIGH_SPEED_DEVICE 0x00800000
#define PORTPDO_NEED_CLEAR_REMOTE_WAKEUP 0x01000000
#define PORTPDO_WMI_REGISTERED 0x02000000
#define PORTPDO_VALID_FOR_PNP_FUNCTION 0x04000000
#define PORTPDO_CYCLED 0x08000000
//
// NOTE: this macro will alway inavlidate the device state but
// never change the current "fail reason"
#define HUB_FAILURE(de) \
{ \ de->HubFlags |= HUBFLAG_HUB_FAILURE; \ USBH_KdPrint((1, "'hub failure, VID %x PID %x line %d file %s\n", \ de->DeviceDescriptor.idVendor, \ de->DeviceDescriptor.idProduct, __LINE__, __FILE__)); \ LOGENTRY(LOG_PNP, "HUB!", de, __LINE__, de->HubFlags); \ }
//#define DEVICE_FAILURE(dep) \ // { \ // dep->PortPdoFlags |= PORTPDO_DEVICE_FAILED; \ // USBH_KdPrint((1, "'device failure, VID %x PID %x line %d file %s\n", \ // dep->DeviceDescriptor.idVendor, \ // dep->DeviceDescriptor.idProduct,\ // __LINE__, __FILE__)); \ // LOGENTRY(LOG_PNP, "DEV!", dep, 0, 0); \ // }
#define IS_ROOT_HUB(de) (de->PhysicalDeviceObject == de->RootHubPdo)
#define USBH_IoInvalidateDeviceRelations(devobj, b) \
{ \ LOGENTRY(LOG_PNP, "HUBr", devobj, 0, 0); \ USBH_KdPrint((1, "'IoInvalidateDeviceRelations %x\n", devobj));\ IoInvalidateDeviceRelations(devobj, b); \ }
//
// Length of buffer for Hub and port status are both 4
//
#define STATUS_HUB_OR_PORT_LENGTH 4
//
// Hub Characterics
//
//
// Powere switch mode
//
#define HUB_CHARS_POWER_SWITCH_MODE_MASK 0x0003
#define HUB_CHARS_POWER_SWITCH_GANGED 0x0000 //00
#define HUB_CHARS_POWER_SWITCH_INDIVIDUAL 0x0001 //01
#define HUB_CHARS_POWER_SWITCH_NONE 0x0002 //1X
#define HUB_IS_GANG_POWER_SWITCHED(hc) \
(((hc) & HUB_CHARS_POWER_SWITCH_MODE_MASK) == HUB_CHARS_POWER_SWITCH_GANGED)
#define HUB_IS_NOT_POWER_SWITCHED(hc) \
(((hc) & HUB_CHARS_POWER_SWITCH_NONE) == HUB_CHARS_POWER_SWITCH_NONE)
#define HUB_IS_PORT_POWER_SWITCHED(hc) \
(((hc) & HUB_CHARS_POWER_SWITCH_MODE_MASK) == HUB_CHARS_POWER_SWITCH_INDIVIDUAL)
BOOLEAN IsBitSet( PVOID Bitmap, ULONG PortNumber );
#define PORT_ALWAYS_POWER_SWITCHED(hd, p) \
IsBitSet(&(hd)->bRemoveAndPowerMask[((hd)->bNumberOfPorts)/8 + 1], \ (p))
#define PORT_DEVICE_NOT_REMOVABLE(hd, p) \
IsBitSet(&(hd)->bRemoveAndPowerMask[0], \ (p))
//
// Compound Device
//
#define HUB_CHARS_COMPOUND_DEVICE 0x4
//
// Over Current Protection Mode
//
#define HUB_CHARS_OVERCURRENT_PROTECTION_MODE_MASK 0x18
#define HUB_CHARS_OVERCURRENT_PROTECTION_MODE_GLOBAL 0x0
#define HUB_CHARS_OVERCURRENT_PROTECTION_MODE_INDIVIDUAL 0x8
#define HUB_CHARS_OVERCURRENT_PROTECTION_MODE_NONE 0x10
//
// Request codes, defined in Ch11
//
#define REQUEST_GET_STATUS 0
#define REQUEST_CLEAR_FEATURE 1
#define REQUEST_GET_STATE 2
#define REQUEST_SET_FEATURE 3
#define REQUEST_SET_ADDRESS 5
#define REQUEST_GET_DESCRIPTOR 6
#define REQUEST_SET_DESCRIPTOR 7
#define REQUEST_GET_CONFIGURATION 8
#define REQUEST_SET_CONFIGURATION 9
#define REQUEST_GET_INTERFACE 10
#define REQUEST_SET_INTERFACE 11
#define REQUEST_SYNCH_FRAME 12
//
// These request types can be composed.
// But it is just easy to define them.
//
#define REQUEST_TYPE_CLEAR_HUB_FEATURE 0x20
#define REQUEST_TYPE_CLEAR_PORT_FEATURE 0x23
#define REQUEST_TYPE_GET_BUS_STATE 0xa3
#define REQUEST_TYPE_GET_HUB_DESCRIPTOR 0xa0
#define REQUEST_TYPE_GET_HUB_STATUS 0xa0
#define REQUEST_TYPE_GET_PORT_STATUS 0xa3
#define REQUEST_TYPE_SET_HUB_DESCRIPTOR 0x20
#define REQUEST_TYPE_SET_HUB_FEATURE 0x20
#define REQUEST_TYPE_SET_PORT_FEATURE 0x23
//
// Feature selector, defined in Ch11
//
#define FEATURE_C_HUB_LOCAL_POWER 0
#define FEATURE_C_HUB_OVER_CURRENT 1
#define FEATURE_PORT_CONNECT 0
#define FEATURE_PORT_ENABLE 1
#define FEATURE_PORT_SUSPEND 2
#define FEATURE_PORT_OVER_CURRENT 3
#define FEATURE_PORT_RESET 4
#define FEATURE_PORT_POWER 8
#define FEATURE_PORT_LOW_SPEED 9
#define FEATURE_C_PORT_CONNECT 16
#define FEATURE_C_PORT_ENABLE 17
#define FEATURE_C_PORT_SUSPEND 18
#define FEATURE_C_PORT_OVER_CURRENT 19
#define FEATURE_C_PORT_RESET 20
//----------------------------------------------------------------------------------
// Utility Macros
#define UsbhBuildGetDescriptorUrb(\
pUrb, \ pDeviceData, \ bDescriptorType, \ bDescriptorIndex, \ wLanguageId, \ ulTransferLength, \ pTransferBuffer) \ {\ (pUrb)->UrbHeader.UsbdDeviceHandle = pDeviceData;\ (pUrb)->UrbHeader.Length = (USHORT) sizeof (struct _URB_CONTROL_DESCRIPTOR_REQUEST);\ (pUrb)->UrbHeader.Function = URB_FUNCTION_GET_DESCRIPTOR_FROM_DEVICE;\ (pUrb)->UrbControlDescriptorRequest.DescriptorType = bDescriptorType;\ (pUrb)->UrbControlDescriptorRequest.Index = bDescriptorIndex;\ (pUrb)->UrbControlDescriptorRequest.LanguageId = wLanguageId;\ (pUrb)->UrbControlDescriptorRequest.TransferBufferLength = ulTransferLength;\ (pUrb)->UrbControlDescriptorRequest.TransferBuffer = pTransferBuffer;\ (pUrb)->UrbControlDescriptorRequest.TransferBufferMDL = NULL;\ (pUrb)->UrbControlVendorClassRequest.UrbLink = NULL;\ }
#define UsbhBuildVendorClassUrb(\
pUrb,\ pDeviceData,\ wFunction,\ ulTransferFlags,\ bRequestType,\ bRequest,\ wFeatureSelector,\ wPort,\ ulTransferBufferLength,\ pTransferBuffer)\ {\ (pUrb)->UrbHeader.Length = (USHORT) sizeof( struct _URB_CONTROL_VENDOR_OR_CLASS_REQUEST);\ (pUrb)->UrbHeader.Function = wFunction;\ (pUrb)->UrbHeader.UsbdDeviceHandle = pDeviceData;\ (pUrb)->UrbControlVendorClassRequest.TransferFlags = ulTransferFlags;\ (pUrb)->UrbControlVendorClassRequest.TransferBufferLength = ulTransferBufferLength;\ (pUrb)->UrbControlVendorClassRequest.TransferBuffer = pTransferBuffer;\ (pUrb)->UrbControlVendorClassRequest.TransferBufferMDL = NULL;\ (pUrb)->UrbControlVendorClassRequest.RequestTypeReservedBits = bRequestType;\ (pUrb)->UrbControlVendorClassRequest.Request = bRequest;\ (pUrb)->UrbControlVendorClassRequest.Value = wFeatureSelector;\ (pUrb)->UrbControlVendorClassRequest.Index = wPort;\ (pUrb)->UrbControlVendorClassRequest.UrbLink = NULL;\ }
//----------------------------------------------------------------------------------
//
// string macros. these work with char and wide char strings
//
// Counting the byte count of an ascii string or wide char string
//
#define STRLEN( Length, p )\
{\ int i;\ for ( i=0; (p)[i]; i++ );\ Length = i*sizeof(*p);\ }
//
// copy wide char string
//
#define STRCPY( pDst, pSrc )\
{\ int nLength, i;\ STRLEN( nLength, pSrc );\ nLength /= sizeof( *pSrc );\ for ( i=0; i < nLength; i++ ) pDst[i] = pSrc[i];\ pDst[i] = 0;\ }
//
// concat (wide) char strings
//
#define STRCAT( pFirst, pSecond )\
{\ int j, k;\ int nLength;\ STRLEN( j, pFirst );\ STRLEN( nLength, pSecond );\ j /= sizeof( *pFirst );\ nLength /= sizeof( *pSecond);\ for ( k=0; k < nLength; k++, j++ ) pFirst[j] = pSecond[k];\ pFirst[j] = 0;\ }
//
// append a (wide) char,
//
#define APPEND( pString, ch )\
{\ int nLength;\ STRLEN( nLength, pString );\ nLength /= sizeof( *pString );\ pString[nLength] = ch;\ pString[nLength+1] = 0;\ }
//----------------------------------------------------------------------------------
//
// Debug Macros
//
#ifdef NTKERN
// Win95 only
#define DBGBREAK() _asm {int 3}
#else
#define DBGBREAK() DbgBreakPoint()
#endif
#define USBHUB_HEAP_TAG 0x42554855 //"UHUB"
#define USBHUB_FREE_TAG 0x62756875 //"uhub"
#if DBG
PVOID UsbhGetHeap( IN POOL_TYPE PoolType, IN ULONG NumberOfBytes, IN ULONG Signature, IN PLONG TotalAllocatedHeapSpace );
VOID UsbhRetHeap( IN PVOID P, IN ULONG Signature, IN PLONG TotalAllocatedHeapSpace );
// TEST_TRAP() is a code coverage trap these should be removed
// if you are able to 'g' past the OK
//
// KdTrap() breaks in the debugger on the debug build
// these indicate bugs in client drivers, kernel apis or fatal error
// conditions that should be debugged. also used to mark
// code for features not implemented yet.
//
// KdBreak() breaks in the debugger when in MAX_DEBUG mode
// ie debug trace info is turned on, these are intended to help
// debug drivers devices and special conditions on the
// bus.
ULONG _cdecl USBH_KdPrintX( ULONG l, PCH Format, ... );
#define UsbhExAllocatePool(pt, l) UsbhGetHeap(pt, l, USBHUB_HEAP_TAG, \
&UsbhHeapCount) #define UsbhExFreePool(p) UsbhRetHeap(p, USBHUB_HEAP_TAG, &UsbhHeapCount)
#define DBG_ONLY(s) s
#define USBH_KdPrint(_s_) USBH_KdPrintX _s_
//#define USBH_KdPrintAlways(s) { DbgPrint( "USBH: "); \ // DbgPrint s; \ // }
#ifdef MAX_DEBUG
#define USBH_KdBreak(s) if (USBH_Debug_Trace_Level) { \
DbgPrint( "USBH: "); \ DbgPrint s; \ } \ DBGBREAK(); #else
#define USBH_KdBreak(s)
#endif /* MAX_DEBUG */
#define USBH_KdTrap(s) { DbgPrint( "USBH: ");\
DbgPrint s; \ DBGBREAK(); }
#define TEST_TRAP() { DbgPrint( "USBH: Code coverage trap %s line: %d\n", __FILE__, __LINE__);\
DBGBREAK();} #else // not debug
#define UsbhExAllocatePool(pt, l) ExAllocatePoolWithTag(pt, l, USBHUB_HEAP_TAG)
#define UsbhExFreePool(p) ExFreePool(p)
#define DBG_ONLY(s)
#define USBH_KdPrint(_s_)
#define USBH_KdBreak(s)
#define USBH_KdTrap(s)
//#define USBH_KdPrintAlways(s)
#define TEST_TRAP();
#endif
#ifdef HOST_GLOBALS
#define DECLARE(type, var, init_value ) type var = init_value;
#define DECLARE_NO_INIT(type, var) type var;
#else
#define DECLARE(type, var, init_value ) extern type var;
#define DECLARE_NO_INIT(type, var ) extern type var;
#endif
//----------------------------------------------------------------------------------
//
// Global Variables
//
//
// Remember our driver object
//
DECLARE( PDRIVER_OBJECT, UsbhDriverObject, NULL)
extern PWCHAR GenericUSBDeviceString;
#if DBG
//
// keep track of heap allocations
//
DECLARE( ULONG, UsbhHeapCount, 0)
#define PNP_TEST_FAIL_ENUM 0x00000001
#define PNP_TEST_FAIL_DEV_POWER 0x00000002
#define PNP_TEST_FAIL_HUB_COUNT 0x00000004
#define PNP_TEST_FAIL_HUB 0x00000008
#define PNP_TEST_FAIL_PORT_RESET 0x00000010
#define PNP_TEST_FAIL_WAKE_REQUEST 0x00000020
#define PNP_TEST_FAIL_RESTORE 0x00000040
DECLARE( ULONG, UsbhPnpTest, 0) #endif
//
// The following strings are used to build HardwareId etc.
//
// USB string
//
DECLARE( PWCHAR, pwchUsbSlash, L"USB\\");
// Vendor ID string
//
DECLARE( PWCHAR, pwchVid, L"Vid_");
//
// Product Id string
//
DECLARE( PWCHAR, pwchPid, L"Pid_");
//
// Revision string
//
DECLARE( PWCHAR, pwchRev, L"Rev_");
//
// Device Class string
//
DECLARE( PWCHAR, pwchDevClass, L"DevClass_");
//
// Class string
//
DECLARE( PWCHAR, pwchClass, L"Class_");
//
// Composite
//
DECLARE( PWCHAR, pwchComposite, L"USB\\COMPOSITE");
//
// SubClass string
//
DECLARE( PWCHAR, pwchSubClass, L"SubClass_");
//
// MultiInterface string
//
DECLARE( PWCHAR, pwchMultiInterface, L"USB\\MI");
//
// Device Protocol string
//
DECLARE( PWCHAR, pwchProt, L"Prot_");
DECLARE_NO_INIT( UNICODE_STRING, UsbhRegistryPath);
//
// To set the verbose level of the debug print
//
#ifdef MAX_DEBUG
#define DEBUG3
#endif /* MAX_DEBUG */
#ifdef DEBUG3
DBG_ONLY( DECLARE( ULONG, USBH_Debug_Trace_Level, 3)) #else
#ifdef DEBUG2
DBG_ONLY( DECLARE( ULONG, USBH_Debug_Trace_Level, 2)) #else
#ifdef DEBUG1
DBG_ONLY( DECLARE( ULONG, USBH_Debug_Trace_Level, 1)) #else
DBG_ONLY( DECLARE( ULONG, USBH_Debug_Trace_Level, 0)) #endif // DEBUG1
#endif // DEBUG2
#endif // DEBUG3
#define USBH_DEBUGFLAG_BREAK_PDO_START 0x00000001
DBG_ONLY( DECLARE( ULONG, USBH_Debug_Flags, 0))
#if DBG
VOID UsbhWarning( PDEVICE_EXTENSION_PORT DeviceExtensionPort, PUCHAR Message, BOOLEAN DebugBreak );
#define ASSERT_HUB(de) USBH_ASSERT(EXTENSION_TYPE_HUB == ((PDEVICE_EXTENSION_HUB) de)->ExtensionType)
#define ASSERT_PORT(de) USBH_ASSERT(EXTENSION_TYPE_PORT == ((PDEVICE_EXTENSION_PORT) de)->ExtensionType)
#define ASSERT_FUNCTION(de) USBH_ASSERT(EXTENSION_TYPE_FUNCTION == ((PDEVICE_EXTENSION_FUNCTION) de)->ExtensionType)
#else
#define UsbhWarning(x, y, z)
#define ASSERT_HUB(de)
#define ASSERT_PORT(de)
#define ASSERT_FUNCTION(de)
#endif
#define TO_USB_DEVICE 0
#define TO_USB_INTERFACE 1
#define TO_USB_ENDPOINT 2
//
// maximum number of times we will attempt to reset
// the hub before giving up
//
#define USBH_MAX_ERRORS 3
//----------------------------------------------------------------------------------
//
// Function Prototypes
//
#ifdef USB2
VOID USBH_InitializeUSB2Hub( PDEVICE_EXTENSION_HUB DeviceExtensionHub );
// use version 5
#define PUSB_HUB_BUS_INTERFACE PUSB_BUS_INTERFACE_HUB_V5
#define HUB_BUSIF_VERSION USB_BUSIF_HUB_VERSION_5
NTSTATUS USBHUB_GetBusInterface( IN PDEVICE_OBJECT RootHubPdo, IN PUSB_HUB_BUS_INTERFACE BusInterface );
NTSTATUS USBD_CreateDeviceEx( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN OUT PUSB_DEVICE_HANDLE *DeviceData, IN PDEVICE_OBJECT RootHubPdo, IN ULONG MaxPacketSize_Endpoint0, IN OUT PULONG DeviceHackFlags, IN USHORT PortStatus, IN USHORT PortNumber );
VOID USBHUB_FlushAllTransfers( PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBD_InitializeDeviceEx( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PUSB_DEVICE_HANDLE DeviceData, IN PDEVICE_OBJECT RootHubPdo, IN OUT PUSB_DEVICE_DESCRIPTOR DeviceDescriptor, IN ULONG DeviceDescriptorLength, IN OUT PUSB_CONFIGURATION_DESCRIPTOR ConfigDescriptor, IN ULONG ConfigDescriptorLength );
NTSTATUS USBD_RemoveDeviceEx( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PUSB_DEVICE_HANDLE DeviceData, IN PDEVICE_OBJECT RootHubPdo, IN ULONG Flags );
NTSTATUS USBD_GetDeviceInformationEx( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PUSB_NODE_CONNECTION_INFORMATION_EX DeviceInformation, IN ULONG DeviceInformationLength, IN PUSB_DEVICE_HANDLE DeviceData );
NTSTATUS USBD_MakePdoNameEx( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN OUT PUNICODE_STRING PdoNameUnicodeString, IN ULONG Index );
ULONG USBD_CalculateUsbBandwidthEx( IN ULONG MaxPacketSize, IN UCHAR EndpointType, IN BOOLEAN LowSpeed );
NTSTATUS USBD_RestoreDeviceEx( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN OUT PUSB_DEVICE_HANDLE OldDeviceData, IN OUT PUSB_DEVICE_HANDLE NewDeviceData, IN PDEVICE_OBJECT RootHubPdo );
NTSTATUS USBD_QuerySelectiveSuspendEnabled( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN OUT PBOOLEAN SelectiveSuspendEnabled );
NTSTATUS USBD_SetSelectiveSuspendEnabled( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN BOOLEAN SelectiveSuspendEnabled );
NTSTATUS USBHUB_GetRootHubName( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PVOID Buffer, IN PULONG BufferLength );
//ULONG
//USBD_GetHackFlags(
// IN PDEVICE_EXTENSION_HUB DeviceExtensionHub
// );
#endif
NTSTATUS USBH_SyncResetPort( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber);
NTSTATUS USBH_SyncResetDevice ( IN PDEVICE_OBJECT DeviceObject );
NTSTATUS USBH_SyncResumePort( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber);
NTSTATUS USBH_SyncSuspendPort( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber);
VOID USBH_ProcessHubStateChange( IN PHUB_STATE CurrentHubState, IN PDEVICE_EXTENSION_HUB DeviceExtensionHub);
VOID USBH_ProcessPortStateChange( IN PPORT_STATE CurrentPortState, IN USHORT PortNumber, IN PDEVICE_EXTENSION_HUB DeviceExtensionHub);
NTSTATUS USBH_SyncGetPortStatus( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber, OUT PUCHAR DataBuffer, IN ULONG DataBufferLength);
NTSTATUS USBH_SyncClearPortStatus( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber, IN USHORT Feature);
NTSTATUS USBH_SyncClearHubStatus( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT Feature);
NTSTATUS USBH_SyncEnablePort( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber);
NTSTATUS USBH_SyncPowerOnPort( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber, IN BOOLEAN WaitForPowerGood);
NTSTATUS USBH_SyncPowerOffPort( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber);
NTSTATUS USBH_SyncPowerOnPorts( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub);
NTSTATUS DriverEntry( IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING UniRegistryPath);
NTSTATUS USBH_HubDispatch( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp);
VOID USBH_DriverUnload( IN PDRIVER_OBJECT DriverObject);
VOID UsbhWait( ULONG MiliSeconds);
NTSTATUS USBH_PdoDispatch( PDEVICE_EXTENSION_PORT pDeviceExtensionPort, PIRP pIrp);
NTSTATUS USBH_SyncGetHubDescriptor( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub);
NTSTATUS USBH_SyncGetDeviceConfigurationDescriptor( PDEVICE_OBJECT DeviceObject, PUCHAR DataBuffer, ULONG DataBufferLength, OUT PULONG BytesReturned);
BOOLEAN USBH_ValidateSerialNumberString( PWCHAR DeviceId );
NTSTATUS USBH_CreateDevice( PDEVICE_EXTENSION_HUB DeviceExtensionHub, USHORT PortNumber, USHORT PortStatus, ULONG RetryIteration );
NTSTATUS USBH_FdoSyncSubmitUrb( PDEVICE_OBJECT HubDeviceObject, IN PURB Urb);
NTSTATUS USBH_SyncGetRootHubPdo( IN PDEVICE_OBJECT DeviceObject, IN OUT PDEVICE_OBJECT *RootHubPdo, IN OUT PDEVICE_OBJECT *HcdDeviceObject, IN OUT PULONG Count );
NTSTATUS USBH_AddDevice( IN PDRIVER_OBJECT DriverObject, IN PDEVICE_OBJECT PhysicalDeviceObject);
NTSTATUS USBH_FdoPnP( PDEVICE_EXTENSION_HUB DeviceExtensionHub, PIRP Irp, UCHAR MinorFunction);
NTSTATUS USBH_FdoPower( PDEVICE_EXTENSION_HUB DeviceExtensionHub, PIRP Irp, UCHAR MinorFunction);
NTSTATUS USBH_ChangeIndication( IN PDEVICE_OBJECT PNull, IN PIRP Irp, IN PVOID Context);
VOID USBH_ChangeIndicationWorker( PVOID Context);
NTSTATUS USBH_PassIrp( PIRP Irp, PDEVICE_OBJECT NextDeviceObject);
VOID USBH_CompleteIrp( IN PIRP Irp, IN NTSTATUS NtStatus);
NTSTATUS USBH_SyncDisablePort( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber);
NTSTATUS USBH_SyncGetHubStatus( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, OUT PUCHAR DataBuffer, IN ULONG DataBufferLength);
NTSTATUS USBH_FdoHubStartDevice( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp);
NTSTATUS USBH_ParentFdoStartDevice( IN OUT PDEVICE_EXTENSION_PARENT DeviceExtensionParent, IN PIRP Irp, IN BOOLEAN NewList );
NTSTATUS USBH_ParentDispatch( IN PDEVICE_EXTENSION_PARENT DeviceExtensionParent, IN PIRP Irp );
NTSTATUS USBH_GetConfigurationDescriptor( IN PDEVICE_OBJECT DeviceObject, IN OUT PUSB_CONFIGURATION_DESCRIPTOR *DataBuffer );
PWCHAR USBH_BuildDeviceID( IN USHORT IdVendor, IN USHORT IdProduct, IN LONG MiId, IN BOOLEAN IsHubClass );
PWCHAR USBH_BuildHardwareIDs( IN USHORT IdVendor, IN USHORT IdProduct, IN USHORT BcdDevice, IN LONG MiId, IN BOOLEAN IsHubClass );
PWCHAR USBH_BuildCompatibleIDs( IN PUCHAR CompatibleID, IN PUCHAR SubCompatibleID, IN UCHAR Class, IN UCHAR SubClass, IN UCHAR Protocol, IN BOOLEAN DeviceClass, IN BOOLEAN DeviceIsHighSpeed );
PWCHAR USBH_BuildInstanceID( IN PWCHAR UniqueIdString, IN ULONG Length );
NTSTATUS USBH_GetDeviceDescriptor( IN PDEVICE_OBJECT HubFDO, OUT PUSB_DEVICE_DESCRIPTOR DeviceDescriptor );
NTSTATUS USBH_GetDeviceQualifierDescriptor( IN PDEVICE_OBJECT DevicePDO, OUT PUSB_DEVICE_QUALIFIER_DESCRIPTOR DeviceQualifierDescriptor );
NTSTATUS USBH_FunctionPdoDispatch( IN PDEVICE_EXTENSION_FUNCTION DeviceExtensionFunction, IN PIRP Irp );
NTSTATUS USBH_CloseConfiguration( IN PDEVICE_EXTENSION_FDO DeviceExtensionFdo );
NTSTATUS USBH_IoctlGetNodeInformation( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
NTSTATUS USBH_IoctlGetHubCapabilities( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
NTSTATUS USBH_IoctlGetNodeConnectionInformation( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp, IN BOOLEAN ExApi );
NTSTATUS USBH_IoctlGetDescriptorForPDO( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
NTSTATUS USBH_SyncSubmitUrb( IN PDEVICE_OBJECT DeviceObject, IN PURB Urb );
NTSTATUS USBH_Transact( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PUCHAR DataBuffer, IN ULONG DataBufferLength, IN BOOLEAN DataOutput, IN USHORT Function, IN UCHAR RequestType, IN UCHAR Request, IN USHORT Feature, IN USHORT Port, OUT PULONG BytesTransferred );
NTSTATUS USBH_GetNameFromPdo( IN PDEVICE_OBJECT PdoDeviceObject, IN OUT PUNICODE_STRING DeviceNameUnicodeString );
NTSTATUS USBH_MakeName( PDEVICE_OBJECT PdoDeviceObject, ULONG NameLength, PWCHAR Name, PUNICODE_STRING UnicodeString );
NTSTATUS USBH_FdoStartDevice( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
VOID USBH_QueryCapabilities( IN PDEVICE_OBJECT PdoDeviceObject, IN PDEVICE_CAPABILITIES DeviceCapabilities );
NTSTATUS USBH_FdoStopDevice( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
NTSTATUS USBH_FdoRemoveDevice( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
NTSTATUS USBH_FdoQueryBusRelations( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
VOID UsbhFdoCleanup( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBH_ProcessDeviceInformation( IN OUT PDEVICE_EXTENSION_PORT DeviceExtensionPort );
NTSTATUS USBH_PdoQueryId( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_PdoPnP( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp, IN UCHAR MinorFunction, IN PBOOLEAN CompleteIrp );
NTSTATUS USBH_PdoRemoveDevice( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
NTSTATUS USBH_PdoQueryCapabilities( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_PdoSetPower( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_ParentFdoStopDevice( IN PDEVICE_EXTENSION_PARENT DeviceExtensionParent, IN PIRP Irp );
NTSTATUS USBH_ParentFdoRemoveDevice( IN PDEVICE_EXTENSION_PARENT DeviceExtensionParent, IN PIRP Irp );
VOID UsbhParentFdoCleanup( IN PDEVICE_EXTENSION_PARENT DeviceExtensionParent );
NTSTATUS USBH_ParentQueryBusRelations( IN PDEVICE_EXTENSION_PARENT DeviceExtensionParent, IN PIRP Irp );
NTSTATUS USBH_FunctionPdoQueryId( IN PDEVICE_EXTENSION_FUNCTION DeviceExtensionFunction, IN PIRP Irp );
NTSTATUS USBH_FunctionPdoQueryDeviceText( IN PDEVICE_EXTENSION_FUNCTION DeviceExtensionFunction, IN PIRP Irp );
NTSTATUS USBH_FunctionPdoPnP( IN PDEVICE_EXTENSION_FUNCTION DeviceExtensionFunction, IN PIRP Irp, IN UCHAR MinorFunction, IN OUT PBOOLEAN IrpNeedsCompletion );
NTSTATUS USBH_IoctlGetNodeName( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
BOOLEAN USBH_HubIsBusPowered( IN PDEVICE_OBJECT DeviceObject, IN PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor );
NTSTATUS USBH_SyncGetStatus( IN PDEVICE_OBJECT HubFDO, IN OUT PUSHORT StatusBits, IN USHORT function, IN USHORT Index );
NTSTATUS USBH_GetSerialNumberString( IN PDEVICE_OBJECT DevicePDO, IN OUT PWCHAR *SerialNumberBuffer, IN OUT PUSHORT SerialNumberBufferLength, IN LANGID LanguageId, IN UCHAR StringIndex );
NTSTATUS USBH_SyncGetStringDescriptor( IN PDEVICE_OBJECT DevicePDO, IN UCHAR Index, IN USHORT LangId, IN OUT PUSB_STRING_DESCRIPTOR Buffer, IN ULONG BufferLength, IN PULONG BytesReturned, IN BOOLEAN ExpectHeader );
NTSTATUS USBH_SyncFeatureRequest( IN PDEVICE_OBJECT DeviceObject, IN USHORT FeatureSelector, IN USHORT Index, IN USHORT Target, IN BOOLEAN ClearFeature );
NTSTATUS USBH_PdoIoctlGetPortStatus( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_PdoIoctlEnablePort( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_FdoDeferPoRequestCompletion( IN PDEVICE_OBJECT DeviceObject, IN UCHAR MinorFunction, IN POWER_STATE PowerState, IN PVOID Context, IN PIO_STATUS_BLOCK IoStatus );
NTSTATUS USBH_DeferIrpCompletion( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp, IN PVOID Context );
NTSTATUS USBH_BuildFunctionConfigurationDescriptor( IN PDEVICE_EXTENSION_FUNCTION DeviceExtensionFunction, IN OUT PUCHAR Buffer, IN ULONG BufferLength, OUT PULONG BytesReturned );
NTSTATUS USBH_ResetHub( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBH_ResetDevice( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber, IN BOOLEAN KeepConfiguration, IN ULONG RetryIteration );
NTSTATUS USBH_PdoIoctlResetPort( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_SetPowerD1orD2( IN PIRP Irp, IN PDEVICE_EXTENSION_PORT DeviceExtensionPort );
NTSTATUS USBH_SetPowerD0( IN PIRP Irp, IN PDEVICE_EXTENSION_PORT DeviceExtensionPort );
NTSTATUS USBH_SetPowerD3( IN PIRP Irp, IN PDEVICE_EXTENSION_PORT DeviceExtensionPort );
NTSTATUS USBH_PdoQueryDeviceText( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_CheckDeviceLanguage( IN PDEVICE_OBJECT DevicePDO, IN LANGID LanguageId );
NTSTATUS USBH_PdoPower( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp, IN UCHAR MinorFunction );
NTSTATUS USBH_SubmitInterruptTransfer( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBH_SymbolicLink( BOOLEAN CreateFlag, PDEVICE_EXTENSION_PORT DeviceExtensionPort, LPGUID lpGuid );
NTSTATUS USBH_SyncPowerOffPorts( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBH_RestoreDevice( IN OUT PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN BOOLEAN KeepConfiguration );
NTSTATUS USBH_PnPIrp_Complete( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp, IN PVOID Context );
NTSTATUS USBH_ParentCreateFunctionList( IN PDEVICE_EXTENSION_PARENT DeviceExtensionParent, IN PUSBD_INTERFACE_LIST_ENTRY InterfaceList, IN PURB Urb );
NTSTATUS USBH_PdoStopDevice( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_ChangeIndicationProcessChange( IN PDEVICE_OBJECT PNull, IN PIRP Irp, IN PVOID Context );
NTSTATUS USBH_ChangeIndicationAckChangeComplete( IN PDEVICE_OBJECT PNull, IN PIRP Irp, IN PVOID Context );
NTSTATUS USBH_ChangeIndicationAckChange( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp, IN PURB Urb, IN USHORT Port, IN USHORT FeatureSelector );
NTSTATUS USBH_IoctlGetNodeConnectionDriverKeyName( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
NTSTATUS USBH_FdoSubmitWaitWakeIrp( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBH_ChangeIndicationQueryChange( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp, IN PURB Urb, IN USHORT Port );
NTSTATUS USBH_InvalidatePortDeviceState( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USB_CONNECTION_STATUS ConnectStatus, IN USHORT PortNumber );
NTSTATUS USBH_PdoEvent( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber );
USB_CONNECTION_STATUS UsbhGetConnectionStatus( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort );
NTSTATUS USBH_ParentSubmitWaitWakeIrp( IN PDEVICE_EXTENSION_PARENT DeviceExtensionParent );
NTSTATUS USBH_WriteFailReason( IN PDEVICE_OBJECT PhysicalDeviceObject, IN ULONG FailReason );
NTSTATUS USBH_WriteRegistryKeyValue ( IN HANDLE Handle, IN PWCHAR KeyNameString, IN ULONG KeyNameStringLength, IN ULONG Data );
NTSTATUS USBH_SystemControl ( IN PDEVICE_EXTENSION_FDO DeviceExtensionFdo, IN PIRP Irp );
NTSTATUS USBH_PortSystemControl ( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_ExecuteWmiMethod( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp, IN ULONG GuidIndex, IN ULONG InstanceIndex, IN ULONG MethodId, IN ULONG InBufferSize, IN ULONG OutBufferSize, IN OUT PUCHAR Buffer );
NTSTATUS USBH_QueryWmiRegInfo( IN PDEVICE_OBJECT DeviceObject, OUT PULONG RegFlags, OUT PUNICODE_STRING InstanceName, OUT PUNICODE_STRING *RegistryPath, OUT PUNICODE_STRING MofResourceName, OUT PDEVICE_OBJECT *Pdo );
NTSTATUS USBH_PortQueryWmiRegInfo( IN PDEVICE_OBJECT DeviceObject, OUT PULONG RegFlags, OUT PUNICODE_STRING InstanceName, OUT PUNICODE_STRING *RegistryPath, OUT PUNICODE_STRING MofResourceName, OUT PDEVICE_OBJECT *Pdo );
NTSTATUS USBH_FlushPortChange( IN OUT PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN OUT PDEVICE_EXTENSION_PORT DeviceExtensionPort );
NTSTATUS USBH_PdoIoctlCyclePort( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_ResetPortOvercurrent( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber, IN PDEVICE_EXTENSION_PORT DeviceExtensionPort );
NTSTATUS USBH_SyncGetControllerInfo( IN PDEVICE_OBJECT DeviceObject, IN PVOID Buffer, IN ULONG BufferLength, IN ULONG Ioctl );
NTSTATUS USBH_SyncGetHubName( IN PDEVICE_OBJECT DeviceObject, IN PVOID Buffer, IN ULONG BufferLength );
NTSTATUS USBH_IoctlHubSymbolicName( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
NTSTATUS USBH_SetWmiDataBlock( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp, IN ULONG GuidIndex, IN ULONG InstanceIndex, IN ULONG BufferSize, IN PUCHAR Buffer );
NTSTATUS USBH_QueryWmiDataBlock( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp, IN ULONG GuidIndex, IN ULONG InstanceIndex, IN ULONG InstanceCount, IN OUT PULONG InstanceLengthArray, IN ULONG OutBufferSize, OUT PUCHAR Buffer );
NTSTATUS USBH_PortQueryWmiDataBlock( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp, IN ULONG GuidIndex, IN ULONG InstanceIndex, IN ULONG InstanceCount, IN OUT PULONG InstanceLengthArray, IN ULONG OutBufferSize, OUT PUCHAR Buffer );
NTSTATUS USBH_SetRegistryKeyValue ( IN HANDLE Handle, IN PUNICODE_STRING KeyNameUnicodeString, IN PVOID Data, IN ULONG DataLength, IN ULONG KeyType );
NTSTATUS USBH_SetPdoRegistryParameter ( IN PDEVICE_OBJECT PhysicalDeviceObject, IN PWCHAR KeyName, IN ULONG KeyNameLength, IN PVOID Data, IN ULONG DataLength, IN ULONG KeyType, IN ULONG DevInstKeyType );
NTSTATUS USBH_GetPdoRegistryParameter( IN PDEVICE_OBJECT PhysicalDeviceObject, IN PWCHAR ValueName, OUT PVOID Data, IN ULONG DataLength, OUT PULONG Type, OUT PULONG ActualDataLength );
NTSTATUS USBH_OsVendorCodeQueryRoutine( IN PWSTR ValueName, IN ULONG ValueType, IN PVOID ValueData, IN ULONG ValueLength, IN PVOID Context, IN PVOID EntryContext );
VOID USBH_GetMsOsVendorCode( IN PDEVICE_OBJECT DeviceObject );
NTSTATUS USBH_GetMsOsFeatureDescriptor( IN PDEVICE_OBJECT DeviceObject, IN UCHAR Recipient, IN UCHAR Interface, IN USHORT Index, IN OUT PVOID DataBuffer, IN ULONG DataBufferLength, OUT PULONG BytesReturned );
VOID USBH_InstallExtPropDesc ( IN PDEVICE_OBJECT DeviceObject );
VOID USBH_InstallExtPropDescSections ( PDEVICE_OBJECT DeviceObject, PMS_EXT_PROP_DESC pMsExtPropDesc );
PMS_EXT_CONFIG_DESC USBH_GetExtConfigDesc ( IN PDEVICE_OBJECT DeviceObject );
BOOLEAN USBH_ValidateExtConfigDesc ( IN PMS_EXT_CONFIG_DESC MsExtConfigDesc, IN PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor );
NTSTATUS USBH_CalculateInterfaceBandwidth( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PUSBD_INTERFACE_INFORMATION Interface, IN OUT PULONG Bandwidth // in kenr units?
);
NTSTATUS USBH_RegQueryDeviceIgnoreHWSerNumFlag( IN USHORT idVendor, IN USHORT idProduct, IN OUT PBOOLEAN IgnoreHWSerNumFlag );
NTSTATUS USBH_RegQueryGenericUSBDeviceString( IN OUT PWCHAR *GenericUSBDeviceString );
VOID USBH_ParentCompleteFunctionWakeIrps( IN PDEVICE_EXTENSION_PARENT DeviceExtensionParent, IN NTSTATUS NtStatus );
BOOLEAN USBH_ValidateConfigurationDescriptor( PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor, USBD_STATUS *UsbdSatus );
VOID USBH_HubCompletePortWakeIrps( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN NTSTATUS NtStatus );
VOID USBH_HubCompletePortIdleIrps( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN NTSTATUS NtStatus );
PUSB_DEVICE_HANDLE USBH_SyncGetDeviceHandle( IN PDEVICE_OBJECT DeviceObject );
VOID USBH_CompletePowerIrp( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp, IN NTSTATUS NtStatus );
VOID USBH_HubESDRecoveryWorker( IN PVOID Context);
NTSTATUS USBH_ScheduleESDRecovery( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
// these are for the USB2 'backport'
PWCHAR USBH_BuildHubHardwareIDs( IN USHORT IdVendor, IN USHORT IdProduct, IN USHORT BcdDevice, IN LONG MiId );
PWCHAR USBH_BuildHubCompatibleIDs( IN UCHAR Class, IN UCHAR SubClass, IN UCHAR Protocol, IN BOOLEAN DeviceClass, IN BOOLEAN DeviceIsHighSpeed );
NTSTATUS USBH_IoctlCycleHubPort( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
VOID USBH_InternalCyclePort( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT PortNumber, IN PDEVICE_EXTENSION_PORT DeviceExtensionPort );
PWCHAR USBH_BuildHubDeviceID( IN USHORT IdVendor, IN USHORT IdProduct, IN LONG MiId );
NTSTATUS USBHUB_GetBusInfo( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PUSB_BUS_NOTIFICATION BusInfo, IN PVOID BusContext );
NTSTATUS USBHUB_GetBusInfoDevice( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PUSB_BUS_NOTIFICATION BusInfo );
NTSTATUS USBHUB_GetBusInterfaceUSBDI( IN PDEVICE_OBJECT HubPdo, IN PUSB_BUS_INTERFACE_USBDI_V2 BusInterface );
USB_DEVICE_TYPE USBH_GetDeviceType( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PUSB_DEVICE_HANDLE DeviceData );
VOID USBH_CompletePortIdleNotification( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort );
VOID USBH_PortIdleNotificationCancelRoutine( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp );
NTSTATUS USBH_FdoSubmitIdleRequestIrp( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBH_HubSetD0( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBHUB_GetControllerName( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PUSB_HUB_NAME Buffer, IN ULONG BufferLength );
NTSTATUS USBHUB_GetExtendedHubInfo( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PUSB_EXTHUB_INFORMATION_0 ExtendedHubInfo );
BOOLEAN USBH_DoesHubNeedWaitWake( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
VOID USBH_CheckHubIdle( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBH_PdoSetContentId( IN PIRP irp, IN PVOID pKsProperty, IN PVOID pvData );
BOOLEAN USBH_CheckDeviceIDUnique( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN USHORT IDVendor, IN USHORT IDProduct, IN PWCHAR SerialNumberBuffer, IN USHORT SerialNumberBufferLength );
VOID USBH_IdleCompletePowerHubWorker( IN PVOID Context );
BOOLEAN USBH_DeviceIs2xDualMode( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort );
PDEVICE_EXTENSION_HUB USBH_GetRootHubDevExt( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
VOID USBH_CheckLeafHubsIdle( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
VOID USBH_HubCancelWakeIrp( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
VOID USBH_HubCancelIdleIrp( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
NTSTATUS USBH_IoctlGetNodeConnectionAttributes( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub, IN PIRP Irp );
VOID USBH_CompletePortIdleIrpsWorker( IN PVOID Context);
VOID USBH_CompletePortWakeIrpsWorker( IN PVOID Context);
VOID USBH_HubAsyncPowerWorker( IN PVOID Context);
VOID USBH_IdleCancelPowerHubWorker( IN PVOID Context);
NTSTATUS USBD_InitUsb2Hub( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
VOID USBH_PdoSetCapabilities( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort );
NTSTATUS USBH_HubPnPIrp_Complete( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp, IN PVOID Context );
NTSTATUS USBH_RegQueryUSBGlobalSelectiveSuspend( IN OUT PBOOLEAN DisableSelectiveSuspend );
VOID USBH_SyncRefreshPortAttributes( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBD_RegisterRhHubCallBack( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBD_UnRegisterRhHubCallBack( IN PDEVICE_EXTENSION_HUB DeviceExtensionHub );
NTSTATUS USBH_PdoStartDevice( IN PDEVICE_EXTENSION_PORT DeviceExtensionPort, IN PIRP Irp );
VOID USBHUB_SetDeviceHandleData( PDEVICE_EXTENSION_HUB DeviceExtensionHub, PDEVICE_OBJECT PdoDeviceObject, PVOID DeviceData );
#define PDO_EXT(p) PdoExt((p))
PDEVICE_EXTENSION_PORT PdoExt( PDEVICE_OBJECT DeviceObject ); #ifdef TEST_MS_DESC
#pragma message ("Warning! Compiling in non-retail test code!")
NTSTATUS USBH_SyncGetMsOsDescriptor( IN PDEVICE_OBJECT DeviceObject, IN USHORT Index, IN OUT PUCHAR DataBuffer, IN ULONG DataBufferLength, OUT PULONG BytesReturned);
NTSTATUS USBH_TestGetMsOsDescriptor( IN PDEVICE_OBJECT DeviceObject, IN USHORT Index );
#endif
#define LOG_PNP 0x00000001
#if DBG
NTSTATUS USBH_GetClassGlobalDebugRegistryParameters( );
VOID UsbhInfo( PDEVICE_EXTENSION_HUB DeviceExtensionHub );
VOID USBH_ShowPortState( IN USHORT PortNumber, IN PPORT_STATE PortState );
#define DEBUG_LOG
#define USBH_ASSERT(exp) \
if (!(exp)) { \ USBH_Assert( #exp, __FILE__, __LINE__, NULL );\ }
VOID USBH_Assert( IN PVOID FailedAssertion, IN PVOID FileName, IN ULONG LineNumber, IN PCHAR Message ); #else
#define USBH_ASSERT(exp)
#define UsbhInfo(de)
#endif
#ifdef DEBUG_LOG
VOID USBH_LogInit( );
VOID USBH_LogFree( );
#define LOGENTRY(mask, sig, info1, info2, info3) \
USBH_Debug_LogEntry(mask, sig, \ (ULONG_PTR)info1, \ (ULONG_PTR)info2, \ (ULONG_PTR)info3)
VOID USBH_Debug_LogEntry( IN ULONG Mask, IN CHAR *Name, IN ULONG_PTR Info1, IN ULONG_PTR Info2, IN ULONG_PTR Info3 );
#else
#define LOGENTRY(mask, sig, info1, info2, info3)
#define USBH_LogInit()
#define USBH_LogFree()
#endif
// last workitem will let the shutdown code continue
// !! do not reference the devicExtension beyond this point
// if event is signaled
#define USBH_DEC_PENDING_IO_COUNT(de) \
LOGENTRY(LOG_PNP, "PEN-", de, &de->PendingRequestEvent, de->PendingRequestCount); \ if (InterlockedDecrement(&de->PendingRequestCount) == 0) {\ USBH_ASSERT(de->HubFlags & HUBFLAG_DEVICE_STOPPING); \ LOGENTRY(LOG_PNP, "hWAK", de, &de->PendingRequestEvent, de->PendingRequestCount); \ KeSetEvent(&de->PendingRequestEvent, 1, FALSE); \ }
#define USBH_INC_PENDING_IO_COUNT(de) \
{\ LOGENTRY(LOG_PNP, "PEN+", de, &de->PendingRequestEvent, de->PendingRequestCount); \ InterlockedIncrement(&de->PendingRequestCount);\ }
|