mirror of https://github.com/acidanthera/audk.git
DynamicTablesPkg: Add AmlSetRdListCheckSum()
Lists of Resource Data elements end with an EndTag (most of the time). This function finds the EndTag (if present) in a list of Resource Data elements and sets the checksum. ACPI 6.4, s6.4.2.9 "End Tag": "This checksum is generated such that adding it to the sum of all the data bytes will produce a zero sum." "If the checksum field is zero, the resource data is treated as if the checksum operation succeeded. Configuration proceeds normally." Reviewed-by: Sami Mujawar <sami.mujawar@arm.com> Signed-off-by: Pierre Gondois <Pierre.Gondois@arm.com>
This commit is contained in:
parent
28b2df475f
commit
74addfeab6
|
@ -904,3 +904,79 @@ AmlPropagateInformation (
|
||||||
|
|
||||||
return EFI_SUCCESS;
|
return EFI_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Find and set the EndTag's Checksum of a list of Resource Data elements.
|
||||||
|
|
||||||
|
Lists of Resource Data elements end with an EndTag (most of the time). This
|
||||||
|
function finds the EndTag (if present) in a list of Resource Data elements
|
||||||
|
and sets the checksum.
|
||||||
|
|
||||||
|
ACPI 6.4, s6.4.2.9 "End Tag":
|
||||||
|
"This checksum is generated such that adding it to the sum of all the data
|
||||||
|
bytes will produce a zero sum."
|
||||||
|
"If the checksum field is zero, the resource data is treated as if the
|
||||||
|
checksum operation succeeded. Configuration proceeds normally."
|
||||||
|
|
||||||
|
To avoid re-computing checksums, if a new resource data elements is
|
||||||
|
added/removed/modified in a list of resource data elements, the AmlLib
|
||||||
|
resets the checksum to 0.
|
||||||
|
|
||||||
|
@param [in] BufferOpNode Node having a list of Resource Data elements.
|
||||||
|
@param [in] CheckSum CheckSum to store in the EndTag.
|
||||||
|
To ignore/avoid computing the checksum,
|
||||||
|
give 0.
|
||||||
|
|
||||||
|
@retval EFI_SUCCESS The function completed successfully.
|
||||||
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
||||||
|
@retval EFI_NOT_FOUND No EndTag found.
|
||||||
|
**/
|
||||||
|
EFI_STATUS
|
||||||
|
EFIAPI
|
||||||
|
AmlSetRdListCheckSum (
|
||||||
|
IN AML_OBJECT_NODE * BufferOpNode,
|
||||||
|
IN UINT8 CheckSum
|
||||||
|
)
|
||||||
|
{
|
||||||
|
EFI_STATUS Status;
|
||||||
|
AML_DATA_NODE * LastRdNode;
|
||||||
|
AML_RD_HEADER RdDataType;
|
||||||
|
|
||||||
|
if (!AmlNodeCompareOpCode (BufferOpNode, AML_BUFFER_OP, 0)) {
|
||||||
|
ASSERT (0);
|
||||||
|
return EFI_INVALID_PARAMETER;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the last Resource data node in the variable list of
|
||||||
|
// argument of the BufferOp node.
|
||||||
|
LastRdNode = (AML_DATA_NODE*)AmlGetPreviousVariableArgument (
|
||||||
|
(AML_NODE_HEADER*)BufferOpNode,
|
||||||
|
NULL
|
||||||
|
);
|
||||||
|
if ((LastRdNode == NULL) ||
|
||||||
|
!IS_AML_DATA_NODE (LastRdNode) ||
|
||||||
|
(LastRdNode->DataType != EAmlNodeDataTypeResourceData)) {
|
||||||
|
ASSERT (0);
|
||||||
|
return EFI_INVALID_PARAMETER;
|
||||||
|
}
|
||||||
|
|
||||||
|
Status = AmlGetResourceDataType (LastRdNode, &RdDataType);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
ASSERT (0);
|
||||||
|
return Status;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check the LastRdNode is an EndTag.
|
||||||
|
// It is possible to have only one Resource Data in a BufferOp with
|
||||||
|
// no EndTag. Return EFI_NOT_FOUND is such case.
|
||||||
|
if (!AmlRdCompareDescId (
|
||||||
|
&RdDataType,
|
||||||
|
AML_RD_BUILD_SMALL_DESC_ID (ACPI_SMALL_END_TAG_DESCRIPTOR_NAME))) {
|
||||||
|
ASSERT (0);
|
||||||
|
return EFI_NOT_FOUND;
|
||||||
|
}
|
||||||
|
|
||||||
|
Status = AmlRdSetEndTagChecksum (LastRdNode->Buffer, CheckSum);
|
||||||
|
ASSERT_EFI_ERROR (Status);
|
||||||
|
|
||||||
|
return Status;
|
||||||
|
}
|
||||||
|
|
|
@ -91,5 +91,37 @@ AmlPropagateInformation (
|
||||||
IN UINT8 NodeCount
|
IN UINT8 NodeCount
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/** Find and set the EndTag's Checksum of a list of Resource Data elements.
|
||||||
|
|
||||||
|
Lists of Resource Data elements end with an EndTag (most of the time). This
|
||||||
|
function finds the EndTag (if present) in a list of Resource Data elements
|
||||||
|
and sets the checksum.
|
||||||
|
|
||||||
|
ACPI 6.4, s6.4.2.9 "End Tag":
|
||||||
|
"This checksum is generated such that adding it to the sum of all the data
|
||||||
|
bytes will produce a zero sum."
|
||||||
|
"If the checksum field is zero, the resource data is treated as if the
|
||||||
|
checksum operation succeeded. Configuration proceeds normally."
|
||||||
|
|
||||||
|
To avoid re-computing checksums, if a new resource data elements is
|
||||||
|
added/removed/modified in a list of resource data elements, the AmlLib
|
||||||
|
resets the checksum to 0.
|
||||||
|
|
||||||
|
@param [in] BufferOpNode Node having a list of Resource Data elements.
|
||||||
|
@param [in] CheckSum CheckSum to store in the EndTag.
|
||||||
|
To ignore/avoid computing the checksum,
|
||||||
|
give 0.
|
||||||
|
|
||||||
|
@retval EFI_SUCCESS The function completed successfully.
|
||||||
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
||||||
|
@retval EFI_NOT_FOUND No EndTag found.
|
||||||
|
**/
|
||||||
|
EFI_STATUS
|
||||||
|
EFIAPI
|
||||||
|
AmlSetRdListCheckSum (
|
||||||
|
IN AML_OBJECT_NODE * BufferOpNode,
|
||||||
|
IN UINT8 CheckSum
|
||||||
|
);
|
||||||
|
|
||||||
#endif // AML_UTILITY_H_
|
#endif // AML_UTILITY_H_
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue