| /** @file | |
| EFI Usb I/O Protocol | |
| Copyright (c) 2006, Intel Corporation | |
| All rights reserved. This program and the accompanying materials | |
| are licensed and made available under the terms and conditions of the BSD License | |
| which accompanies this distribution. The full text of the license may be found at | |
| http://opensource.org/licenses/bsd-license.php | |
| THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | |
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |
| Module Name: UsbIo.h | |
| **/ | |
| #ifndef __USB_IO_H__ | |
| #define __USB_IO_H__ | |
| // | |
| // Global ID for the USB I/O Protocol | |
| // | |
| #define EFI_USB_IO_PROTOCOL_GUID \ | |
| { \ | |
| 0x2B2F68D6, 0x0CD2, 0x44cf, {0x8E, 0x8B, 0xBB, 0xA2, 0x0B, 0x1B, 0x5B, 0x75 } \ | |
| } | |
| typedef struct _EFI_USB_IO_PROTOCOL EFI_USB_IO_PROTOCOL; | |
| /** | |
| Async USB transfer callback routine. | |
| @param Data Data received or sent via the USB Asynchronous Transfer, if the | |
| transfer completed successfully. | |
| @param DataLength The length of Data received or sent via the Asynchronous | |
| Transfer, if transfer successfully completes. | |
| @param Context Data passed from UsbAsyncInterruptTransfer() request. | |
| @param Status Indicates the result of the asynchronous transfer. | |
| @retval EFI_SUCCESS The asynchronous USB transfer request has been successfully executed. | |
| @retval EFI_DEVICE_ERROR The asynchronous USB transfer request failed. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_ASYNC_USB_TRANSFER_CALLBACK) ( | |
| IN VOID *Data, | |
| IN UINTN DataLength, | |
| IN VOID *Context, | |
| IN UINT32 Status | |
| ); | |
| // | |
| // Prototype for EFI USB I/O protocol | |
| // | |
| /** | |
| This function is used to manage a USB device with a control transfer pipe. A control transfer is | |
| typically used to perform device initialization and configuration. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param Request A pointer to the USB device request that will be sent to the USB | |
| device. | |
| @param Direction Indicates the data direction. | |
| @param Data A pointer to the buffer of data that will be transmitted to USB | |
| device or received from USB device. | |
| @param Timeout Indicating the transfer should be completed within this time frame. | |
| The units are in milliseconds. | |
| @param DataLength The size, in bytes, of the data buffer specified by Data. | |
| @param Status A pointer to the result of the USB transfer. | |
| @retval EFI_SUCCESS The control transfer has been successfully executed. | |
| @retval EFI_DEVICE_ERROR The transfer failed. The transfer status is returned in Status. | |
| @retval EFI_INVALID_PARAMETE One or more parameters are invalid. | |
| @retval EFI_OUT_OF_RESOURCES The request could not be completed due to a lack of resources. | |
| @retval EFI_TIMEOUT The control transfer fails due to timeout. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_CONTROL_TRANSFER) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| IN EFI_USB_DEVICE_REQUEST *Request, | |
| IN EFI_USB_DATA_DIRECTION Direction, | |
| IN UINT32 Timeout, | |
| IN OUT VOID *Data OPTIONAL, | |
| IN UINTN DataLength OPTIONAL, | |
| OUT UINT32 *Status | |
| ); | |
| /** | |
| This function is used to manage a USB device with the bulk transfer pipe. Bulk Transfers are | |
| typically used to transfer large amounts of data to/from USB devices. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param DeviceEndpoint A pointer to the USB device request that will be sent to the USB | |
| device. | |
| @param Data A pointer to the buffer of data that will be transmitted to USB | |
| device or received from USB device. | |
| @param DataLength The size, in bytes, of the data buffer specified by Data. | |
| @param Timeout Indicating the transfer should be completed within this time frame. | |
| The units are in milliseconds. | |
| @param Status This parameter indicates the USB transfer status. | |
| @retval EFI_SUCCESS The bulk transfer has been successfully executed. | |
| @retval EFI_DEVICE_ERROR The transfer failed. The transfer status is returned in Status. | |
| @retval EFI_INVALID_PARAMETE One or more parameters are invalid. | |
| @retval EFI_OUT_OF_RESOURCES The request could not be submitted due to a lack of resources. | |
| @retval EFI_TIMEOUT The control transfer fails due to timeout. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_BULK_TRANSFER) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| IN UINT8 DeviceEndpoint, | |
| IN OUT VOID *Data, | |
| IN OUT UINTN *DataLength, | |
| IN UINTN Timeout, | |
| OUT UINT32 *Status | |
| ); | |
| /** | |
| This function is used to manage a USB device with an interrupt transfer pipe. An Asynchronous | |
| Interrupt Transfer is typically used to query a device's status at a fixed rate. For example, | |
| keyboard, mouse, and hub devices use this type of transfer to query their interrupt endpoints at | |
| a fixed rate. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param DeviceEndpoint A pointer to the USB device request that will be sent to the USB | |
| device. | |
| @param IsNewTransfer If TRUE, a new transfer will be submitted to USB controller. If | |
| FALSE, the interrupt transfer is deleted from the device's interrupt | |
| transfer queue. | |
| @param PollingInterval Indicates the periodic rate, in milliseconds, that the transfer is to be | |
| executed. | |
| @param DataLength Specifies the length, in bytes, of the data to be received from the | |
| USB device. | |
| @param Context Data passed to the InterruptCallback function. | |
| @param InterruptCallback The Callback function. This function is called if the asynchronous | |
| interrupt transfer is completed. | |
| @retval EFI_SUCCESS The asynchronous USB transfer request transfer has been successfully executed. | |
| @retval EFI_DEVICE_ERROR The asynchronous USB transfer request failed. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_ASYNC_INTERRUPT_TRANSFER) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| IN UINT8 DeviceEndpoint, | |
| IN BOOLEAN IsNewTransfer, | |
| IN UINTN PollingInterval OPTIONAL, | |
| IN UINTN DataLength OPTIONAL, | |
| IN EFI_ASYNC_USB_TRANSFER_CALLBACK InterruptCallBack OPTIONAL, | |
| IN VOID *Context OPTIONAL | |
| ); | |
| /** | |
| This function is used to manage a USB device with an interrupt transfer pipe. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param DeviceEndpoint A pointer to the USB device request that will be sent to the USB | |
| device. | |
| @param Data A pointer to the buffer of data that will be transmitted to USB | |
| device or received from USB device. | |
| @param DataLength On input, then size, in bytes, of the buffer Data. On output, the | |
| amount of data actually transferred. | |
| @param Timeout The time out, in seconds, for this transfer. | |
| @param Status This parameter indicates the USB transfer status. | |
| @retval EFI_SUCCESS The sync interrupt transfer has been successfully executed. | |
| @retval EFI_INVALID_PARAMETER One or more parameters are invalid. | |
| @retval EFI_DEVICE_ERROR The sync interrupt transfer request failed. | |
| @retval EFI_OUT_OF_RESOURCES The request could not be submitted due to a lack of resources. | |
| @retval EFI_TIMEOUT The transfer fails due to timeout. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_SYNC_INTERRUPT_TRANSFER) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| IN UINT8 DeviceEndpoint, | |
| IN OUT VOID *Data, | |
| IN OUT UINTN *DataLength, | |
| IN UINTN Timeout, | |
| OUT UINT32 *Status | |
| ); | |
| /** | |
| This function is used to manage a USB device with an isochronous transfer pipe. An Isochronous | |
| transfer is typically used to transfer streaming data. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param DeviceEndpoint A pointer to the USB device request that will be sent to the USB | |
| device. | |
| @param Data A pointer to the buffer of data that will be transmitted to USB | |
| device or received from USB device. | |
| @param DataLength The size, in bytes, of the data buffer specified by Data. | |
| @param Status This parameter indicates the USB transfer status. | |
| @retval EFI_SUCCESS The isochronous transfer has been successfully executed. | |
| @retval EFI_INVALID_PARAMETER The parameter DeviceEndpoint is not valid. | |
| @retval EFI_DEVICE_ERROR The transfer failed due to the reason other than timeout, The error status | |
| is returned in Status. | |
| @retval EFI_OUT_OF_RESOURCES The request could not be submitted due to a lack of resources. | |
| @retval EFI_TIMEOUT The transfer fails due to timeout. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_ISOCHRONOUS_TRANSFER) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| IN UINT8 DeviceEndpoint, | |
| IN OUT VOID *Data, | |
| IN UINTN DataLength, | |
| OUT UINT32 *Status | |
| ); | |
| /** | |
| This function is used to manage a USB device with an isochronous transfer pipe. An Isochronous | |
| transfer is typically used to transfer streaming data. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param DeviceEndpoint A pointer to the USB device request that will be sent to the USB | |
| device. | |
| @param Data A pointer to the buffer of data that will be transmitted to USB | |
| device or received from USB device. | |
| @param DataLength The size, in bytes, of the data buffer specified by Data. | |
| @param Context Data passed to the IsochronousCallback() function. | |
| @param IsochronousCallback The IsochronousCallback() function. | |
| @retval EFI_SUCCESS The asynchronous isochronous transfer has been successfully submitted | |
| to the system. | |
| @retval EFI_INVALID_PARAMETER The parameter DeviceEndpoint is not valid. | |
| @retval EFI_OUT_OF_RESOURCES The request could not be submitted due to a lack of resources. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_ASYNC_ISOCHRONOUS_TRANSFER) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| IN UINT8 DeviceEndpoint, | |
| IN OUT VOID *Data, | |
| IN UINTN DataLength, | |
| IN EFI_ASYNC_USB_TRANSFER_CALLBACK IsochronousCallBack, | |
| IN VOID *Context OPTIONAL | |
| ); | |
| /** | |
| Resets and reconfigures the USB controller. This function will work for all USB devices except | |
| USB Hub Controllers. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @retval EFI_SUCCESS The USB controller was reset. | |
| @retval EFI_INVALID_PARAMETER If the controller specified by This is a USB hub. | |
| @retval EFI_DEVICE_ERROR An error occurred during the reconfiguration process. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_PORT_RESET) ( | |
| IN EFI_USB_IO_PROTOCOL *This | |
| ); | |
| /** | |
| Retrieves the USB Device Descriptor. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param DeviceDescriptor A pointer to the caller allocated USB Device Descriptor. | |
| @retval EFI_SUCCESS The device descriptor was retrieved successfully. | |
| @retval EFI_INVALID_PARAMETER DeviceDescriptor is NULL. | |
| @retval EFI_NOT_FOUND The device descriptor was not found. The device may not be configured. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_GET_DEVICE_DESCRIPTOR) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| OUT EFI_USB_DEVICE_DESCRIPTOR *DeviceDescriptor | |
| ); | |
| /** | |
| Retrieves the USB Device Descriptor. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param ConfigurationDescriptor A pointer to the caller allocated USB Active Configuration | |
| Descriptor. | |
| @retval EFI_SUCCESS The active configuration descriptor was retrieved successfully. | |
| @retval EFI_INVALID_PARAMETER ConfigurationDescriptor is NULL. | |
| @retval EFI_NOT_FOUND An active configuration descriptor cannot be found. The device may not | |
| be configured. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_GET_CONFIG_DESCRIPTOR) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| OUT EFI_USB_CONFIG_DESCRIPTOR *ConfigurationDescriptor | |
| ); | |
| /** | |
| Retrieves the Interface Descriptor for a USB Device Controller. As stated earlier, an interface | |
| within a USB device is equivalently to a USB Controller within the current configuration. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param InterfaceDescriptor A pointer to the caller allocated USB Interface Descriptor within | |
| the configuration setting. | |
| @retval EFI_SUCCESS The interface descriptor retrieved successfully. | |
| @retval EFI_INVALID_PARAMETER InterfaceDescriptor is NULL. | |
| @retval EFI_NOT_FOUND The interface descriptor cannot be found. The device may not be | |
| correctly configured. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_GET_INTERFACE_DESCRIPTOR) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| OUT EFI_USB_INTERFACE_DESCRIPTOR *InterfaceDescriptor | |
| ); | |
| /** | |
| Retrieves an Endpoint Descriptor within a USB Controller. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param EndpointIndex Indicates which endpoint descriptor to retrieve. | |
| @param EndpointDescriptor A pointer to the caller allocated USB Endpoint Descriptor of | |
| a USB controller. | |
| @retval EFI_SUCCESS The endpoint descriptor was retrieved successfully. | |
| @retval EFI_INVALID_PARAMETER One or more parameters are invalid. | |
| @retval EFI_NOT_FOUND The endpoint descriptor cannot be found. The device may not be | |
| correctly configured. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_GET_ENDPOINT_DESCRIPTOR) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| IN UINT8 EndpointIndex, | |
| OUT EFI_USB_ENDPOINT_DESCRIPTOR *EndpointDescriptor | |
| ); | |
| /** | |
| Retrieves a Unicode string stored in a USB Device. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param LangID The Language ID for the string being retrieved. | |
| @param StringID The ID of the string being retrieved. | |
| @param String A pointer to a buffer allocated by this function with | |
| AllocatePool() to store the string. | |
| @retval EFI_SUCCESS The string was retrieved successfully. | |
| @retval EFI_NOT_FOUND The string specified by LangID and StringID was not found. | |
| @retval EFI_OUT_OF_RESOURCES There are not enough resources to allocate the return buffer String. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_GET_STRING_DESCRIPTOR) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| IN UINT16 LangID, | |
| IN UINT8 StringID, | |
| OUT CHAR16 **String | |
| ); | |
| /** | |
| Retrieves all the language ID codes that the USB device supports. | |
| @param This A pointer to the EFI_USB_IO_PROTOCOL instance. | |
| @param LangIDTable Language ID for the string the caller wants to get. | |
| @param TableSize The size, in bytes, of the table LangIDTable. | |
| @retval EFI_SUCCESS The support languages were retrieved successfully. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_USB_IO_GET_SUPPORTED_LANGUAGE) ( | |
| IN EFI_USB_IO_PROTOCOL *This, | |
| OUT UINT16 **LangIDTable, | |
| OUT UINT16 *TableSize | |
| ); | |
| // | |
| // Protocol Interface Structure | |
| // | |
| struct _EFI_USB_IO_PROTOCOL { | |
| // | |
| // IO transfer | |
| // | |
| EFI_USB_IO_CONTROL_TRANSFER UsbControlTransfer; | |
| EFI_USB_IO_BULK_TRANSFER UsbBulkTransfer; | |
| EFI_USB_IO_ASYNC_INTERRUPT_TRANSFER UsbAsyncInterruptTransfer; | |
| EFI_USB_IO_SYNC_INTERRUPT_TRANSFER UsbSyncInterruptTransfer; | |
| EFI_USB_IO_ISOCHRONOUS_TRANSFER UsbIsochronousTransfer; | |
| EFI_USB_IO_ASYNC_ISOCHRONOUS_TRANSFER UsbAsyncIsochronousTransfer; | |
| // | |
| // Common device request | |
| // | |
| EFI_USB_IO_GET_DEVICE_DESCRIPTOR UsbGetDeviceDescriptor; | |
| EFI_USB_IO_GET_CONFIG_DESCRIPTOR UsbGetConfigDescriptor; | |
| EFI_USB_IO_GET_INTERFACE_DESCRIPTOR UsbGetInterfaceDescriptor; | |
| EFI_USB_IO_GET_ENDPOINT_DESCRIPTOR UsbGetEndpointDescriptor; | |
| EFI_USB_IO_GET_STRING_DESCRIPTOR UsbGetStringDescriptor; | |
| EFI_USB_IO_GET_SUPPORTED_LANGUAGE UsbGetSupportedLanguages; | |
| // | |
| // Reset controller's parent port | |
| // | |
| EFI_USB_IO_PORT_RESET UsbPortReset; | |
| }; | |
| extern EFI_GUID gEfiUsbIoProtocolGuid; | |
| #endif |