REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3737 Apply uncrustify changes to .c/.h files in the ShellPkg package Cc: Andrew Fish <afish@apple.com> Cc: Leif Lindholm <leif@nuviainc.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com> Reviewed-by: Ray Ni <ray.ni@intel.com>
		
			
				
	
	
		
			167 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			167 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/** @file
 | 
						|
  RSDP table parser
 | 
						|
 | 
						|
  Copyright (c) 2016 - 2019, ARM Limited. All rights reserved.
 | 
						|
  SPDX-License-Identifier: BSD-2-Clause-Patent
 | 
						|
 | 
						|
  @par Reference(s):
 | 
						|
    - ACPI 6.2 Specification - Errata A, September 2017
 | 
						|
**/
 | 
						|
 | 
						|
#include <Library/UefiLib.h>
 | 
						|
#include "AcpiParser.h"
 | 
						|
#include "AcpiTableParser.h"
 | 
						|
 | 
						|
// Local Variables
 | 
						|
STATIC CONST UINT64  *XsdtAddress;
 | 
						|
 | 
						|
/**
 | 
						|
  This function validates the RSDT Address.
 | 
						|
 | 
						|
  @param [in] Ptr     Pointer to the start of the field data.
 | 
						|
  @param [in] Context Pointer to context specific information e.g. this
 | 
						|
                      could be a pointer to the ACPI table header.
 | 
						|
**/
 | 
						|
STATIC
 | 
						|
VOID
 | 
						|
EFIAPI
 | 
						|
