2020-08-05 16:43:33 +02:00
|
|
|
/** @file
|
|
|
|
AML Lib.
|
|
|
|
|
2021-09-30 09:48:20 +02:00
|
|
|
Copyright (c) 2019 - 2021, Arm Limited. All rights reserved.<BR>
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef AML_LIB_H_
|
|
|
|
#define AML_LIB_H_
|
|
|
|
|
|
|
|
/**
|
|
|
|
@mainpage Dynamic AML Generation
|
|
|
|
@{
|
|
|
|
@par Summary
|
|
|
|
@{
|
|
|
|
ACPI tables are categorized as data tables and definition block
|
|
|
|
tables. Dynamic Tables Framework currently supports generation of ACPI
|
|
|
|
data tables. Generation of definition block tables is difficult as these
|
|
|
|
tables are encoded in ACPI Machine Language (AML), which has a complex
|
|
|
|
grammar.
|
|
|
|
|
|
|
|
Dynamic AML Generation is an extension to the Dynamic tables Framework.
|
|
|
|
One of the techniques used to simplify definition block generation is to
|
|
|
|
fixup a template SSDT table.
|
|
|
|
|
|
|
|
Dynamic AML aims to provide a framework that allows fixing up of an ACPI
|
|
|
|
SSDT template with appropriate information about the hardware.
|
|
|
|
|
|
|
|
This framework consists of an:
|
|
|
|
- AMLLib core that implements a rich set of interfaces to parse, traverse
|
|
|
|
and update AML data.
|
|
|
|
- AMLLib library APIs that provides interfaces to search and updates nodes
|
|
|
|
in the AML namespace.
|
|
|
|
@}
|
|
|
|
@}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <IndustryStandard/Acpi.h>
|
|
|
|
|
|
|
|
#ifndef AML_HANDLE
|
|
|
|
|
|
|
|
/** Node handle.
|
|
|
|
*/
|
2021-12-05 23:53:55 +01:00
|
|
|
typedef void *AML_NODE_HANDLE;
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
/** Root Node handle.
|
|
|
|
*/
|
2021-12-05 23:53:55 +01:00
|
|
|
typedef void *AML_ROOT_NODE_HANDLE;
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
/** Object Node handle.
|
|
|
|
*/
|
2021-12-05 23:53:55 +01:00
|
|
|
typedef void *AML_OBJECT_NODE_HANDLE;
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
/** Data Node handle.
|
|
|
|
*/
|
2021-12-05 23:53:55 +01:00
|
|
|
typedef void *AML_DATA_NODE_HANDLE;
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
#endif // AML_HANDLE
|
|
|
|
|
|
|
|
/** Parse the definition block.
|
|
|
|
|
|
|
|
The function parses the whole AML blob. It starts with the ACPI DSDT/SSDT
|
|
|
|
header and then parses the AML bytestream.
|
|
|
|
A tree structure is returned via the RootPtr.
|
|
|
|
The tree must be deleted with the AmlDeleteTree function.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] DefinitionBlock Pointer to the definition block.
|
|
|
|
@param [out] RootPtr Pointer to the root node of the AML tree.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_BUFFER_TOO_SMALL No space left in the buffer.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Could not allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlParseDefinitionBlock (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST EFI_ACPI_DESCRIPTION_HEADER *DefinitionBlock,
|
|
|
|
OUT AML_ROOT_NODE_HANDLE *RootPtr
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Serialize an AML definition block.
|
|
|
|
|
|
|
|
This functions allocates memory with the "AllocateZeroPool ()"
|
|
|
|
function. This memory is used to serialize the AML tree and is
|
|
|
|
returned in the Table.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] RootNode Root node of the tree.
|
|
|
|
@param [out] Table On return, hold the serialized
|
|
|
|
definition block.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Could not allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlSerializeDefinitionBlock (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_ROOT_NODE_HANDLE RootNode,
|
|
|
|
OUT EFI_ACPI_DESCRIPTION_HEADER **Table
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Clone a node and its children (clone a tree branch).
|
|
|
|
|
|
|
|
The cloned branch returned is not attached to any tree.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] Node Pointer to a node.
|
|
|
|
Node is the head of the branch to clone.
|
|
|
|
@param [out] ClonedNode Pointer holding the head of the created cloned
|
|
|
|
branch.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Could not allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCloneTree (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_NODE_HANDLE Node,
|
|
|
|
OUT AML_NODE_HANDLE *ClonedNode
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Delete a Node and its children.
|
|
|
|
|
|
|
|
The Node must be removed from the tree first,
|
|
|
|
or must be the root node.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] Node Pointer to the node to delete.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlDeleteTree (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_NODE_HANDLE Node
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Detach the Node from the tree.
|
|
|
|
|
|
|
|
The function will fail if the Node is in its parent's fixed
|
|
|
|
argument list.
|
|
|
|
The Node is not deleted. The deletion is done separately
|
|
|
|
from the removal.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] Node Pointer to a Node.
|
|
|
|
Must be a data node or an object node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlDetachNode (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_NODE_HANDLE Node
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Find a node in the AML namespace, given an ASL path and a reference Node.
|
|
|
|
|
|
|
|
- The AslPath can be an absolute path, or a relative path from the
|
|
|
|
reference Node;
|
|
|
|
- Node must be a root node or a namespace node;
|
|
|
|
- A root node is expected to be at the top of the tree.
|
|
|
|
|
|
|
|
E.g.:
|
|
|
|
For the following AML namespace, with the ReferenceNode being the node with
|
|
|
|
the name "AAAA":
|
|
|
|
- the node with the name "BBBB" can be found by looking for the ASL
|
|
|
|
path "BBBB";
|
|
|
|
- the root node can be found by looking for the ASL relative path "^",
|
|
|
|
or the absolute path "\\".
|
|
|
|
|
|
|
|
AML namespace:
|
|
|
|
\
|
|
|
|
\-AAAA <- ReferenceNode
|
|
|
|
\-BBBB
|
|
|
|
|
|
|
|
@ingroup NameSpaceApis
|
|
|
|
|
|
|
|
@param [in] ReferenceNode Reference node.
|
|
|
|
If a relative path is given, the
|
|
|
|
search is done from this node. If
|
|
|
|
an absolute path is given, the
|
|
|
|
search is done from the root node.
|
|
|
|
Must be a root node or an object
|
|
|
|
node which is part of the
|
|
|
|
namespace.
|
|
|
|
@param [in] AslPath ASL path to the searched node in
|
|
|
|
the namespace. An ASL path name is
|
|
|
|
NULL terminated. Can be a relative
|
|
|
|
or absolute path.
|
|
|
|
E.g.: "\\_SB.CLU0.CPU0" or "^CPU0"
|
|
|
|
@param [out] OutNode Pointer to the found node.
|
|
|
|
Contains NULL if not found.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_BUFFER_TOO_SMALL No space left in the buffer.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Out of memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlFindNode (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_NODE_HANDLE ReferenceNode,
|
|
|
|
IN CHAR8 *AslPath,
|
|
|
|
OUT AML_NODE_HANDLE *OutNode
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
@defgroup UserApis User APIs
|
|
|
|
@{
|
|
|
|
User APIs are implemented to ease most common actions that might be done
|
|
|
|
using the AmlLib. They allow to find specific objects like "_UID" or
|
|
|
|
"_CRS" and to update their value. It also shows what can be done using
|
|
|
|
AmlLib functions.
|
|
|
|
@}
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** Update the name of a DeviceOp object node.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] DeviceOpNode Object node representing a Device.
|
|
|
|
Must have an OpCode=AML_NAME_OP, SubOpCode=0.
|
|
|
|
OpCode/SubOpCode.
|
|
|
|
DeviceOp object nodes are defined in ASL
|
|
|
|
using the "Device ()" function.
|
|
|
|
@param [in] NewNameString The new Device's name.
|
|
|
|
Must be a NULL-terminated ASL NameString
|
|
|
|
e.g.: "DEV0", "DV15.DEV0", etc.
|
|
|
|
The input string is copied.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlDeviceOpUpdateName (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_OBJECT_NODE_HANDLE DeviceOpNode,
|
|
|
|
IN CHAR8 *NewNameString
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Update an integer value defined by a NameOp object node.
|
|
|
|
|
|
|
|
For compatibility reasons, the NameOpNode must initially
|
|
|
|
contain an integer.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] NameOpNode NameOp object node.
|
|
|
|
Must have an OpCode=AML_NAME_OP, SubOpCode=0.
|
|
|
|
NameOp object nodes are defined in ASL
|
|
|
|
using the "Name ()" function.
|
|
|
|
@param [in] NewInt New Integer value to assign.
|
|
|
|
Must be a UINT64.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlNameOpUpdateInteger (
|
|
|
|
IN AML_OBJECT_NODE_HANDLE NameOpNode,
|
|
|
|
IN UINT64 NewInt
|
|
|
|
);
|
|
|
|
|
|
|
|
/** Update a string value defined by a NameOp object node.
|
|
|
|
|
|
|
|
The NameOpNode must initially contain a string.
|
|
|
|
The EISAID ASL macro converts a string to an integer. This, it is
|
|
|
|
not accepted.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] NameOpNode NameOp object node.
|
|
|
|
Must have an OpCode=AML_NAME_OP, SubOpCode=0.
|
|
|
|
NameOp object nodes are defined in ASL
|
|
|
|
using the "Name ()" function.
|
|
|
|
@param [in] NewName New NULL terminated string to assign to
|
|
|
|
the NameOpNode.
|
|
|
|
The input string is copied.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlNameOpUpdateString (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_OBJECT_NODE_HANDLE NameOpNode,
|
|
|
|
IN CONST CHAR8 *NewName
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
2021-09-30 09:48:20 +02:00
|
|
|
/** Get the first Resource Data element contained in a named object.
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
In the following ASL code, the function will return the Resource Data
|
|
|
|
node corresponding to the "QWordMemory ()" ASL macro.
|
|
|
|
Name (_CRS, ResourceTemplate() {
|
|
|
|
QWordMemory (...) {...},
|
|
|
|
Interrupt (...) {...}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
Note:
|
2021-09-30 09:48:20 +02:00
|
|
|
"_CRS" names defined as methods are not handled by this function.
|
|
|
|
They must be defined as names, using the "Name ()" statement.
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
2021-09-30 09:48:20 +02:00
|
|
|
@param [in] NameOpNode NameOp object node defining a named object.
|
|
|
|
Must have an OpCode=AML_NAME_OP, SubOpCode=0.
|
|
|
|
NameOp object nodes are defined in ASL
|
|
|
|
using the "Name ()" function.
|
|
|
|
@param [out] OutRdNode Pointer to the first Resource Data element of
|
|
|
|
the named object. A Resource Data element
|
|
|
|
is stored in a data node.
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
2021-09-30 09:48:20 +02:00
|
|
|
AmlNameOpGetFirstRdNode (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_OBJECT_NODE_HANDLE NameOpNode,
|
|
|
|
OUT AML_DATA_NODE_HANDLE *OutRdNode
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Get the Resource Data element following the CurrRdNode Resource Data.
|
|
|
|
|
|
|
|
In the following ASL code, if CurrRdNode corresponds to the first
|
|
|
|
"QWordMemory ()" ASL macro, the function will return the Resource Data
|
|
|
|
node corresponding to the "Interrupt ()" ASL macro.
|
|
|
|
Name (_CRS, ResourceTemplate() {
|
|
|
|
QwordMemory (...) {...},
|
|
|
|
Interrupt (...) {...}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
2021-09-30 09:48:20 +02:00
|
|
|
Note:
|
|
|
|
"_CRS" names defined as methods are not handled by this function.
|
|
|
|
They must be defined as names, using the "Name ()" statement.
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] CurrRdNode Pointer to the current Resource Data element of
|
2021-09-30 09:48:20 +02:00
|
|
|
the named object.
|
2020-08-05 16:43:33 +02:00
|
|
|
@param [out] OutRdNode Pointer to the Resource Data element following
|
|
|
|
the CurrRdNode.
|
|
|
|
Contain a NULL pointer if CurrRdNode is the
|
|
|
|
last Resource Data element in the list.
|
|
|
|
The "End Tag" is not considered as a resource
|
|
|
|
data element and is not returned.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
2021-09-30 09:48:20 +02:00
|
|
|
AmlNameOpGetNextRdNode (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_DATA_NODE_HANDLE CurrRdNode,
|
|
|
|
OUT AML_DATA_NODE_HANDLE *OutRdNode
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Update the first interrupt of an Interrupt resource data node.
|
|
|
|
|
|
|
|
The flags of the Interrupt resource data are left unchanged.
|
|
|
|
|
|
|
|
The InterruptRdNode corresponds to the Resource Data created by the
|
|
|
|
"Interrupt ()" ASL macro. It is an Extended Interrupt Resource Data.
|
|
|
|
See ACPI 6.3 specification, s6.4.3.6 "Extended Interrupt Descriptor"
|
|
|
|
for more information about Extended Interrupt Resource Data.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] InterruptRdNode Pointer to the an extended interrupt
|
|
|
|
resource data node.
|
|
|
|
@param [in] Irq Interrupt value to update.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Out of resources.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlUpdateRdInterrupt (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_DATA_NODE_HANDLE InterruptRdNode,
|
|
|
|
IN UINT32 Irq
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Update the base address and length of a QWord resource data node.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] QWordRdNode Pointer a QWord resource data
|
|
|
|
node.
|
|
|
|
@param [in] BaseAddress Base address.
|
|
|
|
@param [in] BaseAddressLength Base address length.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Out of resources.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlUpdateRdQWord (
|
|
|
|
IN AML_DATA_NODE_HANDLE QWordRdNode,
|
|
|
|
IN UINT64 BaseAddress,
|
|
|
|
IN UINT64 BaseAddressLength
|
|
|
|
);
|
|
|
|
|
2021-12-09 10:24:58 +01:00
|
|
|
/** Code generation for the "DWordIO ()" ASL function.
|
|
|
|
|
|
|
|
The Resource Data effectively created is a DWord Address Space Resource
|
|
|
|
Data. Cf ACPI 6.4:
|
|
|
|
- s6.4.3.5.2 "DWord Address Space Descriptor".
|
|
|
|
- s19.6.34 "DWordIO".
|
|
|
|
|
|
|
|
The created resource data node can be:
|
|
|
|
- appended to the list of resource data elements of the NameOpNode.
|
|
|
|
In such case NameOpNode must be defined by a the "Name ()" ASL statement
|
|
|
|
and initially contain a "ResourceTemplate ()".
|
|
|
|
- returned through the NewRdNode parameter.
|
|
|
|
|
|
|
|
See ACPI 6.4 spec, s19.6.34 for more.
|
|
|
|
|
|
|
|
@param [in] IsResourceConsumer ResourceUsage parameter.
|
|
|
|
@param [in] IsMinFixed Minimum address is fixed.
|
|
|
|
@param [in] IsMaxFixed Maximum address is fixed.
|
|
|
|
@param [in] IsPosDecode Decode parameter
|
|
|
|
@param [in] IsaRanges Possible values are:
|
|
|
|
0-Reserved
|
|
|
|
1-NonISAOnly
|
|
|
|
2-ISAOnly
|
|
|
|
3-EntireRange
|
|
|
|
@param [in] AddressGranularity Address granularity.
|
|
|
|
@param [in] AddressMinimum Minimum address.
|
|
|
|
@param [in] AddressMaximum Maximum address.
|
|
|
|
@param [in] AddressTranslation Address translation.
|
|
|
|
@param [in] RangeLength Range length.
|
|
|
|
@param [in] ResourceSourceIndex Resource Source index.
|
|
|
|
Not supported. Must be 0.
|
|
|
|
@param [in] ResourceSource Resource Source.
|
|
|
|
Not supported. Must be NULL.
|
|
|
|
@param [in] IsDenseTranslation TranslationDensity parameter.
|
|
|
|
@param [in] IsTypeStatic TranslationType parameter.
|
|
|
|
@param [in] NameOpNode NameOp object node defining a named object.
|
|
|
|
If provided, append the new resource data
|
|
|
|
node to the list of resource data elements
|
|
|
|
of this node.
|
|
|
|
@param [out] NewRdNode If provided and success,
|
|
|
|
contain the created node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Could not allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenRdDWordIo (
|
|
|
|
IN BOOLEAN IsResourceConsumer,
|
|
|
|
IN BOOLEAN IsMinFixed,
|
|
|
|
IN BOOLEAN IsMaxFixed,
|
|
|
|
IN BOOLEAN IsPosDecode,
|
|
|
|
IN UINT8 IsaRanges,
|
|
|
|
IN UINT32 AddressGranularity,
|
|
|
|
IN UINT32 AddressMinimum,
|
|
|
|
IN UINT32 AddressMaximum,
|
|
|
|
IN UINT32 AddressTranslation,
|
|
|
|
IN UINT32 RangeLength,
|
|
|
|
IN UINT8 ResourceSourceIndex,
|
|
|
|
IN CONST CHAR8 *ResourceSource,
|
|
|
|
IN BOOLEAN IsDenseTranslation,
|
|
|
|
IN BOOLEAN IsTypeStatic,
|
|
|
|
IN AML_OBJECT_NODE_HANDLE NameOpNode, OPTIONAL
|
|
|
|
OUT AML_DATA_NODE_HANDLE *NewRdNode OPTIONAL
|
|
|
|
);
|
|
|
|
|
|
|
|
/** Code generation for the "DWordMemory ()" ASL function.
|
|
|
|
|
|
|
|
The Resource Data effectively created is a DWord Address Space Resource
|
|
|
|
Data. Cf ACPI 6.4:
|
|
|
|
- s6.4.3.5.2 "DWord Address Space Descriptor".
|
|
|
|
- s19.6.35 "DWordMemory".
|
|
|
|
|
|
|
|
The created resource data node can be:
|
|
|
|
- appended to the list of resource data elements of the NameOpNode.
|
|
|
|
In such case NameOpNode must be defined by a the "Name ()" ASL statement
|
|
|
|
and initially contain a "ResourceTemplate ()".
|
|
|
|
- returned through the NewRdNode parameter.
|
|
|
|
|
|
|
|
See ACPI 6.4 spec, s19.6.35 for more.
|
|
|
|
|
|
|
|
@param [in] IsResourceConsumer ResourceUsage parameter.
|
|
|
|
@param [in] IsPosDecode Decode parameter
|
|
|
|
@param [in] IsMinFixed Minimum address is fixed.
|
|
|
|
@param [in] IsMaxFixed Maximum address is fixed.
|
|
|
|
@param [in] Cacheable Possible values are:
|
|
|
|
0-The memory is non-cacheable
|
|
|
|
1-The memory is cacheable
|
|
|
|
2-The memory is cacheable and supports
|
|
|
|
write combining
|
|
|
|
3-The memory is cacheable and prefetchable
|
|
|
|
@param [in] IsReadWrite ReadAndWrite parameter.
|
|
|
|
@param [in] AddressGranularity Address granularity.
|
|
|
|
@param [in] AddressMinimum Minimum address.
|
|
|
|
@param [in] AddressMaximum Maximum address.
|
|
|
|
@param [in] AddressTranslation Address translation.
|
|
|
|
@param [in] RangeLength Range length.
|
|
|
|
@param [in] ResourceSourceIndex Resource Source index.
|
|
|
|
Not supported. Must be 0.
|
|
|
|
@param [in] ResourceSource Resource Source.
|
|
|
|
Not supported. Must be NULL.
|
|
|
|
@param [in] MemoryRangeType Possible values are:
|
|
|
|
0-AddressRangeMemory
|
|
|
|
1-AddressRangeReserved
|
|
|
|
2-AddressRangeACPI
|
|
|
|
3-AddressRangeNVS
|
|
|
|
@param [in] IsTypeStatic TranslationType parameter.
|
|
|
|
@param [in] NameOpNode NameOp object node defining a named object.
|
|
|
|
If provided, append the new resource data
|
|
|
|
node to the list of resource data elements
|
|
|
|
of this node.
|
|
|
|
@param [out] NewRdNode If provided and success,
|
|
|
|
contain the created node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Could not allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenRdDWordMemory (
|
|
|
|
IN BOOLEAN IsResourceConsumer,
|
|
|
|
IN BOOLEAN IsPosDecode,
|
|
|
|
IN BOOLEAN IsMinFixed,
|
|
|
|
IN BOOLEAN IsMaxFixed,
|
|
|
|
IN UINT8 Cacheable,
|
|
|
|
IN BOOLEAN IsReadWrite,
|
|
|
|
IN UINT32 AddressGranularity,
|
|
|
|
IN UINT32 AddressMinimum,
|
|
|
|
IN UINT32 AddressMaximum,
|
|
|
|
IN UINT32 AddressTranslation,
|
|
|
|
IN UINT32 RangeLength,
|
|
|
|
IN UINT8 ResourceSourceIndex,
|
|
|
|
IN CONST CHAR8 *ResourceSource,
|
|
|
|
IN UINT8 MemoryRangeType,
|
|
|
|
IN BOOLEAN IsTypeStatic,
|
|
|
|
IN AML_OBJECT_NODE_HANDLE NameOpNode, OPTIONAL
|
|
|
|
OUT AML_DATA_NODE_HANDLE *NewRdNode OPTIONAL
|
|
|
|
);
|
|
|
|
|
|
|
|
/** Code generation for the "WordBusNumber ()" ASL function.
|
|
|
|
|
|
|
|
The Resource Data effectively created is a Word Address Space Resource
|
|
|
|
Data. Cf ACPI 6.4:
|
|
|
|
- s6.4.3.5.3 "Word Address Space Descriptor".
|
|
|
|
- s19.6.149 "WordBusNumber".
|
|
|
|
|
|
|
|
The created resource data node can be:
|
|
|
|
- appended to the list of resource data elements of the NameOpNode.
|
|
|
|
In such case NameOpNode must be defined by a the "Name ()" ASL statement
|
|
|
|
and initially contain a "ResourceTemplate ()".
|
|
|
|
- returned through the NewRdNode parameter.
|
|
|
|
|
|
|
|
See ACPI 6.4 spec, s19.6.149 for more.
|
|
|
|
|
|
|
|
@param [in] IsResourceConsumer ResourceUsage parameter.
|
|
|
|
@param [in] IsMinFixed Minimum address is fixed.
|
|
|
|
@param [in] IsMaxFixed Maximum address is fixed.
|
|
|
|
@param [in] IsPosDecode Decode parameter
|
|
|
|
@param [in] AddressGranularity Address granularity.
|
|
|
|
@param [in] AddressMinimum Minimum address.
|
|
|
|
@param [in] AddressMaximum Maximum address.
|
|
|
|
@param [in] AddressTranslation Address translation.
|
|
|
|
@param [in] RangeLength Range length.
|
|
|
|
@param [in] ResourceSourceIndex Resource Source index.
|
|
|
|
Not supported. Must be 0.
|
|
|
|
@param [in] ResourceSource Resource Source.
|
|
|
|
Not supported. Must be NULL.
|
|
|
|
@param [in] NameOpNode NameOp object node defining a named object.
|
|
|
|
If provided, append the new resource data
|
|
|
|
node to the list of resource data elements
|
|
|
|
of this node.
|
|
|
|
@param [out] NewRdNode If provided and success,
|
|
|
|
contain the created node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Could not allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenRdWordBusNumber (
|
|
|
|
IN BOOLEAN IsResourceConsumer,
|
|
|
|
IN BOOLEAN IsMinFixed,
|
|
|
|
IN BOOLEAN IsMaxFixed,
|
|
|
|
IN BOOLEAN IsPosDecode,
|
|
|
|
IN UINT32 AddressGranularity,
|
|
|
|
IN UINT32 AddressMinimum,
|
|
|
|
IN UINT32 AddressMaximum,
|
|
|
|
IN UINT32 AddressTranslation,
|
|
|
|
IN UINT32 RangeLength,
|
|
|
|
IN UINT8 ResourceSourceIndex,
|
|
|
|
IN CONST CHAR8 *ResourceSource,
|
|
|
|
IN AML_OBJECT_NODE_HANDLE NameOpNode, OPTIONAL
|
|
|
|
OUT AML_DATA_NODE_HANDLE *NewRdNode OPTIONAL
|
|
|
|
);
|
|
|
|
|
|
|
|
/** Code generation for the "QWordMemory ()" ASL function.
|
|
|
|
|
|
|
|
The Resource Data effectively created is a QWord Address Space Resource
|
|
|
|
Data. Cf ACPI 6.4:
|
|
|
|
- s6.4.3.5.1 "QWord Address Space Descriptor".
|
|
|
|
- s19.6.110 "QWordMemory".
|
|
|
|
|
|
|
|
The created resource data node can be:
|
|
|
|
- appended to the list of resource data elements of the NameOpNode.
|
|
|
|
In such case NameOpNode must be defined by a the "Name ()" ASL statement
|
|
|
|
and initially contain a "ResourceTemplate ()".
|
|
|
|
- returned through the NewRdNode parameter.
|
|
|
|
|
|
|
|
See ACPI 6.4 spec, s19.6.110 for more.
|
|
|
|
|
|
|
|
@param [in] IsResourceConsumer ResourceUsage parameter.
|
|
|
|
@param [in] IsPosDecode Decode parameter.
|
|
|
|
@param [in] IsMinFixed Minimum address is fixed.
|
|
|
|
@param [in] IsMaxFixed Maximum address is fixed.
|
|
|
|
@param [in] Cacheable Possible values are:
|
|
|
|
0-The memory is non-cacheable
|
|
|
|
1-The memory is cacheable
|
|
|
|
2-The memory is cacheable and supports
|
|
|
|
write combining
|
|
|
|
3-The memory is cacheable and prefetchable
|
|
|
|
@param [in] IsReadWrite ReadAndWrite parameter.
|
|
|
|
@param [in] AddressGranularity Address granularity.
|
|
|
|
@param [in] AddressMinimum Minimum address.
|
|
|
|
@param [in] AddressMaximum Maximum address.
|
|
|
|
@param [in] AddressTranslation Address translation.
|
|
|
|
@param [in] RangeLength Range length.
|
|
|
|
@param [in] ResourceSourceIndex Resource Source index.
|
|
|
|
Not supported. Must be 0.
|
|
|
|
@param [in] ResourceSource Resource Source.
|
|
|
|
Not supported. Must be NULL.
|
|
|
|
@param [in] MemoryRangeType Possible values are:
|
|
|
|
0-AddressRangeMemory
|
|
|
|
1-AddressRangeReserved
|
|
|
|
2-AddressRangeACPI
|
|
|
|
3-AddressRangeNVS
|
|
|
|
@param [in] IsTypeStatic TranslationType parameter.
|
|
|
|
@param [in] NameOpNode NameOp object node defining a named object.
|
|
|
|
If provided, append the new resource data
|
|
|
|
node to the list of resource data elements
|
|
|
|
of this node.
|
|
|
|
@param [out] NewRdNode If provided and success,
|
|
|
|
contain the created node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Could not allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenRdQWordMemory (
|
|
|
|
IN BOOLEAN IsResourceConsumer,
|
|
|
|
IN BOOLEAN IsPosDecode,
|
|
|
|
IN BOOLEAN IsMinFixed,
|
|
|
|
IN BOOLEAN IsMaxFixed,
|
|
|
|
IN UINT8 Cacheable,
|
|
|
|
IN BOOLEAN IsReadWrite,
|
|
|
|
IN UINT64 AddressGranularity,
|
|
|
|
IN UINT64 AddressMinimum,
|
|
|
|
IN UINT64 AddressMaximum,
|
|
|
|
IN UINT64 AddressTranslation,
|
|
|
|
IN UINT64 RangeLength,
|
|
|
|
IN UINT8 ResourceSourceIndex,
|
|
|
|
IN CONST CHAR8 *ResourceSource,
|
|
|
|
IN UINT8 MemoryRangeType,
|
|
|
|
IN BOOLEAN IsTypeStatic,
|
|
|
|
IN AML_OBJECT_NODE_HANDLE NameOpNode, OPTIONAL
|
|
|
|
OUT AML_DATA_NODE_HANDLE *NewRdNode OPTIONAL
|
|
|
|
);
|
|
|
|
|
2021-09-30 09:48:21 +02:00
|
|
|
/** Code generation for the "Interrupt ()" ASL function.
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
The Resource Data effectively created is an Extended Interrupt Resource
|
2021-09-30 09:48:21 +02:00
|
|
|
Data. Cf ACPI 6.4:
|
|
|
|
- s6.4.3.6 "Extended Interrupt Descriptor"
|
|
|
|
- s19.6.64 "Interrupt (Interrupt Resource Descriptor Macro)"
|
2020-08-05 16:43:33 +02:00
|
|
|
|
2021-09-30 09:48:21 +02:00
|
|
|
The created resource data node can be:
|
|
|
|
- appended to the list of resource data elements of the NameOpNode.
|
|
|
|
In such case NameOpNode must be defined by a the "Name ()" ASL statement
|
|
|
|
and initially contain a "ResourceTemplate ()".
|
|
|
|
- returned through the NewRdNode parameter.
|
2020-08-05 16:43:33 +02:00
|
|
|
|
2021-09-30 09:48:20 +02:00
|
|
|
@ingroup CodeGenApis
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
@param [in] ResourceConsumer The device consumes the specified interrupt
|
|
|
|
or produces it for use by a child device.
|
|
|
|
@param [in] EdgeTriggered The interrupt is edge triggered or
|
|
|
|
level triggered.
|
|
|
|
@param [in] ActiveLow The interrupt is active-high or active-low.
|
|
|
|
@param [in] Shared The interrupt can be shared with other
|
|
|
|
devices or not (Exclusive).
|
|
|
|
@param [in] IrqList Interrupt list. Must be non-NULL.
|
|
|
|
@param [in] IrqCount Interrupt count. Must be non-zero.
|
2021-09-30 09:48:21 +02:00
|
|
|
@param [in] NameOpNode NameOp object node defining a named object.
|
|
|
|
If provided, append the new resource data node
|
|
|
|
to the list of resource data elements of this
|
|
|
|
node.
|
|
|
|
@param [out] NewRdNode If provided and success,
|
|
|
|
contain the created node.
|
2020-08-05 16:43:33 +02:00
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Could not allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
2021-09-30 09:48:21 +02:00
|
|
|
AmlCodeGenRdInterrupt (
|
2020-08-05 16:43:33 +02:00
|
|
|
IN BOOLEAN ResourceConsumer,
|
|
|
|
IN BOOLEAN EdgeTriggered,
|
|
|
|
IN BOOLEAN ActiveLow,
|
|
|
|
IN BOOLEAN Shared,
|
2021-09-30 09:48:21 +02:00
|
|
|
IN UINT32 *IrqList,
|
|
|
|
IN UINT8 IrqCount,
|
2021-12-03 03:00:40 +01:00
|
|
|
IN AML_OBJECT_NODE_HANDLE NameOpNode OPTIONAL,
|
2021-09-30 09:48:21 +02:00
|
|
|
OUT AML_DATA_NODE_HANDLE *NewRdNode OPTIONAL
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** AML code generation for DefinitionBlock.
|
|
|
|
|
|
|
|
Create a Root Node handle.
|
|
|
|
It is the caller's responsibility to free the allocated memory
|
|
|
|
with the AmlDeleteTree function.
|
|
|
|
|
|
|
|
AmlCodeGenDefinitionBlock (TableSignature, OemId, TableID, OEMRevision) is
|
|
|
|
equivalent to the following ASL code:
|
|
|
|
DefinitionBlock (AMLFileName, TableSignature, ComplianceRevision,
|
|
|
|
OemId, TableID, OEMRevision) {}
|
|
|
|
with the ComplianceRevision set to 2 and the AMLFileName is ignored.
|
|
|
|
|
|
|
|
@ingroup CodeGenApis
|
|
|
|
|
|
|
|
@param[in] TableSignature 4-character ACPI signature.
|
|
|
|
Must be 'DSDT' or 'SSDT'.
|
|
|
|
@param[in] OemId 6-character string OEM identifier.
|
|
|
|
@param[in] OemTableId 8-character string OEM table identifier.
|
|
|
|
@param[in] OemRevision OEM revision number.
|
|
|
|
@param[out] DefinitionBlockTerm The ASL Term handle representing a
|
|
|
|
Definition Block.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Success.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenDefinitionBlock (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST CHAR8 *TableSignature,
|
|
|
|
IN CONST CHAR8 *OemId,
|
|
|
|
IN CONST CHAR8 *OemTableId,
|
|
|
|
IN UINT32 OemRevision,
|
|
|
|
OUT AML_ROOT_NODE_HANDLE *NewRootNode
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** AML code generation for a Name object node, containing a String.
|
|
|
|
|
|
|
|
AmlCodeGenNameString ("_HID", "HID0000", ParentNode, NewObjectNode) is
|
|
|
|
equivalent of the following ASL code:
|
|
|
|
Name(_HID, "HID0000")
|
|
|
|
|
|
|
|
@ingroup CodeGenApis
|
|
|
|
|
|
|
|
@param [in] NameString The new variable name.
|
|
|
|
Must be a NULL-terminated ASL NameString
|
|
|
|
e.g.: "DEV0", "DV15.DEV0", etc.
|
|
|
|
The input string is copied.
|
|
|
|
@param [in] String NULL terminated String to associate to the
|
|
|
|
NameString.
|
|
|
|
@param [in] ParentNode If provided, set ParentNode as the parent
|
|
|
|
of the node created.
|
|
|
|
@param [out] NewObjectNode If success, contains the created node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Success.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenNameString (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST CHAR8 *NameString,
|
|
|
|
IN CHAR8 *String,
|
|
|
|
IN AML_NODE_HANDLE ParentNode OPTIONAL,
|
|
|
|
OUT AML_OBJECT_NODE_HANDLE *NewObjectNode OPTIONAL
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** AML code generation for a Name object node, containing an Integer.
|
|
|
|
|
|
|
|
AmlCodeGenNameInteger ("_UID", 1, ParentNode, NewObjectNode) is
|
|
|
|
equivalent of the following ASL code:
|
|
|
|
Name(_UID, One)
|
|
|
|
|
|
|
|
@ingroup CodeGenApis
|
|
|
|
|
|
|
|
@param [in] NameString The new variable name.
|
|
|
|
Must be a NULL-terminated ASL NameString
|
|
|
|
e.g.: "DEV0", "DV15.DEV0", etc.
|
|
|
|
The input string is copied.
|
|
|
|
@param [in] Integer Integer to associate to the NameString.
|
|
|
|
@param [in] ParentNode If provided, set ParentNode as the parent
|
|
|
|
of the node created.
|
|
|
|
@param [out] NewObjectNode If success, contains the created node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Success.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenNameInteger (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST CHAR8 *NameString,
|
|
|
|
IN UINT64 Integer,
|
|
|
|
IN AML_NODE_HANDLE ParentNode OPTIONAL,
|
|
|
|
OUT AML_OBJECT_NODE_HANDLE *NewObjectNode OPTIONAL
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** AML code generation for a Device object node.
|
|
|
|
|
|
|
|
AmlCodeGenDevice ("COM0", ParentNode, NewObjectNode) is
|
|
|
|
equivalent of the following ASL code:
|
|
|
|
Device(COM0) {}
|
|
|
|
|
|
|
|
@ingroup CodeGenApis
|
|
|
|
|
|
|
|
@param [in] NameString The new Device's name.
|
|
|
|
Must be a NULL-terminated ASL NameString
|
|
|
|
e.g.: "DEV0", "DV15.DEV0", etc.
|
|
|
|
The input string is copied.
|
|
|
|
@param [in] ParentNode If provided, set ParentNode as the parent
|
|
|
|
of the node created.
|
|
|
|
@param [out] NewObjectNode If success, contains the created node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Success.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenDevice (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST CHAR8 *NameString,
|
|
|
|
IN AML_NODE_HANDLE ParentNode OPTIONAL,
|
|
|
|
OUT AML_OBJECT_NODE_HANDLE *NewObjectNode OPTIONAL
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** AML code generation for a Scope object node.
|
|
|
|
|
|
|
|
AmlCodeGenScope ("_SB", ParentNode, NewObjectNode) is
|
|
|
|
equivalent of the following ASL code:
|
|
|
|
Scope(_SB) {}
|
|
|
|
|
|
|
|
@ingroup CodeGenApis
|
|
|
|
|
|
|
|
@param [in] NameString The new Scope's name.
|
|
|
|
Must be a NULL-terminated ASL NameString
|
|
|
|
e.g.: "DEV0", "DV15.DEV0", etc.
|
|
|
|
The input string is copied.
|
|
|
|
@param [in] ParentNode If provided, set ParentNode as the parent
|
|
|
|
of the node created.
|
|
|
|
@param [out] NewObjectNode If success, contains the created node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Success.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenScope (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST CHAR8 *NameString,
|
|
|
|
IN AML_NODE_HANDLE ParentNode OPTIONAL,
|
|
|
|
OUT AML_OBJECT_NODE_HANDLE *NewObjectNode OPTIONAL
|
2020-08-05 16:43:33 +02:00
|
|
|
);
|
|
|
|
|
2021-10-08 16:46:28 +02:00
|
|
|
/** AML code generation for a method returning a NameString.
|
|
|
|
|
|
|
|
AmlCodeGenMethodRetNameString (
|
|
|
|
"MET0", "_CRS", 1, TRUE, 3, ParentNode, NewObjectNode
|
|
|
|
);
|
|
|
|
is equivalent of the following ASL code:
|
|
|
|
Method(MET0, 1, Serialized, 3) {
|
|
|
|
Return (_CRS)
|
|
|
|
}
|
|
|
|
|
|
|
|
The ASL parameters "ReturnType" and "ParameterTypes" are not asked
|
|
|
|
in this function. They are optional parameters in ASL.
|
|
|
|
|
|
|
|
@ingroup CodeGenApis
|
|
|
|
|
|
|
|
@param [in] MethodNameString The new Method's name.
|
|
|
|
Must be a NULL-terminated ASL NameString
|
|
|
|
e.g.: "MET0", "_SB.MET0", etc.
|
|
|
|
The input string is copied.
|
|
|
|
@param [in] ReturnedNameString The name of the object returned by the
|
|
|
|
method. Optional parameter, can be:
|
|
|
|
- NULL (ignored).
|
|
|
|
- A NULL-terminated ASL NameString.
|
|
|
|
e.g.: "MET0", "_SB.MET0", etc.
|
|
|
|
The input string is copied.
|
|
|
|
@param [in] NumArgs Number of arguments.
|
|
|
|
Must be 0 <= NumArgs <= 6.
|
|
|
|
@param [in] IsSerialized TRUE is equivalent to Serialized.
|
|
|
|
FALSE is equivalent to NotSerialized.
|
|
|
|
Default is NotSerialized in ASL spec.
|
|
|
|
@param [in] SyncLevel Synchronization level for the method.
|
|
|
|
Must be 0 <= SyncLevel <= 15.
|
|
|
|
Default is 0 in ASL.
|
|
|
|
@param [in] ParentNode If provided, set ParentNode as the parent
|
|
|
|
of the node created.
|
|
|
|
@param [out] NewObjectNode If success, contains the created node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Success.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenMethodRetNameString (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST CHAR8 *MethodNameString,
|
|
|
|
IN CONST CHAR8 *ReturnedNameString OPTIONAL,
|
|
|
|
IN UINT8 NumArgs,
|
|
|
|
IN BOOLEAN IsSerialized,
|
|
|
|
IN UINT8 SyncLevel,
|
|
|
|
IN AML_NODE_HANDLE ParentNode OPTIONAL,
|
|
|
|
OUT AML_OBJECT_NODE_HANDLE *NewObjectNode OPTIONAL
|
2021-10-08 16:46:28 +02:00
|
|
|
);
|
|
|
|
|
2021-10-08 16:46:29 +02:00
|
|
|
/** Create a _LPI name.
|
|
|
|
|
|
|
|
AmlCreateLpiNode ("_LPI", 0, 1, ParentNode, &LpiNode) is
|
|
|
|
equivalent of the following ASL code:
|
|
|
|
Name (_LPI, Package (
|
|
|
|
0, // Revision
|
|
|
|
1, // LevelId
|
|
|
|
0 // Count
|
|
|
|
))
|
|
|
|
|
|
|
|
This function doesn't define any LPI state. As shown above, the count
|
|
|
|
of _LPI state is set to 0.
|
|
|
|
The AmlAddLpiState () function must be used to add LPI states.
|
|
|
|
|
|
|
|
Cf ACPI 6.3 specification, s8.4.4 "Lower Power Idle States".
|
|
|
|
|
|
|
|
@ingroup CodeGenApis
|
|
|
|
|
|
|
|
@param [in] LpiNameString The new LPI 's object name.
|
|
|
|
Must be a NULL-terminated ASL NameString
|
|
|
|
e.g.: "_LPI", "DEV0.PLPI", etc.
|
|
|
|
The input string is copied.
|
|
|
|
@param [in] Revision Revision number of the _LPI states.
|
|
|
|
@param [in] LevelId A platform defined number that identifies the
|
|
|
|
level of hierarchy of the processor node to
|
|
|
|
which the LPI states apply.
|
|
|
|
@param [in] ParentNode If provided, set ParentNode as the parent
|
|
|
|
of the node created.
|
|
|
|
@param [out] NewLpiNode If success, contains the created node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCreateLpiNode (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST CHAR8 *LpiNameString,
|
|
|
|
IN UINT16 Revision,
|
|
|
|
IN UINT64 LevelId,
|
|
|
|
IN AML_NODE_HANDLE ParentNode OPTIONAL,
|
|
|
|
OUT AML_OBJECT_NODE_HANDLE *NewLpiNode OPTIONAL
|
2021-10-08 16:46:29 +02:00
|
|
|
);
|
|
|
|
|
DynamicTablesPkg: AML code generation to add an _LPI state
Add AmlAddLpiState() to generates AML code to add an _LPI state
to an _LPI object created using AmlCreateLpiNode().
AmlAddLpiState increments the count of LPI states in the LPI
node by one, and adds the following package:
Package() {
MinResidency,
WorstCaseWakeLatency,
Flags,
ArchFlags,
ResCntFreq,
EnableParentState,
(GenericRegisterDescriptor != NULL) ? // Entry method. If a
ResourceTemplate(GenericRegisterDescriptor) : // Register is given,
Integer, // use it. Use the
// Integer otherwise
ResourceTemplate() { // NULL Residency
Register (SystemMemory, 0, 0, 0, 0) // Counter
},
ResourceTemplate() { // NULL Usage Counter
Register (SystemMemory, 0, 0, 0, 0)
},
"" // NULL State Name
},
Reviewed-by: Sami Mujawar <sami.mujawar@arm.com>
Signed-off-by: Pierre Gondois <Pierre.Gondois@arm.com>
2021-10-08 16:46:30 +02:00
|
|
|
/** Add an _LPI state to a LPI node created using AmlCreateLpiNode ().
|
|
|
|
|
|
|
|
AmlAddLpiState () increments the Count of LPI states in the LPI node by one,
|
|
|
|
and adds the following package:
|
|
|
|
Package() {
|
|
|
|
MinResidency,
|
|
|
|
WorstCaseWakeLatency,
|
|
|
|
Flags,
|
|
|
|
ArchFlags,
|
|
|
|
ResCntFreq,
|
|
|
|
EnableParentState,
|
|
|
|
(GenericRegisterDescriptor != NULL) ? // Entry method. If a
|
|
|
|
ResourceTemplate(GenericRegisterDescriptor) : // Register is given,
|
|
|
|
Integer, // use it. Use the
|
|
|
|
// Integer otherwise.
|
|
|
|
ResourceTemplate() { // NULL Residency Counter
|
|
|
|
Register (SystemMemory, 0, 0, 0, 0)
|
|
|
|
},
|
|
|
|
ResourceTemplate() { // NULL Usage Counter
|
|
|
|
Register (SystemMemory, 0, 0, 0, 0)
|
|
|
|
},
|
|
|
|
"" // NULL State Name
|
|
|
|
},
|
|
|
|
|
|
|
|
Cf ACPI 6.3 specification, s8.4.4 "Lower Power Idle States".
|
|
|
|
|
|
|
|
@ingroup CodeGenApis
|
|
|
|
|
|
|
|
@param [in] MinResidency Minimum Residency.
|
|
|
|
@param [in] WorstCaseWakeLatency Worst case wake-up latency.
|
|
|
|
@param [in] Flags Flags.
|
|
|
|
@param [in] ArchFlags Architectural flags.
|
|
|
|
@param [in] ResCntFreq Residency Counter Frequency.
|
|
|
|
@param [in] EnableParentState Enabled Parent State.
|
|
|
|
@param [in] GenericRegisterDescriptor Entry Method.
|
|
|
|
If not NULL, use this Register to
|
|
|
|
describe the entry method address.
|
|
|
|
@param [in] Integer Entry Method.
|
|
|
|
If GenericRegisterDescriptor is NULL,
|
|
|
|
take this value.
|
|
|
|
@param [in] ResidencyCounterRegister If not NULL, use it to populate the
|
|
|
|
residency counter register.
|
|
|
|
@param [in] UsageCounterRegister If not NULL, use it to populate the
|
|
|
|
usage counter register.
|
|
|
|
@param [in] StateName If not NULL, use it to populate the
|
|
|
|
state name.
|
|
|
|
@param [in] LpiNode Lpi node created with the function
|
|
|
|
AmlCreateLpiNode to which the new LPI
|
|
|
|
state is appended.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlAddLpiState (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN UINT32 MinResidency,
|
|
|
|
IN UINT32 WorstCaseWakeLatency,
|
|
|
|
IN UINT32 Flags,
|
|
|
|
IN UINT32 ArchFlags,
|
|
|
|
IN UINT32 ResCntFreq,
|
|
|
|
IN UINT32 EnableParentState,
|
|
|
|
IN EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE *GenericRegisterDescriptor OPTIONAL,
|
|
|
|
IN UINT64 Integer OPTIONAL,
|
|
|
|
IN EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE *ResidencyCounterRegister OPTIONAL,
|
|
|
|
IN EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE *UsageCounterRegister OPTIONAL,
|
|
|
|
IN CHAR8 *StateName OPTIONAL,
|
|
|
|
IN AML_OBJECT_NODE_HANDLE LpiNode
|
DynamicTablesPkg: AML code generation to add an _LPI state
Add AmlAddLpiState() to generates AML code to add an _LPI state
to an _LPI object created using AmlCreateLpiNode().
AmlAddLpiState increments the count of LPI states in the LPI
node by one, and adds the following package:
Package() {
MinResidency,
WorstCaseWakeLatency,
Flags,
ArchFlags,
ResCntFreq,
EnableParentState,
(GenericRegisterDescriptor != NULL) ? // Entry method. If a
ResourceTemplate(GenericRegisterDescriptor) : // Register is given,
Integer, // use it. Use the
// Integer otherwise
ResourceTemplate() { // NULL Residency
Register (SystemMemory, 0, 0, 0, 0) // Counter
},
ResourceTemplate() { // NULL Usage Counter
Register (SystemMemory, 0, 0, 0, 0)
},
"" // NULL State Name
},
Reviewed-by: Sami Mujawar <sami.mujawar@arm.com>
Signed-off-by: Pierre Gondois <Pierre.Gondois@arm.com>
2021-10-08 16:46:30 +02:00
|
|
|
);
|
|
|
|
|
2021-09-30 09:48:20 +02:00
|
|
|
// DEPRECATED APIS
|
|
|
|
#ifndef DISABLE_NEW_DEPRECATED_INTERFACES
|
|
|
|
|
|
|
|
/** DEPRECATED API
|
|
|
|
|
|
|
|
Get the first Resource Data element contained in a "_CRS" object.
|
|
|
|
|
|
|
|
In the following ASL code, the function will return the Resource Data
|
|
|
|
node corresponding to the "QWordMemory ()" ASL macro.
|
|
|
|
Name (_CRS, ResourceTemplate() {
|
|
|
|
QWordMemory (...) {...},
|
|
|
|
Interrupt (...) {...}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
Note:
|
|
|
|
- The "_CRS" object must be declared using ASL "Name (Declare Named Object)".
|
|
|
|
- "_CRS" declared using ASL "Method (Declare Control Method)" is not
|
|
|
|
supported.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] NameOpCrsNode NameOp object node defining a "_CRS" object.
|
|
|
|
Must have an OpCode=AML_NAME_OP, SubOpCode=0.
|
|
|
|
NameOp object nodes are defined in ASL
|
|
|
|
using the "Name ()" function.
|
|
|
|
@param [out] OutRdNode Pointer to the first Resource Data element of
|
|
|
|
the "_CRS" object. A Resource Data element
|
|
|
|
is stored in a data node.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlNameOpCrsGetFirstRdNode (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_OBJECT_NODE_HANDLE NameOpCrsNode,
|
|
|
|
OUT AML_DATA_NODE_HANDLE *OutRdNode
|
2021-09-30 09:48:20 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** DEPRECATED API
|
|
|
|
|
|
|
|
Get the Resource Data element following the CurrRdNode Resource Data.
|
|
|
|
|
|
|
|
In the following ASL code, if CurrRdNode corresponds to the first
|
|
|
|
"QWordMemory ()" ASL macro, the function will return the Resource Data
|
|
|
|
node corresponding to the "Interrupt ()" ASL macro.
|
|
|
|
Name (_CRS, ResourceTemplate() {
|
|
|
|
QwordMemory (...) {...},
|
|
|
|
Interrupt (...) {...}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
The CurrRdNode Resource Data node must be defined in an object named "_CRS"
|
|
|
|
and defined by a "Name ()" ASL function.
|
|
|
|
|
|
|
|
@ingroup UserApis
|
|
|
|
|
|
|
|
@param [in] CurrRdNode Pointer to the current Resource Data element of
|
|
|
|
the "_CRS" variable.
|
|
|
|
@param [out] OutRdNode Pointer to the Resource Data element following
|
|
|
|
the CurrRdNode.
|
|
|
|
Contain a NULL pointer if CurrRdNode is the
|
|
|
|
last Resource Data element in the list.
|
|
|
|
The "End Tag" is not considered as a resource
|
|
|
|
data element and is not returned.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlNameOpCrsGetNextRdNode (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN AML_DATA_NODE_HANDLE CurrRdNode,
|
|
|
|
OUT AML_DATA_NODE_HANDLE *OutRdNode
|
2021-09-30 09:48:20 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** DEPRECATED API
|
|
|
|
|
|
|
|
Add an Interrupt Resource Data node.
|
|
|
|
|
|
|
|
This function creates a Resource Data element corresponding to the
|
|
|
|
"Interrupt ()" ASL function, stores it in an AML Data Node.
|
|
|
|
|
|
|
|
It then adds it after the input CurrRdNode in the list of resource data
|
|
|
|
element.
|
|
|
|
|
|
|
|
The Resource Data effectively created is an Extended Interrupt Resource
|
|
|
|
Data. See ACPI 6.3 specification, s6.4.3.6 "Extended Interrupt Descriptor"
|
|
|
|
for more information about Extended Interrupt Resource Data.
|
|
|
|
|
|
|
|
The Extended Interrupt contains one single interrupt.
|
|
|
|
|
|
|
|
This function allocates memory to create a data node. It is the caller's
|
|
|
|
responsibility to either:
|
|
|
|
- attach this node to an AML tree;
|
|
|
|
- delete this node.
|
|
|
|
|
|
|
|
Note: The _CRS node must be defined using the ASL Name () function.
|
|
|
|
e.g. Name (_CRS, ResourceTemplate () {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
@ingroup CodeGenApis
|
|
|
|
|
|
|
|
@param [in] NameOpCrsNode NameOp object node defining a "_CRS" object.
|
|
|
|
Must have an OpCode=AML_NAME_OP, SubOpCode=0.
|
|
|
|
NameOp object nodes are defined in ASL
|
|
|
|
using the "Name ()" function.
|
|
|
|
@param [in] ResourceConsumer The device consumes the specified interrupt
|
|
|
|
or produces it for use by a child device.
|
|
|
|
@param [in] EdgeTriggered The interrupt is edge triggered or
|
|
|
|
level triggered.
|
|
|
|
@param [in] ActiveLow The interrupt is active-high or active-low.
|
|
|
|
@param [in] Shared The interrupt can be shared with other
|
|
|
|
devices or not (Exclusive).
|
|
|
|
@param [in] IrqList Interrupt list. Must be non-NULL.
|
|
|
|
@param [in] IrqCount Interrupt count. Must be non-zero.
|
|
|
|
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Could not allocate memory.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlCodeGenCrsAddRdInterrupt (
|
|
|
|
IN AML_OBJECT_NODE_HANDLE NameOpCrsNode,
|
|
|
|
IN BOOLEAN ResourceConsumer,
|
|
|
|
IN BOOLEAN EdgeTriggered,
|
|
|
|
IN BOOLEAN ActiveLow,
|
|
|
|
IN BOOLEAN Shared,
|
2021-12-05 23:53:55 +01:00
|
|
|
IN UINT32 *IrqList,
|
2021-09-30 09:48:20 +02:00
|
|
|
IN UINT8 IrqCount
|
|
|
|
);
|
|
|
|
|
|
|
|
#endif // DISABLE_NEW_DEPRECATED_INTERFACES
|
|
|
|
|
2020-08-05 16:43:33 +02:00
|
|
|
#endif // AML_LIB_H_
|