2011-04-14 11:35:16 +00:00
|
|
|
#ifndef INTERFACES_HPP
|
|
|
|
#define INTERFACES_HPP
|
|
|
|
|
|
|
|
//=========================================================================================
|
|
|
|
//
|
|
|
|
// class IUSBHardwareDevice
|
|
|
|
//
|
|
|
|
// Description: This class provides access to the usb hardware controller
|
|
|
|
//
|
|
|
|
|
2012-02-28 18:54:30 +00:00
|
|
|
#define DEFINE_ABSTRACT_USBEHCIHARDWARE() \
|
2012-02-28 15:13:30 +00:00
|
|
|
STDMETHOD_(VOID, SetAsyncListRegister)( THIS_ \
|
|
|
|
IN ULONG PhysicalAddress) PURE; \
|
|
|
|
\
|
|
|
|
STDMETHOD_(VOID, SetPeriodicListRegister)( THIS_ \
|
|
|
|
IN ULONG PhysicalAddress) PURE; \
|
|
|
|
\
|
|
|
|
STDMETHOD_(struct _QUEUE_HEAD *, GetAsyncListQueueHead)( THIS) PURE; \
|
|
|
|
\
|
|
|
|
STDMETHOD_(ULONG, GetPeriodicListRegister)( THIS) PURE; \
|
|
|
|
\
|
|
|
|
STDMETHOD_(VOID, SetCommandRegister)( THIS_ \
|
|
|
|
IN struct _EHCI_USBCMD_CONTENT *UsbCmd) PURE; \
|
|
|
|
\
|
|
|
|
STDMETHOD_(VOID, GetCommandRegister)( THIS_ \
|
2014-07-05 16:32:43 +00:00
|
|
|
OUT struct _EHCI_USBCMD_CONTENT *UsbCmd) PURE;
|
2012-02-28 15:13:30 +00:00
|
|
|
|
|
|
|
#define IMP_IUSBEHCIHARDWARE \
|
|
|
|
STDMETHODIMP_(VOID) SetAsyncListRegister( \
|
|
|
|
IN ULONG PhysicalAddress); \
|
|
|
|
\
|
|
|
|
STDMETHODIMP_(VOID) SetPeriodicListRegister( \
|
|
|
|
IN ULONG PhysicalAddress); \
|
|
|
|
\
|
|
|
|
STDMETHODIMP_(struct _QUEUE_HEAD *) GetAsyncListQueueHead(); \
|
|
|
|
\
|
|
|
|
STDMETHODIMP_(ULONG) GetPeriodicListRegister(); \
|
|
|
|
\
|
|
|
|
STDMETHODIMP_(VOID) SetCommandRegister( \
|
|
|
|
IN struct _EHCI_USBCMD_CONTENT *UsbCmd); \
|
|
|
|
STDMETHODIMP_(VOID) GetCommandRegister( \
|
2014-07-05 16:32:43 +00:00
|
|
|
OUT struct _EHCI_USBCMD_CONTENT *UsbCmd);
|
2012-02-28 15:13:30 +00:00
|
|
|
|
|
|
|
DECLARE_INTERFACE_(IEHCIHardwareDevice, IUSBHardwareDevice)
|
2011-04-14 11:35:16 +00:00
|
|
|
{
|
|
|
|
DEFINE_ABSTRACT_UNKNOWN()
|
2012-02-28 15:13:30 +00:00
|
|
|
DEFINE_ABSTRACT_USBHARDWAREDEVICE()
|
|
|
|
DEFINE_ABSTRACT_USBEHCIHARDWARE()
|
2011-04-14 11:35:16 +00:00
|
|
|
};
|
|
|
|
|
2012-02-28 15:13:30 +00:00
|
|
|
typedef IEHCIHardwareDevice *PEHCIHARDWAREDEVICE;
|
2011-04-14 11:35:16 +00:00
|
|
|
|
|
|
|
//=========================================================================================
|
|
|
|
//
|
|
|
|
// class IUSBRequest
|
|
|
|
//
|
|
|
|
// Description: This class is used to issue request to usb controller. The class is
|
|
|
|
// initialized using InitializeXXX methods. You also need to call SetEndpoint to define the endpoint
|
|
|
|
// In addition you can call SetCompletionDetails if you need to wait for the end of
|
|
|
|
// the request or want to complete an irp. You call AddUSBRequest to add the request to the queue.
|
|
|
|
// Once the request is completed the CompletionCallback is invoked. The CompletionCallback
|
|
|
|
// will take care of any completion details which have been set. If the request is cancelled, the
|
|
|
|
// CancelCallback routine is invoked.
|
|
|
|
//
|
|
|
|
|
2011-04-19 01:21:10 +00:00
|
|
|
struct _QUEUE_HEAD;
|
2012-02-10 20:15:39 +00:00
|
|
|
struct _USB_ENDPOINT;
|
2011-04-19 01:21:10 +00:00
|
|
|
|
2012-02-28 15:13:30 +00:00
|
|
|
#define DEFINE_ABSTRACT_USBEHCIREQUEST() \
|
|
|
|
STDMETHOD_(VOID, CompletionCallback)( THIS_ \
|
|
|
|
IN NTSTATUS NtStatusCode, \
|
|
|
|
IN ULONG UrbStatusCode, \
|
|
|
|
IN struct _QUEUE_HEAD *QueueHead) PURE; \
|
|
|
|
\
|
|
|
|
STDMETHOD_(NTSTATUS, GetQueueHead)( THIS_ \
|
|
|
|
IN struct _QUEUE_HEAD ** OutHead) PURE; \
|
|
|
|
\
|
|
|
|
STDMETHOD_(BOOLEAN, ShouldReleaseRequestAfterCompletion)( THIS) PURE; \
|
|
|
|
\
|
|
|
|
\
|
|
|
|
STDMETHOD_(VOID, FreeQueueHead)( THIS_ \
|
|
|
|
IN struct _QUEUE_HEAD * QueueHead) PURE; \
|
|
|
|
\
|
|
|
|
STDMETHOD_(BOOLEAN, IsQueueHeadComplete)( THIS_ \
|
2012-03-02 14:21:44 +00:00
|
|
|
IN struct _QUEUE_HEAD * QueueHead) PURE; \
|
|
|
|
\
|
|
|
|
STDMETHOD_(USB_DEVICE_SPEED, GetSpeed)( THIS) PURE; \
|
|
|
|
\
|
|
|
|
STDMETHOD_(UCHAR, GetInterval)( THIS) PURE;
|
2012-02-28 15:13:30 +00:00
|
|
|
|
|
|
|
#define IMP_IEHCIREQUEST \
|
|
|
|
STDMETHODIMP_(VOID) CompletionCallback( \
|
|
|
|
IN NTSTATUS NtStatusCode, \
|
|
|
|
IN ULONG UrbStatusCode, \
|
|
|
|
IN struct _QUEUE_HEAD *QueueHead); \
|
|
|
|
\
|
|
|
|
STDMETHODIMP_(NTSTATUS) GetQueueHead( \
|
|
|
|
IN struct _QUEUE_HEAD ** OutHead); \
|
|
|
|
\
|
|
|
|
STDMETHODIMP_(BOOLEAN) ShouldReleaseRequestAfterCompletion(); \
|
|
|
|
\
|
|
|
|
STDMETHODIMP_(VOID) FreeQueueHead(struct _QUEUE_HEAD * QueueHead); \
|
|
|
|
\
|
|
|
|
STDMETHODIMP_(BOOLEAN) IsQueueHeadComplete( \
|
2012-03-02 14:21:44 +00:00
|
|
|
IN struct _QUEUE_HEAD * QueueHead); \
|
|
|
|
\
|
|
|
|
STDMETHODIMP_(USB_DEVICE_SPEED) GetSpeed( THIS); \
|
|
|
|
\
|
|
|
|
STDMETHODIMP_(UCHAR) GetInterval( THIS);
|
2012-02-28 15:13:30 +00:00
|
|
|
|
|
|
|
DECLARE_INTERFACE_(IEHCIRequest, IUSBRequest)
|
2011-04-14 11:35:16 +00:00
|
|
|
{
|
|
|
|
DEFINE_ABSTRACT_UNKNOWN()
|
2012-02-28 15:13:30 +00:00
|
|
|
DEFINE_ABSTRACT_USBREQUEST()
|
|
|
|
DEFINE_ABSTRACT_USBEHCIREQUEST()
|
2011-04-14 11:35:16 +00:00
|
|
|
};
|
|
|
|
|
2011-04-27 16:23:42 +00:00
|
|
|
|
2012-02-28 15:13:30 +00:00
|
|
|
typedef IEHCIRequest *PEHCIREQUEST;
|
2011-04-17 19:23:13 +00:00
|
|
|
|
2011-04-14 11:35:16 +00:00
|
|
|
//=========================================================================================
|
|
|
|
//
|
|
|
|
// class IUSBQueue
|
|
|
|
//
|
|
|
|
// Description: This class manages pending requests
|
|
|
|
//
|
|
|
|
|
2012-02-28 15:13:30 +00:00
|
|
|
#define DEFINE_ABSTRACT_USBEHCIQUEUE() \
|
|
|
|
STDMETHOD_(VOID, InterruptCallback)( THIS_ \
|
|
|
|
IN NTSTATUS Status, \
|
|
|
|
OUT PULONG ShouldRingDoorBell) PURE; \
|
|
|
|
\
|
2012-02-28 17:26:16 +00:00
|
|
|
STDMETHOD_(VOID, CompleteAsyncRequests)( THIS) PURE;
|
2012-02-28 15:13:30 +00:00
|
|
|
|
|
|
|
#define IMP_IEHCIQUEUE \
|
|
|
|
STDMETHODIMP_(VOID) InterruptCallback( \
|
|
|
|
IN NTSTATUS Status, \
|
|
|
|
OUT PULONG ShouldRingDoorBell); \
|
|
|
|
\
|
2012-02-28 17:26:16 +00:00
|
|
|
STDMETHODIMP_(VOID) CompleteAsyncRequests();
|
2012-02-28 15:13:30 +00:00
|
|
|
|
|
|
|
DECLARE_INTERFACE_(IEHCIQueue, IUSBQueue)
|
2011-04-15 17:57:24 +00:00
|
|
|
{
|
|
|
|
DEFINE_ABSTRACT_UNKNOWN()
|
2012-02-28 15:13:30 +00:00
|
|
|
DEFINE_ABSTRACT_USBQUEUE()
|
|
|
|
DEFINE_ABSTRACT_USBEHCIQUEUE()
|
[USBEHCI_NEW]
- Fix bug in CDMAMemoryManager initialization, which calculated the bitmap length wrong
- Create interface IUSBDevice, which will be used to abstract connected usb devices
- Implement support functions for the device interface.
- Implement USBHI_CreateUsbDevice, USBHI_InitializeUsbDevice, USBHI_GetUsbDescriptors, USBHI_RemoveUsbDevice, USBHI_GetExtendedHubInformation, USBHI_RootHubInitNotification, USBHI_SetDeviceHandleData, USBDI_GetUSBDIVersion, USBDI_IsDeviceHighSpeed
- Partly implement USBHI_QueryDeviceInformation
- Based on mjmartin usbehci
svn path=/branches/usb-bringup/; revision=51372
2011-04-17 08:20:40 +00:00
|
|
|
};
|
|
|
|
|
2012-02-28 15:13:30 +00:00
|
|
|
typedef IEHCIQueue *PEHCIQUEUE;
|
[USBEHCI_NEW]
- Fix bug in CDMAMemoryManager initialization, which calculated the bitmap length wrong
- Create interface IUSBDevice, which will be used to abstract connected usb devices
- Implement support functions for the device interface.
- Implement USBHI_CreateUsbDevice, USBHI_InitializeUsbDevice, USBHI_GetUsbDescriptors, USBHI_RemoveUsbDevice, USBHI_GetExtendedHubInformation, USBHI_RootHubInitNotification, USBHI_SetDeviceHandleData, USBDI_GetUSBDIVersion, USBDI_IsDeviceHighSpeed
- Partly implement USBHI_QueryDeviceInformation
- Based on mjmartin usbehci
svn path=/branches/usb-bringup/; revision=51372
2011-04-17 08:20:40 +00:00
|
|
|
|
2014-01-03 17:23:55 +00:00
|
|
|
#endif /* INTERFACES_HPP */
|