ValidateRsdtAddress (
 | 
						|
  IN UINT8  *Ptr,
 | 
						|
  IN VOID   *Context
 | 
						|
  )
 | 
						|
{
 | 
						|
 #if defined (MDE_CPU_ARM) || defined (MDE_CPU_AARCH64)
 | 
						|
  // Reference: Server Base Boot Requirements System Software on ARM Platforms
 | 
						|
  // Section: 4.2.1.1 RSDP
 | 
						|
  // Root System Description Pointer (RSDP), ACPI ? 5.2.5.
 | 
						|
  //   - Within the RSDP, the RsdtAddress field must be null (zero) and the
 | 
						|
  //     XsdtAddresss MUST be a valid, non-null, 64-bit value.
 | 
						|
  UINT32  RsdtAddr;
 | 
						|
 | 
						|
  RsdtAddr = *(UINT32 *)Ptr;
 | 
						|
 | 
						|
  if (RsdtAddr != 0) {
 | 
						|
    IncrementErrorCount ();
 | 
						|
    Print (
 | 
						|
      L"\nERROR: Rsdt Address = 0x%p. This must be NULL on ARM Platforms.",
 | 
						|
      RsdtAddr
 | 
						|
      );
 | 
						|
  }
 | 
						|
 | 
						|
 #endif
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
  This function validates the XSDT Address.
 | 
						|
 | 
						|
  @param [in] Ptr     Pointer to the start of the field data.
 | 
						|
  @param [in] Context Pointer to context specific information e.g. this
 | 
						|
                      could be a pointer to the ACPI table header.
 | 
						|
**/
 | 
						|
STATIC
 | 
						|
VOID
 | 
						|
EFIAPI
 | 
						|
ValidateXsdtAddress (
 | 
						|
  IN UINT8  *Ptr,
 | 
						|
  IN VOID   *Context
 | 
						|
  )
 | 
						|
{
 | 
						|
 #if defined (MDE_CPU_ARM) || defined (MDE_CPU_AARCH64)
 | 
						|
  // Reference: Server Base Boot Requirements System Software on ARM Platforms
 | 
						|
  // Section: 4.2.1.1 RSDP
 | 
						|
  // Root System Description Pointer (RSDP), ACPI ? 5.2.5.
 | 
						|
  //   - Within the RSDP, the RsdtAddress field must be null (zero) and the
 | 
						|
  //     XsdtAddresss MUST be a valid, non-null, 64-bit value.
 | 
						|
  UINT64  XsdtAddr;
 | 
						|
 | 
						|
  XsdtAddr = *(UINT64 *)Ptr;
 | 
						|
 | 
						|
  if (XsdtAddr == 0) {
 | 
						|
    IncrementErrorCount ();
 | 
						|
    Print (
 | 
						|
      L"\nERROR: Xsdt Address = 0x%p. This must not be NULL on ARM Platforms.",
 | 
						|
      XsdtAddr
 | 
						|
      );
 | 
						|
  }
 | 
						|
 | 
						|
 #endif
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
  An array describing the ACPI RSDP Table.
 | 
						|
**/
 | 
						|
STATIC CONST ACPI_PARSER  RsdpParser[] = {
 | 
						|
  { L"Signature",         8, 0,  NULL,        Dump8Chars, NULL,                  NULL,                NULL },
 | 
						|
  { L"Checksum",          1, 8,  L"0x%x",     NULL,       NULL,                  NULL,                NULL },
 | 
						|
  { L"Oem ID",            6, 9,  NULL,        Dump6Chars, NULL,                  NULL,                NULL },
 | 
						|
  { L"Revision",          1, 15, L"%d",       NULL,       NULL,                  NULL,                NULL },
 | 
						|
  { L"RSDT Address",      4, 16, L"0x%x",     NULL,       NULL,                  ValidateRsdtAddress, NULL },
 | 
						|
  { L"Length",            4, 20, L"%d",       NULL,       NULL,                  NULL,                NULL },
 | 
						|
  { L"XSDT Address",      8, 24, L"0x%lx",    NULL,       (VOID **)&XsdtAddress,
 | 
						|
    ValidateXsdtAddress, NULL },
 | 
						|
  { L"Extended Checksum", 1, 32, L"0x%x",     NULL,       NULL,                  NULL,                NULL },
 | 
						|
  { L"Reserved",          3, 33, L"%x %x %x", Dump3Chars, NULL,                  NULL,                NULL }
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
  This function parses the ACPI RSDP table.
 | 
						|
 | 
						|
  This function invokes the parser for the XSDT table.
 | 
						|
  * Note - This function does not support parsing of RSDT table.
 | 
						|
 | 
						|
  This function also performs a RAW dump of the ACPI table and
 | 
						|
  validates the checksum.
 | 
						|
 | 
						|
  @param [in] Trace              If TRUE, trace the ACPI fields.
 | 
						|
  @param [in] Ptr                Pointer to the start of the buffer.
 | 
						|
  @param [in] AcpiTableLength    Length of the ACPI table.
 | 
						|
  @param [in] AcpiTableRevision  Revision of the ACPI table.
 | 
						|
**/
 | 
						|
VOID
 | 
						|
EFIAPI
 | 
						|
ParseAcpiRsdp (
 | 
						|
  IN BOOLEAN  Trace,
 | 
						|
  IN UINT8    *Ptr,
 | 
						|
  IN UINT32   AcpiTableLength,
 | 
						|
  IN UINT8    AcpiTableRevision
 | 
						|
  )
 | 
						|
{
 | 
						|
  if (Trace) {
 | 
						|
    DumpRaw (Ptr, AcpiTableLength);
 | 
						|
    VerifyChecksum (TRUE, Ptr, AcpiTableLength);
 | 
						|
  }
 | 
						|
 | 
						|
  ParseAcpi (
 | 
						|
    Trace,
 | 
						|
    0,
 | 
						|
    "RSDP",
 | 
						|
    Ptr,
 | 
						|
    AcpiTableLength,
 | 
						|
    PARSER_PARAMS (RsdpParser)
 | 
						|
    );
 | 
						|
 | 
						|
  // Check if the values used to control the parsing logic have been
 | 
						|
  // successfully read.
 | 
						|
  if (XsdtAddress == NULL) {
 | 
						|
    IncrementErrorCount ();
 | 
						|
    Print (
 | 
						|
      L"ERROR: Insufficient table length. AcpiTableLength = %d." \
 | 
						|
      L"RSDP parsing aborted.\n",
 | 
						|
      AcpiTableLength
 | 
						|
      );
 | 
						|
    return;
 | 
						|
  }
 | 
						|
 | 
						|
  // This code currently supports parsing of XSDT table only
 | 
						|
  // and does not parse the RSDT table. Platforms provide the
 | 
						|
  // RSDT to enable compatibility with ACPI 1.0 operating systems.
 | 
						|
  // Therefore the RSDT should not be used on ARM platforms.
 | 
						|
  if ((*XsdtAddress) == 0) {
 | 
						|
    IncrementErrorCount ();
 | 
						|
    Print (L"ERROR: XSDT Pointer is not set. RSDP parsing aborted.\n");
 | 
						|
    return;
 | 
						|
  }
 | 
						|
 | 
						|
  ProcessAcpiTable ((UINT8 *)(UINTN)(*XsdtAddress));
 | 
						|
}
 |