mirror of https://github.com/acidanthera/audk.git
Add super IO protocol from PI 1.2 specification.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@9162 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
d82018184e
commit
bf3a8d8beb
|
@ -0,0 +1,194 @@
|
||||||
|
/** @file
|
||||||
|
The Super I/O Protocol is installed by the Super I/O driver. The Super I/O driver is a UEFI driver
|
||||||
|
model compliant driver. In the Start() routine of the Super I/O driver, a handle with an instance
|
||||||
|
of EFI_SIO_PROTOCOL is created for each device within the Super I/O. The device within the
|
||||||
|
Super I/O is powered up, enabled, and assigned with the default set of resources. In the Stop()
|
||||||
|
routine of the Super I/O driver, the device is disabled and Super I/O protocol is uninstalled.
|
||||||
|
|
||||||
|
Copyright (c) 2006 - 2008, 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.
|
||||||
|
|
||||||
|
**/
|
||||||
|
|
||||||
|
#ifndef __EFI_SUPER_IO_PROTOCOL_H__
|
||||||
|
#define __EFI_SUPER_IO_PROTOCOL_H__
|
||||||
|
|
||||||
|
#define EFI_SIO_PROTOCOL_GUID \
|
||||||
|
{ 0x215fdd18, 0xbd50, 0x4feb, { 0x89, 0xb, 0x58, 0xca, 0xb, 0x47, 0x39, 0xe9 } }
|
||||||
|
|
||||||
|
typedef union {
|
||||||
|
UINT8 Byte;
|
||||||
|
struct {
|
||||||
|
UINT8 Length : 3;
|
||||||
|
UINT8 Name : 4;
|
||||||
|
UINT8 Type : 1;
|
||||||
|
} Bits;
|
||||||
|
} ACPI_SMALL_RESOURCE_HEADER;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
union {
|
||||||
|
UINT8 Byte;
|
||||||
|
struct{
|
||||||
|
UINT8 Name : 7;
|
||||||
|
UINT8 Type : 1;
|
||||||
|
}Bits;
|
||||||
|
} Header;
|
||||||
|
UINT16 Length;
|
||||||
|
} ACPI_LARGE_RESOURCE_HEADER;
|
||||||
|
|
||||||
|
typedef union {
|
||||||
|
ACPI_SMALL_RESOURCE_HEADER *SmallHeader;
|
||||||
|
ACPI_LARGE_RESOURCE_HEADER *LargeHeader;
|
||||||
|
} ACPI_RESOURCE_HEADER_PTR;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
UINT8 Register; ///< Register number.
|
||||||
|
UINT8 AndMask; ///< Bitwise AND mask.
|
||||||
|
UINT8 OrMask; ///< Bitwise OR mask.
|
||||||
|
} EFI_SIO_REGISTER_MODIFY;
|
||||||
|
|
||||||
|
typedef struct _EFI_SIO_PROTOCOL EFI_SIO_PROTOCOL;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Provides a low level access to the registers for the Super I/O.
|
||||||
|
|
||||||
|
@param[in] This Indicates a pointer to the calling context.
|
||||||
|
@param[in] Write Specifies the type of the register operation. If this parameter is TRUE, Value is
|
||||||
|
interpreted as an input parameter and the operation is a register write. If this parameter
|
||||||
|
is FALSE, Value is interpreted as an output parameter and the operation is a register
|
||||||
|
read.
|
||||||
|
@param[in] ExitCfgMode Exit Configuration Mode Indicator. If this parameter is set to TRUE, the Super I/O
|
||||||
|
driver will turn off configuration mode of the Super I/O prior to returning from this
|
||||||
|
function. If this parameter is set to FALSE, the Super I/O driver will leave Super I/O
|
||||||
|
in the configuration mode.
|
||||||
|
The Super I/O driver must track the current state of the Super I/O and enable the
|
||||||
|
configuration mode of Super I/O if necessary prior to register access.
|
||||||
|
@param[in] Register Register number.
|
||||||
|
@param[in, out] Value If Write is TRUE, Value is a pointer to the buffer containing the byte of data to be
|
||||||
|
written to the Super I/O register. If Write is FALSE, Value is a pointer to the
|
||||||
|
destination buffer for the byte of data to be read from the Super I/O register.
|
||||||
|
|
||||||
|
@retval EFI_SUCCESS The operation completed successfully
|
||||||
|
@retval EFI_INVALID_PARAMETER The Value is NULL
|
||||||
|
@retval EFI_INVALID_PARAMETER Invalid Register number
|
||||||
|
|
||||||
|
**/
|
||||||
|
typedef
|
||||||
|
EFI_STATUS
|
||||||
|
(EFIAPI *EFI_SIO_REGISTER_ACCESS)(
|
||||||
|
IN CONST EFI_SIO_PROTOCOL *This,
|
||||||
|
IN BOOLEAN Write,
|
||||||
|
IN BOOLEAN ExitCfgMode,
|
||||||
|
IN UINT8 Register,
|
||||||
|
IN OUT UINT8 *Value
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Provides an interface to get a list of the current resources consumed by the device in the ACPI
|
||||||
|
Resource Descriptor format.
|
||||||
|
|
||||||
|
GetResources() returns a list of resources currently consumed by the device. The
|
||||||
|
ResourceList is a pointer to the buffer containing resource descriptors for the device. The
|
||||||
|
descriptors are in the format of Small or Large ACPI resource descriptor as defined by ACPI
|
||||||
|
specification (2.0 & 3.0). The buffer of resource descriptors is terminated with the 'End tag'
|
||||||
|
resource descriptor.
|
||||||
|
|
||||||
|
@param[in] This Indicates a pointer to the calling context.
|
||||||
|
@param[out] ResourceList A pointer to an ACPI resource descriptor list that defines the current resources used by
|
||||||
|
the device. Type ACPI_RESOURCE_HEADER_PTR is defined in the "Related
|
||||||
|
Definitions" below.
|
||||||
|
|
||||||
|
@retval EFI_SUCCESS The operation completed successfully
|
||||||
|
@retval EFI_INVALID_PARAMETER ResourceList is NULL
|
||||||
|
|
||||||
|
**/
|
||||||
|
typedef
|
||||||
|
EFI_STATUS
|
||||||
|
(EFIAPI *EFI_SIO_GET_RESOURCES)(
|
||||||
|
IN CONST EFI_SIO_PROTOCOL *This,
|
||||||
|
OUT ACPI_RESOURCE_HEADER_PTR *ResourceList
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Sets the resources for the device.
|
||||||
|
|
||||||
|
@param[in] This Indicates a pointer to the calling context.
|
||||||
|
@param[in] ResourceList Pointer to the ACPI resource descriptor list. Type ACPI_RESOURCE_HEADER_PTR
|
||||||
|
is defined in the "Related Definitions" section of
|
||||||
|
EFI_SIO_PROTOCOL.GetResources().
|
||||||
|
|
||||||
|
@retval EFI_SUCCESS The operation completed successfully
|
||||||
|
@retval EFI_INVALID_PARAMETER ResourceList is invalid
|
||||||
|
@retval EFI_ACCESS_DENIED Some of the resources in ResourceList are in use
|
||||||
|
|
||||||
|
**/
|
||||||
|
typedef
|
||||||
|
EFI_STATUS
|
||||||
|
(EFIAPI *EFI_SIO_SET_RESOURCES)(
|
||||||
|
IN CONST EFI_SIO_PROTOCOL *This,
|
||||||
|
IN ACPI_RESOURCE_HEADER_PTR ResourceList
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Provides a collection of resource descriptor lists. Each resource descriptor list in the collection
|
||||||
|
defines a combination of resources that can potentially be used by the device.
|
||||||
|
|
||||||
|
@param[in] This Indicates a pointer to the calling context.
|
||||||
|
@param[out] ResourceCollection Collection of the resource descriptor lists.
|
||||||
|
|
||||||
|
@retval EFI_SUCCESS The operation completed successfully
|
||||||
|
@retval EFI_INVALID_PARAMETER ResourceCollection is NULL
|
||||||
|
**/
|
||||||
|
typedef
|
||||||
|
EFI_STATUS
|
||||||
|
(EFIAPI *EFI_SIO_POSSIBLE_RESOURCES)(
|
||||||
|
IN CONST EFI_SIO_PROTOCOL *This,
|
||||||
|
OUT ACPI_RESOURCE_HEADER_PTR *ResourceCollection
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Provides an interface for a table based programming of the Super I/O registers.
|
||||||
|
|
||||||
|
The Modify() function provides an interface for table based programming of the Super I/O
|
||||||
|
registers. This function can be used to perform programming of multiple Super I/O registers with a
|
||||||
|
single function call. For each table entry, the Register is read, its content is bitwise ANDed with
|
||||||
|
AndMask, and then ORed with OrMask before being written back to the Register. The Super
|
||||||
|
I/O driver must track the current state of the Super I/O and enable the configuration mode of Super I/
|
||||||
|
O if necessary prior to table processing. Once the table is processed, the Super I/O device has to be
|
||||||
|
returned to the original state.
|
||||||
|
|
||||||
|
@param[in] This Indicates a pointer to the calling context.
|
||||||
|
@param[in] Command A pointer to an array of NumberOfCommands EFI_SIO_REGISTER_MODIFY
|
||||||
|
structures. Each structure specifies a single Super I/O register modify operation. Type
|
||||||
|
EFI_SIO_REGISTER_MODIFY is defined in the "Related Definitions" below.
|
||||||
|
@param[in] NumberOfCommands Number of elements in the Command array.
|
||||||
|
|
||||||
|
@retval EFI_SUCCESS The operation completed successfully
|
||||||
|
@retval EFI_INVALID_PARAMETER Command is NULL
|
||||||
|
|
||||||
|
**/
|
||||||
|
typedef
|
||||||
|
EFI_STATUS
|
||||||
|
(EFIAPI *EFI_SIO_MODIFY)(
|
||||||
|
IN CONST EFI_SIO_PROTOCOL *This,
|
||||||
|
IN CONST EFI_SIO_REGISTER_MODIFY *Command,
|
||||||
|
IN UINTN NumberOfCommands
|
||||||
|
);
|
||||||
|
|
||||||
|
struct _EFI_SIO_PROTOCOL {
|
||||||
|
EFI_SIO_REGISTER_ACCESS RegisterAccess;
|
||||||
|
EFI_SIO_GET_RESOURCES GetResources;
|
||||||
|
EFI_SIO_SET_RESOURCES SetResources;
|
||||||
|
EFI_SIO_POSSIBLE_RESOURCES PossibleResources;
|
||||||
|
EFI_SIO_MODIFY Modify;
|
||||||
|
};
|
||||||
|
|
||||||
|
extern EFI_GUID gEfiSioProtocolGuid;
|
||||||
|
|
||||||
|
#endif // __EFI_SUPER_IO_PROTOCOL_H__
|
|
@ -572,6 +572,9 @@
|
||||||
## Include/Protocol/AcpiSystemDescriptionTable.h
|
## Include/Protocol/AcpiSystemDescriptionTable.h
|
||||||
gEfiAcpiSdtProtocolGuid = { 0xeb97088e, 0xcfdf, 0x49c6, { 0xbe, 0x4b, 0xd9, 0x6, 0xa5, 0xb2, 0xe, 0x86 }}
|
gEfiAcpiSdtProtocolGuid = { 0xeb97088e, 0xcfdf, 0x49c6, { 0xbe, 0x4b, 0xd9, 0x6, 0xa5, 0xb2, 0xe, 0x86 }}
|
||||||
|
|
||||||
|
## Include/Protocol/SuperIo.h
|
||||||
|
gEfiSioProtocolGuid = { 0x215fdd18, 0xbd50, 0x4feb, { 0x89, 0xb, 0x58, 0xca, 0xb, 0x47, 0x39, 0xe9 } }
|
||||||
|
|
||||||
#
|
#
|
||||||
# Protocols defined in UEFI2.1/UEFI2.0/EFI1.1
|
# Protocols defined in UEFI2.1/UEFI2.0/EFI1.1
|
||||||
#
|
#
|
||||||
|
|
Loading…
Reference in New Issue