public inbox for devel@edk2.groups.io
 help / color / mirror / Atom feed
From: "Sami Mujawar" <sami.mujawar@arm.com>
To: Pierre.Gondois@arm.com, devel@edk2.groups.io,
	Alexei.Fedorov@arm.com, nd <nd@arm.com>
Subject: Re: [PATCH v2 11/21] DynamicTablesPkg: AML Code generation for Resource data EndTag
Date: Fri, 8 Oct 2021 15:07:06 +0100	[thread overview]
Message-ID: <63348e92-07e8-3fbe-08de-e25ccc392233@arm.com> (raw)
In-Reply-To: <20211007153210.26608-12-Pierre.Gondois@arm.com>

Hi Pierre,

This patch looks good to me.

Reviewed-by: Sami Mujawar <sami.mujawar@arm.com>

Regards,

Sami Mujawar

On 07/10/2021 04:32 PM, Pierre.Gondois@arm.com wrote:
> From: Pierre Gondois <Pierre.Gondois@arm.com>
>
> Add a helper function AmlCodeGenEndTag() to generate AML Resource Data
> EndTag. The EndTag resource data is automatically generated by the ASL
> compiler at the end of a list of resource data elements. Therefore, an
> equivalent function is not present in ASL.
>
> However, AmlCodeGenEndTag() is useful when generating AML code for the
> ResourceTemplate() macro.
>
> Signed-off-by: Pierre Gondois <Pierre.Gondois@arm.com>
> ---
>   .../AmlLib/CodeGen/AmlResourceDataCodeGen.c   | 113 ++++++++++++++++++
>   .../AmlLib/CodeGen/AmlResourceDataCodeGen.h   |  43 +++++++
>   2 files changed, 156 insertions(+)
>
> diff --git a/DynamicTablesPkg/Library/Common/AmlLib/CodeGen/AmlResourceDataCodeGen.c b/DynamicTablesPkg/Library/Common/AmlLib/CodeGen/AmlResourceDataCodeGen.c
> index 20b745f27a2b..0bdb6c24c5bb 100644
> --- a/DynamicTablesPkg/Library/Common/AmlLib/CodeGen/AmlResourceDataCodeGen.c
> +++ b/DynamicTablesPkg/Library/Common/AmlLib/CodeGen/AmlResourceDataCodeGen.c
> @@ -280,6 +280,119 @@ AmlCodeGenRdRegister (
>     return LinkRdNode (RdNode, NameOpNode, NewRdNode);
>   }
>
> +/** Code generation for the EndTag resource data.
> +
> +  The EndTag resource data is automatically generated by the ASL compiler
> +  at the end of a list of resource data elements. Thus, it doesn't have
> +  a corresponding ASL function.
> +
> +  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.
> +
> +  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]  CheckSum        CheckSum to store in the EndTag.
> +                               To ignore/avoid computing the checksum,
> +                               give 0.
> +  @param [in]  ParentNode      If not NULL, add the generated node
> +                               to the end of the variable list of
> +                               argument of the ParentNode.
> +                               The ParentNode must not initially contain
> +                               an EndTag resource data element.
> +  @param  [out] NewRdNode      If success, contains the generated 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
> +AmlCodeGenEndTag (
> +  IN  UINT8               CheckSum,   OPTIONAL
> +  IN  AML_OBJECT_NODE   * ParentNode, OPTIONAL
> +  OUT AML_DATA_NODE    ** NewRdNode   OPTIONAL
> +  )
> +{
> +  EFI_STATUS                      Status;
> +  AML_DATA_NODE                 * RdNode;
> +  EFI_ACPI_END_TAG_DESCRIPTOR     EndTag;
> +  ACPI_SMALL_RESOURCE_HEADER      SmallResHdr;
> +
> +  if ((ParentNode == NULL) && (NewRdNode == NULL)) {
> +    ASSERT (0);
> +    return EFI_INVALID_PARAMETER;
> +  }
> +
> +  RdNode = NULL;
> +
> +  // Header
> +  SmallResHdr.Bits.Length = sizeof (EFI_ACPI_END_TAG_DESCRIPTOR) -
> +                              sizeof (ACPI_SMALL_RESOURCE_HEADER);
> +  SmallResHdr.Bits.Name = ACPI_SMALL_END_TAG_DESCRIPTOR_NAME;
> +  SmallResHdr.Bits.Type = ACPI_SMALL_ITEM_FLAG;
> +
> +  // Body
> +  EndTag.Desc = SmallResHdr.Byte;
> +  EndTag.Checksum = CheckSum;
> +
> +  Status = AmlCreateDataNode (
> +             EAmlNodeDataTypeResourceData,
> +             (UINT8*)&EndTag,
> +             sizeof (EFI_ACPI_END_TAG_DESCRIPTOR),
> +             &RdNode
> +             );
> +  if (EFI_ERROR (Status)) {
> +    ASSERT (0);
> +    return Status;
> +  }
> +
> +  if (NewRdNode != NULL) {
> +    *NewRdNode = RdNode;
> +  }
> +
> +  if (ParentNode != NULL) {
> +    // Check the BufferOp doesn't contain any resource data yet.
> +    // This is a hard check: do not allow to add an EndTag if the BufferNode
> +    // already has resource data elements attached. Indeed, the EndTag should
> +    // have already been added.
> +    if (AmlGetNextVariableArgument ((AML_NODE_HEADER*)ParentNode, NULL) !=
> +          NULL) {
> +      ASSERT (0);
> +      Status = EFI_INVALID_PARAMETER;
> +      goto error_handler;
> +    }
> +
> +    // Add the EndTag RdNode. Indeed, the AmlAppendRdNode function
> +    // is looking for an EndTag, which we are adding here.
> +    Status = AmlVarListAddTail (
> +               (AML_NODE_HEADER*)ParentNode,
> +               (AML_NODE_HEADER*)RdNode
> +               );
> +    if (EFI_ERROR (Status)) {
> +      ASSERT (0);
> +      goto error_handler;
> +    }
> +  }
> +
> +  return Status;
> +
> +error_handler:
> +  if (RdNode != NULL) {
> +    AmlDeleteTree ((AML_NODE_HEADER*)RdNode);
> +  }
> +  return Status;
> +}
> +
>   // DEPRECATED APIS
>   #ifndef DISABLE_NEW_DEPRECATED_INTERFACES
>
> diff --git a/DynamicTablesPkg/Library/Common/AmlLib/CodeGen/AmlResourceDataCodeGen.h b/DynamicTablesPkg/Library/Common/AmlLib/CodeGen/AmlResourceDataCodeGen.h
> index 831d6a7462ae..102340495933 100644
> --- a/DynamicTablesPkg/Library/Common/AmlLib/CodeGen/AmlResourceDataCodeGen.h
> +++ b/DynamicTablesPkg/Library/Common/AmlLib/CodeGen/AmlResourceDataCodeGen.h
> @@ -104,4 +104,47 @@ AmlCodeGenRdRegister (
>     OUT AML_DATA_NODE_HANDLE    *NewRdNode  OPTIONAL
>     );
>
> +/** Code generation for the EndTag resource data.
> +
> +  The EndTag resource data is automatically generated by the ASL compiler
> +  at the end of a list of resource data elements. Thus, it doesn't have
> +  a corresponding ASL function.
> +
> +  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.
> +
> +  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]  CheckSum        CheckSum to store in the EndTag.
> +                               To ignore/avoid computing the checksum,
> +                               give 0.
> +  @param [in]  ParentNode      If not NULL, add the generated node
> +                               to the end of the variable list of
> +                               argument of the ParentNode.
> +                               The ParentNode must not initially contain
> +                               an EndTag resource data element.
> +  @param  [out] NewRdNode      If success, contains the generated 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
> +AmlCodeGenEndTag (
> +  IN  UINT8               CheckSum,   OPTIONAL
> +  IN  AML_OBJECT_NODE   * ParentNode, OPTIONAL
> +  OUT AML_DATA_NODE    ** NewRdNode   OPTIONAL
> +  );
> +
>   #endif // AML_RESOURCE_DATA_CODE_GEN_H_

IMPORTANT NOTICE: The contents of this email and any attachments are confidential and may also be privileged. If you are not the intended recipient, please notify the sender immediately and do not disclose the contents to any other person, use it for any purpose, or store or copy the information in any medium. Thank you.

  reply	other threads:[~2021-10-08 14:07 UTC|newest]

Thread overview: 38+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-10-07 15:31 [PATCH v2 00/21] Create a SSDT CPU topology generator PierreGondois
2021-10-07 15:31 ` [PATCH v2 01/21] DynamicTablesPkg: Remove unnecessary includes PierreGondois
2021-10-08 14:06   ` Sami Mujawar
2021-10-07 15:31 ` [PATCH v2 02/21] DynamicTablesPkg: Add missing parameter check PierreGondois
2021-10-08 14:06   ` Sami Mujawar
2021-10-07 15:31 ` [PATCH v2 03/21] DynamicTablesPkg: Add AddSsdtAcpiHeader() PierreGondois
2021-10-08 14:06   ` Sami Mujawar
2021-10-07 15:31 ` [PATCH v2 04/21] DynamicTablesPkg: Add AmlRdSetEndTagChecksum() PierreGondois
2021-10-08 14:06   ` Sami Mujawar
2021-10-07 15:31 ` [PATCH v2 05/21] DynamicTablesPkg: Add AmlSetRdListCheckSum() PierreGondois
2021-10-08 14:06   ` Sami Mujawar
2021-10-07 15:31 ` [PATCH v2 06/21] DynamicTablesPkg: Set EndTag's Checksum if RdList is modified PierreGondois
2021-10-08 14:06   ` Sami Mujawar
2021-10-07 15:31 ` [PATCH v2 07/21] DynamicTablesPkg: Clear pointer in node creation fcts PierreGondois
2021-10-08 14:06   ` Sami Mujawar
2021-10-07 15:31 ` [PATCH v2 08/21] DynamicTablesPkg: Update error handling for node creation PierreGondois
2021-10-08 14:06   ` Sami Mujawar
2021-10-07 15:31 ` [PATCH v2 09/21] DynamicTablesPkg: Make AmlNodeGetIntegerValue public PierreGondois
2021-10-07 15:31 ` [PATCH v2 10/21] DynamicTablesPkg: AML Code generation for Register() PierreGondois
2021-10-07 15:32 ` [PATCH v2 11/21] DynamicTablesPkg: AML Code generation for Resource data EndTag PierreGondois
2021-10-08 14:07   ` Sami Mujawar [this message]
2021-10-07 15:32 ` [PATCH v2 12/21] DynamicTablesPkg: AML code generation for a Package PierreGondois
2021-10-08 14:06   ` Sami Mujawar
2021-10-07 15:32 ` [PATCH v2 13/21] DynamicTablesPkg: Helper function to compute package length PierreGondois
2021-10-07 15:32 ` [PATCH v2 14/21] DynamicTablesPkg: AML code generation for a ResourceTemplate PierreGondois
2021-10-08 14:07   ` Sami Mujawar
2021-10-07 15:32 ` [PATCH v2 15/21] DynamicTablesPkg: AML code generation for a Method PierreGondois
2021-10-08 14:07   ` Sami Mujawar
2021-10-07 15:32 ` [PATCH v2 16/21] DynamicTablesPkg: AML code generation to Return a NameString PierreGondois
2021-10-08 13:28   ` Sami Mujawar
2021-10-07 15:32 ` [PATCH v2 17/21] DynamicTablesPkg: AML code generation for a Method returning a NS PierreGondois
2021-10-08 14:17   ` Sami Mujawar
2021-10-07 15:32 ` [PATCH v2 18/21] DynamicTablesPkg: AML code generation for a _LPI object PierreGondois
2021-10-08 14:24   ` Sami Mujawar
2021-10-07 15:32 ` [PATCH v2 19/21] DynamicTablesPkg: AML code generation to add an _LPI state PierreGondois
2021-10-08 14:29   ` Sami Mujawar
2021-10-07 15:32 ` [PATCH v2 20/21] DynamicTablesPkg: Add CM_ARM_LPI_INFO object PierreGondois
2021-10-07 15:32 ` [PATCH v2 21/21] DynamicTablesPkg: SSDT CPU topology and LPI state generator PierreGondois

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-list from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=63348e92-07e8-3fbe-08de-e25ccc392233@arm.com \
    --to=devel@edk2.groups.io \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox