mirror of
				https://github.com/acidanthera/audk.git
				synced 2025-10-25 17:23:53 +02:00 
			
		
		
		
	Bugzilla: 3995 (https://bugzilla.tianocore.org/show_bug.cgi?id=3995) ACPI 6.4 spec states that if the revision field in the DSDT header is less than 2, then all integers are restricted in width to 32 bits, including in SSDTs. Arm Base boot requirements state that platforms must conform to ACPI 6.3 or later, and that legacy tables are not supported. Adds a check for this field and raise warning if revision is less than 2 on arm. Signed-off-by: Edward Pickup <edward.pickup@arm.com> Reviewed-by: Zhichao Gao <zhichao.gao@intel.com>
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|   DSDT table parser
 | |
| 
 | |
|   Copyright (c) 2016 - 2022, ARM Limited. All rights reserved.
 | |
|   SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| 
 | |
|   @par Reference(s):
 | |
|     - ACPI 6.2 Specification - Errata A, September 2017
 | |
| **/
 | |
| 
 | |
| #include <IndustryStandard/Acpi.h>
 | |
| #include <Library/UefiLib.h>
 | |
| #include "AcpiParser.h"
 | |
| #include "AcpiTableParser.h"
 | |
| 
 | |
| /**
 | |
|   This function parses the ACPI DSDT table.
 | |
|   When trace is enabled this function parses the DSDT table and
 | |
|   traces the ACPI table fields.
 | |
|   For the DSDT table only the ACPI header fields are parsed and
 | |
|   traced.
 | |
| 
 | |
|   @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
 | |
| ParseAcpiDsdt (
 | |
|   IN BOOLEAN  Trace,
 | |
|   IN UINT8    *Ptr,
 | |
|   IN UINT32   AcpiTableLength,
 | |
|   IN UINT8    AcpiTableRevision
 | |
|   )
 | |
| {
 | |
|   if (!Trace) {
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   DumpAcpiHeader (Ptr);
 | |
| 
 | |
|   // As per 19.6.29 in the version 6.4 of the ACPI spec, a revision less than 2
 | |
|   // restricts integers to 32 bit width. This may not be intended, raise a
 | |
|   // warning
 | |
|  #if defined (MDE_CPU_AARCH64) || defined (MDE_CPU_ARM)
 | |
|   if (AcpiTableRevision < 2) {
 | |
|     IncrementWarningCount ();
 | |
|     Print (
 | |
|       L"WARNING: DSDT Table Revision less than 2. Integer width restricted to "
 | |
|       L"32 bits. Table Revision = %d.\n",
 | |
|       AcpiTableRevision
 | |
|       );
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|  #endif
 | |
| }
 |