mirror of https://github.com/acidanthera/audk.git
DynamicTablesPkg: AML code generation for a _LPI object
_LPI object provides a method to describe Low Power Idle states that define the local power states for each node in a hierarchical processor topology. Therefore, add AmlCreateLpiNode() to generate code for a _LPI object. AmlCreateLpiNode ("_LPI", 0, 1, ParentNode, &LpiNode) is equivalent of the following ASL code: Name (_LPI, Package ( 0, // Revision 1, // LevelId 0 // Count )) Reviewed-by: Sami Mujawar <sami.mujawar@arm.com> Signed-off-by: Pierre Gondois <Pierre.Gondois@arm.com>
This commit is contained in:
parent
3e958e93ce
commit
018a962d92
|
@ -672,6 +672,50 @@ AmlCodeGenMethodRetNameString (
|
||||||
OUT AML_OBJECT_NODE_HANDLE * NewObjectNode OPTIONAL
|
OUT AML_OBJECT_NODE_HANDLE * NewObjectNode OPTIONAL
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/** 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 (
|
||||||
|
IN CONST CHAR8 * LpiNameString,
|
||||||
|
IN UINT16 Revision,
|
||||||
|
IN UINT64 LevelId,
|
||||||
|
IN AML_NODE_HANDLE ParentNode, OPTIONAL
|
||||||
|
OUT AML_OBJECT_NODE_HANDLE * NewLpiNode OPTIONAL
|
||||||
|
);
|
||||||
|
|
||||||
// DEPRECATED APIS
|
// DEPRECATED APIS
|
||||||
#ifndef DISABLE_NEW_DEPRECATED_INTERFACES
|
#ifndef DISABLE_NEW_DEPRECATED_INTERFACES
|
||||||
|
|
||||||
|
|
|
@ -1441,3 +1441,136 @@ error_handler:
|
||||||
}
|
}
|
||||||
return Status;
|
return Status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** 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 allows to add LPI states.
|
||||||
|
|
||||||
|
Cf ACPI 6.3 specification, s8.4.4 "Lower Power Idle States".
|
||||||
|
|
||||||
|
@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 (
|
||||||
|
IN CONST CHAR8 * LpiNameString,
|
||||||
|
IN UINT16 Revision,
|
||||||
|
IN UINT64 LevelId,
|
||||||
|
IN AML_NODE_HANDLE ParentNode, OPTIONAL
|
||||||
|
OUT AML_OBJECT_NODE_HANDLE * NewLpiNode OPTIONAL
|
||||||
|
)
|
||||||
|
{
|
||||||
|
EFI_STATUS Status;
|
||||||
|
AML_OBJECT_NODE_HANDLE PackageNode;
|
||||||
|
AML_OBJECT_NODE_HANDLE IntegerNode;
|
||||||
|
|
||||||
|
if ((LpiNameString == NULL) ||
|
||||||
|
((ParentNode == NULL) && (NewLpiNode == NULL))) {
|
||||||
|
ASSERT (0);
|
||||||
|
return EFI_INVALID_PARAMETER;
|
||||||
|
}
|
||||||
|
|
||||||
|
IntegerNode = NULL;
|
||||||
|
|
||||||
|
Status = AmlCodeGenPackage (&PackageNode);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
ASSERT (0);
|
||||||
|
return Status;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create and attach Revision
|
||||||
|
Status = AmlCodeGenInteger (Revision, &IntegerNode);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
ASSERT (0);
|
||||||
|
IntegerNode = NULL;
|
||||||
|
goto error_handler;
|
||||||
|
}
|
||||||
|
|
||||||
|
Status = AmlVarListAddTail (
|
||||||
|
(AML_NODE_HANDLE)PackageNode,
|
||||||
|
(AML_NODE_HANDLE)IntegerNode
|
||||||
|
);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
ASSERT (0);
|
||||||
|
goto error_handler;
|
||||||
|
}
|
||||||
|
|
||||||
|
IntegerNode = NULL;
|
||||||
|
|
||||||
|
// Create and attach LevelId
|
||||||
|
Status = AmlCodeGenInteger (LevelId, &IntegerNode);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
ASSERT (0);
|
||||||
|
IntegerNode = NULL;
|
||||||
|
goto error_handler;
|
||||||
|
}
|
||||||
|
|
||||||
|
Status = AmlVarListAddTail (
|
||||||
|
(AML_NODE_HANDLE)PackageNode,
|
||||||
|
(AML_NODE_HANDLE)IntegerNode
|
||||||
|
);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
ASSERT (0);
|
||||||
|
goto error_handler;
|
||||||
|
}
|
||||||
|
|
||||||
|
IntegerNode = NULL;
|
||||||
|
|
||||||
|
// Create and attach Count. No LPI state is added, so 0.
|
||||||
|
Status = AmlCodeGenInteger (0, &IntegerNode);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
ASSERT (0);
|
||||||
|
IntegerNode = NULL;
|
||||||
|
goto error_handler;
|
||||||
|
}
|
||||||
|
|
||||||
|
Status = AmlVarListAddTail (
|
||||||
|
(AML_NODE_HANDLE)PackageNode,
|
||||||
|
(AML_NODE_HANDLE)IntegerNode
|
||||||
|
);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
ASSERT (0);
|
||||||
|
goto error_handler;
|
||||||
|
}
|
||||||
|
|
||||||
|
IntegerNode = NULL;
|
||||||
|
|
||||||
|
Status = AmlCodeGenName (LpiNameString, PackageNode, ParentNode, NewLpiNode);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
ASSERT (0);
|
||||||
|
goto error_handler;
|
||||||
|
}
|
||||||
|
|
||||||
|
return Status;
|
||||||
|
|
||||||
|
error_handler:
|
||||||
|
AmlDeleteTree ((AML_NODE_HANDLE)PackageNode);
|
||||||
|
if (IntegerNode != NULL) {
|
||||||
|
AmlDeleteTree ((AML_NODE_HANDLE)IntegerNode);
|
||||||
|
}
|
||||||
|
return Status;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue