2007-06-19 12:12:02 +02:00
|
|
|
/** @file
|
2008-07-25 12:50:50 +02:00
|
|
|
EFI Usb I/O Protocol as defined in UEFI specification.
|
2018-06-27 15:11:33 +02:00
|
|
|
This protocol is used by code, typically drivers, running in the EFI
|
|
|
|
boot services environment to access USB devices like USB keyboards,
|
|
|
|
mice and mass storage devices. In particular, functions for managing devices
|
2008-07-25 12:50:50 +02:00
|
|
|
on USB buses are defined here.
|
2018-06-27 15:11:33 +02:00
|
|
|
|
|
|
|
Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:00 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-06-19 12:12:02 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __USB_IO_H__
|
|
|
|
#define __USB_IO_H__
|
|
|
|
|
|
|
|
#include <IndustryStandard/Usb.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 } \
|
|
|
|
}
|
|
|
|
|
2021-12-05 23:54:05 +01:00
|
|
|
typedef struct _EFI_USB_IO_PROTOCOL EFI_USB_IO_PROTOCOL;
|
2007-06-19 12:12:02 +02:00
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
//
|
|
|
|
// Related Definition for EFI USB I/O protocol
|
|
|
|
//
|
|
|
|
|
|
|
|
//
|
|
|
|
// USB standard descriptors and reqeust
|
|
|
|
//
|
2021-12-05 23:54:05 +01:00
|
|
|
typedef USB_DEVICE_REQUEST EFI_USB_DEVICE_REQUEST;
|
|
|
|
typedef USB_DEVICE_DESCRIPTOR EFI_USB_DEVICE_DESCRIPTOR;
|
|
|
|
typedef USB_CONFIG_DESCRIPTOR EFI_USB_CONFIG_DESCRIPTOR;
|
|
|
|
typedef USB_INTERFACE_DESCRIPTOR EFI_USB_INTERFACE_DESCRIPTOR;
|
|
|
|
typedef USB_ENDPOINT_DESCRIPTOR EFI_USB_ENDPOINT_DESCRIPTOR;
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2008-12-09 15:04:41 +01:00
|
|
|
///
|
|
|
|
/// USB data transfer direction
|
|
|
|
///
|
2007-07-18 07:10:20 +02:00
|
|
|
typedef enum {
|
|
|
|
EfiUsbDataIn,
|
|
|
|
EfiUsbDataOut,
|
|
|
|
EfiUsbNoData
|
|
|
|
} EFI_USB_DATA_DIRECTION;
|
|
|
|
|
|
|
|
//
|
|
|
|
// USB Transfer Results
|
|
|
|
//
|
2021-12-05 23:54:05 +01:00
|
|
|
#define EFI_USB_NOERROR 0x00
|
|
|
|
#define EFI_USB_ERR_NOTEXECUTE 0x01
|
|
|
|
#define EFI_USB_ERR_STALL 0x02
|
|
|
|
#define EFI_USB_ERR_BUFFER 0x04
|
|
|
|
#define EFI_USB_ERR_BABBLE 0x08
|
|
|
|
#define EFI_USB_ERR_NAK 0x10
|
|
|
|
#define EFI_USB_ERR_CRC 0x20
|
|
|
|
#define EFI_USB_ERR_TIMEOUT 0x40
|
|
|
|
#define EFI_USB_ERR_BITSTUFF 0x80
|
|
|
|
#define EFI_USB_ERR_SYSTEM 0x100
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
Async USB transfer callback routine.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
@param Data Data received or sent via the USB Asynchronous Transfer, if the
|
2007-07-18 07:10:20 +02:00
|
|
|
transfer completed successfully.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param DataLength The length of Data received or sent via the Asynchronous
|
2007-07-18 07:10:20 +02:00
|
|
|
Transfer, if transfer successfully completes.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param Context Data passed from UsbAsyncInterruptTransfer() request.
|
|
|
|
@param Status Indicates the result of the asynchronous transfer.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@retval EFI_SUCCESS The asynchronous USB transfer request has been successfully executed.
|
2007-06-19 12:12:02 +02:00
|
|
|
@retval EFI_DEVICE_ERROR The asynchronous USB transfer request failed.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_ASYNC_USB_TRANSFER_CALLBACK)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN VOID *Data,
|
|
|
|
IN UINTN DataLength,
|
|
|
|
IN VOID *Context,
|
|
|
|
IN UINT32 Status
|
|
|
|
);
|
|
|
|
|
|
|
|
//
|
|
|
|
// Prototype for EFI USB I/O protocol
|
|
|
|
//
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
This function is used to manage a USB device with a control transfer pipe. A control transfer is
|
2007-07-18 07:10:20 +02:00
|
|
|
typically used to perform device initialization and configuration.
|
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param Request A pointer to the USB device request that will be sent to the USB
|
2007-07-18 07:10:20 +02:00
|
|
|
device.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param Direction Indicates the data direction.
|
|
|
|
@param Timeout Indicating the transfer should be completed within this time frame.
|
2007-07-18 07:10:20 +02:00
|
|
|
The units are in milliseconds.
|
2008-02-25 08:01:44 +01:00
|
|
|
@param Data A pointer to the buffer of data that will be transmitted to USB
|
|
|
|
device or received from USB device.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param DataLength The size, in bytes, of the data buffer specified by Data.
|
|
|
|
@param Status A pointer to the result of the USB transfer.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
@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.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_CONTROL_TRANSFER)(
|
2007-06-19 12:12:02 +02:00
|
|
|
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
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
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.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param DeviceEndpoint The destination USB device endpoint to which the
|
|
|
|
device request is being sent. DeviceEndpoint must
|
|
|
|
be between 0x01 and 0x0F or between 0x81 and 0x8F,
|
|
|
|
otherwise EFI_INVALID_PARAMETER is returned. If
|
|
|
|
the endpoint is not a BULK endpoint, EFI_INVALID_PARAMETER
|
|
|
|
is returned. The MSB of this parameter indicates
|
|
|
|
the endpoint direction. The number "1" stands for
|
2008-09-28 09:16:30 +02:00
|
|
|
an IN endpoint, and "0" stands for an OUT endpoint.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param Data A pointer to the buffer of data that will be transmitted to USB
|
2007-07-18 07:10:20 +02:00
|
|
|
device or received from USB device.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param DataLength The size, in bytes, of the data buffer specified by Data.
|
2008-09-28 07:30:46 +02:00
|
|
|
On input, the size, in bytes, of the data buffer specified by Data.
|
|
|
|
On output, the number of bytes that were actually transferred.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param Timeout Indicating the transfer should be completed within this time frame.
|
2018-06-27 15:11:33 +02:00
|
|
|
The units are in milliseconds. If Timeout is 0, then the
|
|
|
|
caller must wait for the function to be completed until
|
2008-09-28 07:30:46 +02:00
|
|
|
EFI_SUCCESS or EFI_DEVICE_ERROR is returned.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param Status This parameter indicates the USB transfer status.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
@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.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_BULK_TRANSFER)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN EFI_USB_IO_PROTOCOL *This,
|
|
|
|
IN UINT8 DeviceEndpoint,
|
|
|
|
IN OUT VOID *Data,
|
|
|
|
IN OUT UINTN *DataLength,
|
|
|
|
IN UINTN Timeout,
|
|
|
|
OUT UINT32 *Status
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
|
|
|
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,
|
2007-06-19 12:12:02 +02:00
|
|
|
keyboard, mouse, and hub devices use this type of transfer to query their interrupt endpoints at
|
2007-07-18 07:10:20 +02:00
|
|
|
a fixed rate.
|
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param DeviceEndpoint The destination USB device endpoint to which the
|
|
|
|
device request is being sent. DeviceEndpoint must
|
|
|
|
be between 0x01 and 0x0F or between 0x81 and 0x8F,
|
|
|
|
otherwise EFI_INVALID_PARAMETER is returned. If
|
|
|
|
the endpoint is not a BULK endpoint, EFI_INVALID_PARAMETER
|
|
|
|
is returned. The MSB of this parameter indicates
|
|
|
|
the endpoint direction. The number "1" stands for
|
2008-09-28 09:16:30 +02:00
|
|
|
an IN endpoint, and "0" stands for an OUT endpoint.
|
2007-07-18 07:10:20 +02:00
|
|
|
@param IsNewTransfer If TRUE, a new transfer will be submitted to USB controller. If
|
2007-06-19 12:12:02 +02:00
|
|
|
FALSE, the interrupt transfer is deleted from the device's interrupt
|
2007-07-18 07:10:20 +02:00
|
|
|
transfer queue.
|
|
|
|
@param PollingInterval Indicates the periodic rate, in milliseconds, that the transfer is to be
|
2018-06-27 15:11:33 +02:00
|
|
|
executed.This parameter is required when IsNewTransfer is TRUE. The
|
|
|
|
value must be between 1 to 255, otherwise EFI_INVALID_PARAMETER is returned.
|
2008-09-28 07:30:46 +02:00
|
|
|
The units are in milliseconds.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param DataLength Specifies the length, in bytes, of the data to be received from the
|
2008-09-28 07:30:46 +02:00
|
|
|
USB device. This parameter is only required when IsNewTransfer is TRUE.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param InterruptCallback The Callback function. This function is called if the asynchronous
|
2018-06-27 15:11:33 +02:00
|
|
|
interrupt transfer is completed. This parameter is required
|
2008-09-28 07:30:46 +02:00
|
|
|
when IsNewTransfer is TRUE.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param Context Data passed to the InterruptCallback function. This is an optional
|
2008-09-28 07:30:46 +02:00
|
|
|
parameter and may be NULL.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
@retval EFI_SUCCESS The asynchronous USB transfer request transfer has been successfully executed.
|
2007-07-18 07:10:20 +02:00
|
|
|
@retval EFI_DEVICE_ERROR The asynchronous USB transfer request failed.
|
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_ASYNC_INTERRUPT_TRANSFER)(
|
2007-06-19 12:12:02 +02:00
|
|
|
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
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
This function is used to manage a USB device with an interrupt transfer pipe.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param DeviceEndpoint The destination USB device endpoint to which the
|
|
|
|
device request is being sent. DeviceEndpoint must
|
|
|
|
be between 0x01 and 0x0F or between 0x81 and 0x8F,
|
|
|
|
otherwise EFI_INVALID_PARAMETER is returned. If
|
|
|
|
the endpoint is not a BULK endpoint, EFI_INVALID_PARAMETER
|
|
|
|
is returned. The MSB of this parameter indicates
|
|
|
|
the endpoint direction. The number "1" stands for
|
2008-09-28 09:16:30 +02:00
|
|
|
an IN endpoint, and "0" stands for an OUT endpoint.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param Data A pointer to the buffer of data that will be transmitted to USB
|
2007-07-18 07:10:20 +02:00
|
|
|
device or received from USB device.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param DataLength On input, then size, in bytes, of the buffer Data. On output, the
|
2007-07-18 07:10:20 +02:00
|
|
|
amount of data actually transferred.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param Timeout The time out, in seconds, for this transfer. If Timeout is 0,
|
|
|
|
then the caller must wait for the function to be completed
|
|
|
|
until EFI_SUCCESS or EFI_DEVICE_ERROR is returned. If the
|
2008-09-28 07:30:46 +02:00
|
|
|
transfer is not completed in this time frame, then EFI_TIMEOUT is returned.
|
2007-07-18 07:10:20 +02:00
|
|
|
@param Status This parameter indicates the USB transfer status.
|
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
@retval EFI_SUCCESS The sync interrupt transfer has been successfully executed.
|
|
|
|
@retval EFI_INVALID_PARAMETER One or more parameters are invalid.
|
2007-07-18 07:10:20 +02:00
|
|
|
@retval EFI_DEVICE_ERROR The sync interrupt transfer request failed.
|
2007-06-19 12:12:02 +02:00
|
|
|
@retval EFI_OUT_OF_RESOURCES The request could not be submitted due to a lack of resources.
|
2007-07-18 07:10:20 +02:00
|
|
|
@retval EFI_TIMEOUT The transfer fails due to timeout.
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_SYNC_INTERRUPT_TRANSFER)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN EFI_USB_IO_PROTOCOL *This,
|
|
|
|
IN UINT8 DeviceEndpoint,
|
|
|
|
IN OUT VOID *Data,
|
|
|
|
IN OUT UINTN *DataLength,
|
|
|
|
IN UINTN Timeout,
|
|
|
|
OUT UINT32 *Status
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
This function is used to manage a USB device with an isochronous transfer pipe. An Isochronous
|
|
|
|
transfer is typically used to transfer streaming data.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param DeviceEndpoint The destination USB device endpoint to which the
|
|
|
|
device request is being sent. DeviceEndpoint must
|
|
|
|
be between 0x01 and 0x0F or between 0x81 and 0x8F,
|
|
|
|
otherwise EFI_INVALID_PARAMETER is returned. If
|
|
|
|
the endpoint is not a BULK endpoint, EFI_INVALID_PARAMETER
|
|
|
|
is returned. The MSB of this parameter indicates
|
|
|
|
the endpoint direction. The number "1" stands for
|
2008-09-28 09:16:30 +02:00
|
|
|
an IN endpoint, and "0" stands for an OUT endpoint.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param Data A pointer to the buffer of data that will be transmitted to USB
|
2007-07-18 07:10:20 +02:00
|
|
|
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.
|
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
@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
|
2007-07-18 07:10:20 +02:00
|
|
|
is returned in Status.
|
2007-06-19 12:12:02 +02:00
|
|
|
@retval EFI_OUT_OF_RESOURCES The request could not be submitted due to a lack of resources.
|
2007-07-18 07:10:20 +02:00
|
|
|
@retval EFI_TIMEOUT The transfer fails due to timeout.
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_ISOCHRONOUS_TRANSFER)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN EFI_USB_IO_PROTOCOL *This,
|
|
|
|
IN UINT8 DeviceEndpoint,
|
|
|
|
IN OUT VOID *Data,
|
|
|
|
IN UINTN DataLength,
|
|
|
|
OUT UINT32 *Status
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
This function is used to manage a USB device with an isochronous transfer pipe. An Isochronous
|
2007-07-18 07:10:20 +02:00
|
|
|
transfer is typically used to transfer streaming data.
|
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param DeviceEndpoint The destination USB device endpoint to which the
|
|
|
|
device request is being sent. DeviceEndpoint must
|
|
|
|
be between 0x01 and 0x0F or between 0x81 and 0x8F,
|
|
|
|
otherwise EFI_INVALID_PARAMETER is returned. If
|
|
|
|
the endpoint is not a BULK endpoint, EFI_INVALID_PARAMETER
|
|
|
|
is returned. The MSB of this parameter indicates
|
|
|
|
the endpoint direction. The number "1" stands for
|
2008-09-28 09:16:30 +02:00
|
|
|
an IN endpoint, and "0" stands for an OUT endpoint.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param Data A pointer to the buffer of data that will be transmitted to USB
|
2007-07-18 07:10:20 +02:00
|
|
|
device or received from USB device.
|
|
|
|
@param DataLength The size, in bytes, of the data buffer specified by Data.
|
2008-09-28 07:30:46 +02:00
|
|
|
This is an optional parameter and may be NULL.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param IsochronousCallback The IsochronousCallback() function.This function is
|
2008-09-28 07:30:46 +02:00
|
|
|
called if the requested isochronous transfer is completed.
|
2008-07-25 12:50:50 +02:00
|
|
|
@param Context Data passed to the IsochronousCallback() function.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
@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.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_ASYNC_ISOCHRONOUS_TRANSFER)(
|
2007-06-19 12:12:02 +02:00
|
|
|
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
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
Resets and reconfigures the USB controller. This function will work for all USB devices except
|
2007-07-18 07:10:20 +02:00
|
|
|
USB Hub Controllers.
|
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The USB controller was reset.
|
2007-06-19 12:12:02 +02:00
|
|
|
@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.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_PORT_RESET)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN EFI_USB_IO_PROTOCOL *This
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
Retrieves the USB Device Descriptor.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param DeviceDescriptor A pointer to the caller allocated USB Device Descriptor.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
@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.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_GET_DEVICE_DESCRIPTOR)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN EFI_USB_IO_PROTOCOL *This,
|
|
|
|
OUT EFI_USB_DEVICE_DESCRIPTOR *DeviceDescriptor
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
Retrieves the USB Device Descriptor.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param ConfigurationDescriptor A pointer to the caller allocated USB Active Configuration
|
2007-07-18 07:10:20 +02:00
|
|
|
Descriptor.
|
2007-06-19 12:12:02 +02:00
|
|
|
@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
|
2007-07-18 07:10:20 +02:00
|
|
|
be configured.
|
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_GET_CONFIG_DESCRIPTOR)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN EFI_USB_IO_PROTOCOL *This,
|
|
|
|
OUT EFI_USB_CONFIG_DESCRIPTOR *ConfigurationDescriptor
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
Retrieves the Interface Descriptor for a USB Device Controller. As stated earlier, an interface
|
2007-07-18 07:10:20 +02:00
|
|
|
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.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param InterfaceDescriptor A pointer to the caller allocated USB Interface Descriptor within
|
2007-07-18 07:10:20 +02:00
|
|
|
the configuration setting.
|
2007-06-19 12:12:02 +02:00
|
|
|
@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
|
2007-07-18 07:10:20 +02:00
|
|
|
correctly configured.
|
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_GET_INTERFACE_DESCRIPTOR)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN EFI_USB_IO_PROTOCOL *This,
|
|
|
|
OUT EFI_USB_INTERFACE_DESCRIPTOR *InterfaceDescriptor
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
Retrieves an Endpoint Descriptor within a USB Controller.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param EndpointIndex Indicates which endpoint descriptor to retrieve.
|
|
|
|
@param EndpointDescriptor A pointer to the caller allocated USB Endpoint Descriptor of
|
2007-07-18 07:10:20 +02:00
|
|
|
a USB controller.
|
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
@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
|
2007-07-18 07:10:20 +02:00
|
|
|
correctly configured.
|
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_GET_ENDPOINT_DESCRIPTOR)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN EFI_USB_IO_PROTOCOL *This,
|
|
|
|
IN UINT8 EndpointIndex,
|
|
|
|
OUT EFI_USB_ENDPOINT_DESCRIPTOR *EndpointDescriptor
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2009-09-24 10:56:33 +02:00
|
|
|
Retrieves a string stored in a USB Device.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param LangID The Language ID for the string being retrieved.
|
2007-07-18 07:10:20 +02:00
|
|
|
@param StringID The ID of the string being retrieved.
|
|
|
|
@param String A pointer to a buffer allocated by this function with
|
2018-06-27 15:11:33 +02:00
|
|
|
AllocatePool() to store the string.If this function
|
|
|
|
returns EFI_SUCCESS, it stores the string the caller
|
|
|
|
wants to get. The caller should release the string
|
2008-09-28 07:30:46 +02:00
|
|
|
buffer with FreePool() after the string is not used any more.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@retval EFI_SUCCESS The string was retrieved successfully.
|
|
|
|
@retval EFI_NOT_FOUND The string specified by LangID and StringID was not found.
|
2007-06-19 12:12:02 +02:00
|
|
|
@retval EFI_OUT_OF_RESOURCES There are not enough resources to allocate the return buffer String.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_GET_STRING_DESCRIPTOR)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN EFI_USB_IO_PROTOCOL *This,
|
|
|
|
IN UINT16 LangID,
|
|
|
|
IN UINT8 StringID,
|
|
|
|
OUT CHAR16 **String
|
|
|
|
);
|
|
|
|
|
2007-07-18 07:10:20 +02:00
|
|
|
/**
|
2007-06-19 12:12:02 +02:00
|
|
|
Retrieves all the language ID codes that the USB device supports.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@param This A pointer to the EFI_USB_IO_PROTOCOL instance.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param LangIDTable Language ID for the string the caller wants to get.
|
2018-06-27 15:11:33 +02:00
|
|
|
This is a 16-bit ID defined by Microsoft. This
|
|
|
|
buffer pointer is allocated and maintained by
|
|
|
|
the USB Bus Driver, the caller should not modify
|
2008-09-28 07:30:46 +02:00
|
|
|
its contents.
|
2007-06-19 12:12:02 +02:00
|
|
|
@param TableSize The size, in bytes, of the table LangIDTable.
|
2007-07-18 07:10:20 +02:00
|
|
|
|
|
|
|
@retval EFI_SUCCESS The support languages were retrieved successfully.
|
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_USB_IO_GET_SUPPORTED_LANGUAGE)(
|
2007-06-19 12:12:02 +02:00
|
|
|
IN EFI_USB_IO_PROTOCOL *This,
|
|
|
|
OUT UINT16 **LangIDTable,
|
|
|
|
OUT UINT16 *TableSize
|
|
|
|
);
|
|
|
|
|
2008-10-13 04:54:29 +02:00
|
|
|
///
|
2018-06-27 15:11:33 +02:00
|
|
|
/// The EFI_USB_IO_PROTOCOL provides four basic transfers types described
|
|
|
|
/// in the USB 1.1 Specification. These include control transfer, interrupt
|
|
|
|
/// transfer, bulk transfer and isochronous transfer. The EFI_USB_IO_PROTOCOL
|
|
|
|
/// also provides some basic USB device/controller management and configuration
|
|
|
|
/// interfaces. A USB device driver uses the services of this protocol to manage USB devices.
|
2008-10-13 04:54:29 +02:00
|
|
|
///
|
2007-06-19 12:12:02 +02:00
|
|
|
struct _EFI_USB_IO_PROTOCOL {
|
|
|
|
//
|
|
|
|
// IO transfer
|
|
|
|
//
|
2021-12-05 23:54:05 +01:00
|
|
|
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;
|
2007-06-19 12:12:02 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Common device request
|
|
|
|
//
|
2021-12-05 23:54:05 +01:00
|
|
|
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;
|
2007-06-19 12:12:02 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Reset controller's parent port
|
|
|
|
//
|
2021-12-05 23:54:05 +01:00
|
|
|
EFI_USB_IO_PORT_RESET UsbPortReset;
|
2007-06-19 12:12:02 +02:00
|
|
|
};
|
|
|
|
|
2021-12-05 23:54:05 +01:00
|
|
|
extern EFI_GUID gEfiUsbIoProtocolGuid;
|
2007-06-19 12:12:02 +02:00
|
|
|
|
|
|
|
#endif
|