2008-04-17 07:48:13 +02:00
|
|
|
/*++
|
|
|
|
|
2010-04-28 14:39:50 +02:00
|
|
|
Copyright (c) 2006, Intel Corporation. All rights reserved.<BR>
|
|
|
|
This program and the accompanying materials
|
2008-04-17 07:48:13 +02:00
|
|
|
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:
|
|
|
|
|
|
|
|
DeviceIo.h
|
|
|
|
|
|
|
|
Abstract:
|
|
|
|
|
|
|
|
Private Data definition for Device IO driver
|
|
|
|
|
|
|
|
--*/
|
|
|
|
|
|
|
|
#ifndef _DEVICE_IO_H
|
|
|
|
#define _DEVICE_IO_H
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-12-16 16:31:52 +01:00
|
|
|
#define DEVICE_IO_PRIVATE_DATA_SIGNATURE SIGNATURE_32 ('d', 'e', 'v', 'I')
|
2008-04-17 07:48:13 +02:00
|
|
|
|
|
|
|
#define MAX_COMMON_BUFFER 0x00000000FFFFFFFF
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINTN Signature;
|
|
|
|
EFI_HANDLE Handle;
|
|
|
|
EFI_DEVICE_IO_PROTOCOL DeviceIo;
|
|
|
|
EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL *PciRootBridgeIo;
|
|
|
|
EFI_DEVICE_PATH_PROTOCOL *DevicePath;
|
|
|
|
UINT16 PrimaryBus;
|
|
|
|
UINT16 SubordinateBus;
|
|
|
|
} DEVICE_IO_PRIVATE_DATA;
|
|
|
|
|
|
|
|
#define DEVICE_IO_PRIVATE_DATA_FROM_THIS(a) CR (a, DEVICE_IO_PRIVATE_DATA, DeviceIo, DEVICE_IO_PRIVATE_DATA_SIGNATURE)
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
DeviceIoConstructor (
|
|
|
|
IN EFI_HANDLE Handle,
|
|
|
|
IN EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL *PciRootBridgeIo,
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *DevicePath,
|
|
|
|
IN UINT16 PrimaryBus,
|
|
|
|
IN UINT16 SubordinateBus
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Initialize and install a Device IO protocol on a empty device path handle.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
Handle - Handle of PCI RootBridge IO instance
|
|
|
|
PciRootBridgeIo - PCI RootBridge IO instance
|
|
|
|
DevicePath - Device Path of PCI RootBridge IO instance
|
|
|
|
PrimaryBus - Primary Bus
|
|
|
|
SubordinateBus - Subordinate Bus
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - This driver is added to ControllerHandle.
|
|
|
|
EFI_ALREADY_STARTED - This driver is already running on ControllerHandle.
|
|
|
|
Others - This driver does not support this device.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoMemRead (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN EFI_IO_WIDTH Width,
|
|
|
|
IN UINT64 Address,
|
|
|
|
IN UINTN Count,
|
|
|
|
IN OUT VOID *Buffer
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Perform reading memory mapped I/O space of device.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to EFI_DEVICE_IO protocol instance.
|
|
|
|
Width - Width of I/O operations.
|
|
|
|
Address - The base address of I/O operations.
|
|
|
|
Count - The number of I/O operations to perform.
|
|
|
|
Bytes moves is Width size * Count, starting at Address.
|
|
|
|
Buffer - The destination buffer to store results.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The data was read from the device.
|
|
|
|
EFI_INVALID_PARAMETER - Width is invalid.
|
|
|
|
EFI_OUT_OF_RESOURCES - The request could not be completed due to lack of resources.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoMemWrite (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN EFI_IO_WIDTH Width,
|
|
|
|
IN UINT64 Address,
|
|
|
|
IN UINTN Count,
|
|
|
|
IN OUT VOID *Buffer
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Perform writing memory mapped I/O space of device.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to EFI_DEVICE_IO protocol instance.
|
|
|
|
Width - Width of I/O operations.
|
|
|
|
Address - The base address of I/O operations.
|
|
|
|
Count - The number of I/O operations to perform.
|
|
|
|
Bytes moves is Width size * Count, starting at Address.
|
|
|
|
Buffer - The source buffer of data to be written.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The data was written to the device.
|
|
|
|
EFI_INVALID_PARAMETER - Width is invalid.
|
|
|
|
EFI_OUT_OF_RESOURCES - The request could not be completed due to lack of resources.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoIoRead (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN EFI_IO_WIDTH Width,
|
|
|
|
IN UINT64 Address,
|
|
|
|
IN UINTN Count,
|
|
|
|
IN OUT VOID *Buffer
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Perform reading I/O space of device.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to EFI_DEVICE_IO protocol instance.
|
|
|
|
Width - Width of I/O operations.
|
|
|
|
Address - The base address of I/O operations.
|
|
|
|
Count - The number of I/O operations to perform.
|
|
|
|
Bytes moves is Width size * Count, starting at Address.
|
|
|
|
Buffer - The destination buffer to store results.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The data was read from the device.
|
|
|
|
EFI_INVALID_PARAMETER - Width is invalid.
|
|
|
|
EFI_OUT_OF_RESOURCES - The request could not be completed due to lack of resources.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoIoWrite (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN EFI_IO_WIDTH Width,
|
|
|
|
IN UINT64 Address,
|
|
|
|
IN UINTN Count,
|
|
|
|
IN OUT VOID *Buffer
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Perform writing I/O space of device.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to EFI_DEVICE_IO protocol instance.
|
|
|
|
Width - Width of I/O operations.
|
|
|
|
Address - The base address of I/O operations.
|
|
|
|
Count - The number of I/O operations to perform.
|
|
|
|
Bytes moves is Width size * Count, starting at Address.
|
|
|
|
Buffer - The source buffer of data to be written.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The data was written to the device.
|
|
|
|
EFI_INVALID_PARAMETER - Width is invalid.
|
|
|
|
EFI_OUT_OF_RESOURCES - The request could not be completed due to lack of resources.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoPciRead (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN EFI_IO_WIDTH Width,
|
|
|
|
IN UINT64 Address,
|
|
|
|
IN UINTN Count,
|
|
|
|
IN OUT VOID *Buffer
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Perform reading PCI configuration space of device
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to EFI_DEVICE_IO protocol instance.
|
|
|
|
Width - Width of I/O operations.
|
|
|
|
Address - The base address of I/O operations.
|
|
|
|
Count - The number of I/O operations to perform.
|
|
|
|
Bytes moves is Width size * Count, starting at Address.
|
|
|
|
Buffer - The destination buffer to store results.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The data was read from the device.
|
|
|
|
EFI_INVALID_PARAMETER - Width is invalid.
|
|
|
|
EFI_OUT_OF_RESOURCES - The request could not be completed due to lack of resources.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoPciWrite (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN EFI_IO_WIDTH Width,
|
|
|
|
IN UINT64 Address,
|
|
|
|
IN UINTN Count,
|
|
|
|
IN OUT VOID *Buffer
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Perform writing PCI configuration space of device.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to EFI_DEVICE_IO protocol instance.
|
|
|
|
Width - Width of I/O operations.
|
|
|
|
Address - The base address of I/O operations.
|
|
|
|
Count - The number of I/O operations to perform.
|
|
|
|
Bytes moves is Width size * Count, starting at Address.
|
|
|
|
Buffer - The source buffer of data to be written.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The data was written to the device.
|
|
|
|
EFI_INVALID_PARAMETER - Width is invalid.
|
|
|
|
EFI_OUT_OF_RESOURCES - The request could not be completed due to lack of resources.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoPciDevicePath (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN UINT64 Address,
|
|
|
|
IN OUT EFI_DEVICE_PATH_PROTOCOL **PciDevicePath
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Append a PCI device path node to another device path.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to EFI_DEVICE_IO_PROTOCOL.
|
|
|
|
Address - PCI bus,device, function.
|
|
|
|
PciDevicePath - PCI device path.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
Pointer to the appended PCI device path.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoMap (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN EFI_IO_OPERATION_TYPE Operation,
|
|
|
|
IN EFI_PHYSICAL_ADDRESS *HostAddress,
|
|
|
|
IN OUT UINTN *NumberOfBytes,
|
|
|
|
OUT EFI_PHYSICAL_ADDRESS *DeviceAddress,
|
|
|
|
OUT VOID **Mapping
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Provides the device-specific addresses needed to access system memory.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to the EFI_DEVICE_IO_INTERFACE instance.
|
|
|
|
Operation - Indicates if the bus master is going to read or write to system memory.
|
|
|
|
HostAddress - The system memory address to map to the device.
|
|
|
|
NumberOfBytes - On input the number of bytes to map. On output the number of bytes
|
|
|
|
that were mapped.
|
|
|
|
DeviceAddress - The resulting map address for the bus master device to use to access the
|
|
|
|
hosts HostAddress.
|
|
|
|
Mapping - A resulting value to pass to Unmap().
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The range was mapped for the returned NumberOfBytes.
|
|
|
|
EFI_INVALID_PARAMETER - The Operation or HostAddress is undefined.
|
|
|
|
EFI_UNSUPPORTED - The HostAddress cannot be mapped as a common buffer.
|
|
|
|
EFI_DEVICE_ERROR - The system hardware could not map the requested address.
|
|
|
|
EFI_OUT_OF_RESOURCES - The request could not be completed due to a lack of resources.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoUnmap (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN VOID *Mapping
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Completes the Map() operation and releases any corresponding resources.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to the EFI_DEVICE_IO_INTERFACE instance.
|
|
|
|
Mapping - The mapping value returned from Map().
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The range was unmapped.
|
|
|
|
EFI_DEVICE_ERROR - The data was not committed to the target system memory.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoAllocateBuffer (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN EFI_ALLOCATE_TYPE Type,
|
|
|
|
IN EFI_MEMORY_TYPE MemoryType,
|
|
|
|
IN UINTN Pages,
|
|
|
|
IN OUT EFI_PHYSICAL_ADDRESS *HostAddress
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Allocates pages that are suitable for an EFIBusMasterCommonBuffer mapping.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to the EFI_DEVICE_IO_INTERFACE instance.
|
|
|
|
Type - The type allocation to perform.
|
|
|
|
MemoryType - The type of memory to allocate, EfiBootServicesData or
|
|
|
|
EfiRuntimeServicesData.
|
|
|
|
Pages - The number of pages to allocate.
|
|
|
|
HostAddress - A pointer to store the base address of the allocated range.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The requested memory pages were allocated.
|
|
|
|
EFI_OUT_OF_RESOURCES - The memory pages could not be allocated.
|
|
|
|
EFI_INVALID_PARAMETER - The requested memory type is invalid.
|
|
|
|
EFI_UNSUPPORTED - The requested PhysicalAddress is not supported on
|
|
|
|
this platform.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoFlush (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Flushes any posted write data to the device.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to the EFI_DEVICE_IO_INTERFACE instance.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The buffers were flushed.
|
|
|
|
EFI_DEVICE_ERROR - The buffers were not flushed due to a hardware error.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeviceIoFreeBuffer (
|
|
|
|
IN EFI_DEVICE_IO_PROTOCOL *This,
|
|
|
|
IN UINTN Pages,
|
|
|
|
IN EFI_PHYSICAL_ADDRESS HostAddress
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Frees pages that were allocated with AllocateBuffer().
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - A pointer to the EFI_DEVICE_IO_INTERFACE instance.
|
|
|
|
Pages - The number of pages to free.
|
|
|
|
HostAddress - The base address of the range to free.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_SUCCESS - The requested memory pages were freed.
|
|
|
|
EFI_NOT_FOUND - The requested memory pages were not allocated with
|
|
|
|
AllocateBuffer().
|
|
|
|
EFI_INVALID_PARAMETER - HostAddress is not page aligned or Pages is invalid.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|