2010-02-24 01:21:16 +01:00
|
|
|
## @file
|
2009-03-20 21:58:47 +01:00
|
|
|
# ACPI Table Protocol Driver
|
|
|
|
#
|
2018-06-27 15:08:52 +02:00
|
|
|
# This driver initializes ACPI tables (Rsdp, Rsdt and Xsdt) and produces UEFI/PI
|
2016-04-18 03:39:19 +02:00
|
|
|
# services to install/uninstall/manage ACPI tables.
|
|
|
|
#
|
2021-04-30 08:17:56 +02:00
|
|
|
# Copyright (c) 2006 - 2021, Intel Corporation. All rights reserved.<BR>
|
MdeModulePkg: AcpiTableDxe: make 4 GB table allocation limit optional
AARCH64 systems never require compatibility with legacy ACPI OSes, and
may not have any 32-bit addressable system RAM. To support ACPI on these
systems, we need to be able to relax the 4 GB allocation restriction.
So add a PCD PcdAcpiExposedTableVersions containing a bitmask describing
which ACPI versions are targeted, and wire it up it up to the memory
allocation calls in AcpiTableDxe/AcpiTableProtocol.c. I.e., if ACPI v1.0b
is not among the supported versions, the memory allocations are not limited
to 4 GB, and only table types that carry 64-bit addresses are emitted.
Note that this will inhibit the publishing of any tables that carry only
32-bit addresses, i.e., RSDPv1, RSDTv1 and RSDTv3.
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Reviewed-by: "Yao, Jiewen" <jiewen.yao@intel.com>
Reviewed-by: Star Zeng <star.zeng@intel.com>
2016-02-17 15:37:58 +01:00
|
|
|
# Copyright (c) 2016, Linaro Ltd. All rights reserved.<BR>
|
2019-04-04 01:05:13 +02:00
|
|
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
2009-03-20 21:58:47 +01:00
|
|
|
#
|
2010-02-24 01:21:16 +01:00
|
|
|
##
|
2009-03-20 21:58:47 +01:00
|
|
|
|
|
|
|
[Defines]
|
|
|
|
INF_VERSION = 0x00010005
|
|
|
|
BASE_NAME = AcpiTableDxe
|
2014-08-28 08:34:06 +02:00
|
|
|
MODULE_UNI_FILE = AcpiTableDxe.uni
|
2010-04-06 04:54:39 +02:00
|
|
|
FILE_GUID = 9622E42C-8E38-4a08-9E8F-54F784652F6B
|
2009-03-20 21:58:47 +01:00
|
|
|
MODULE_TYPE = DXE_DRIVER
|
|
|
|
VERSION_STRING = 1.0
|
|
|
|
|
|
|
|
ENTRY_POINT = InitializeAcpiTableDxe
|
|
|
|
|
|
|
|
#
|
|
|
|
# The following information is for reference only and not required by the build tools.
|
|
|
|
#
|
2018-06-29 05:27:00 +02:00
|
|
|
# VALID_ARCHITECTURES = IA32 X64 EBC
|
2009-03-20 21:58:47 +01:00
|
|
|
#
|
|
|
|
|
2010-02-24 01:21:16 +01:00
|
|
|
[Sources]
|
2009-03-20 21:58:47 +01:00
|
|
|
AcpiTableProtocol.c
|
|
|
|
AcpiTable.h
|
|
|
|
AcpiTable.c
|
2010-05-18 04:26:49 +02:00
|
|
|
AcpiSdt.h
|
|
|
|
AcpiSdt.c
|
|
|
|
Aml.c
|
|
|
|
AmlString.c
|
|
|
|
AmlOption.c
|
|
|
|
AmlChild.c
|
|
|
|
AmlNamespace.c
|
2009-03-20 21:58:47 +01:00
|
|
|
|
|
|
|
[Packages]
|
|
|
|
MdePkg/MdePkg.dec
|
|
|
|
MdeModulePkg/MdeModulePkg.dec
|
|
|
|
|
|
|
|
[LibraryClasses]
|
|
|
|
UefiBootServicesTableLib
|
|
|
|
MemoryAllocationLib
|
|
|
|
UefiDriverEntryPoint
|
|
|
|
BaseMemoryLib
|
|
|
|
UefiLib
|
|
|
|
DebugLib
|
|
|
|
BaseLib
|
|
|
|
PcdLib
|
2021-04-30 08:17:56 +02:00
|
|
|
HobLib
|
2009-03-20 21:58:47 +01:00
|
|
|
|
|
|
|
[Guids]
|
2021-04-30 08:17:56 +02:00
|
|
|
gEfiAcpi10TableGuid ## PRODUCES ## SystemTable
|
|
|
|
gEfiAcpiTableGuid ## PRODUCES ## SystemTable
|
|
|
|
gUniversalPayloadAcpiTableGuid ## SOMETIMES_CONSUMES ## HOB
|
2009-03-20 21:58:47 +01:00
|
|
|
|
2010-05-18 04:26:49 +02:00
|
|
|
[FeaturePcd]
|
2014-08-28 08:34:06 +02:00
|
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdInstallAcpiSdtProtocol ## CONSUMES
|
2010-05-18 04:26:49 +02:00
|
|
|
|
2013-09-16 04:20:52 +02:00
|
|
|
[Pcd]
|
2014-08-28 08:34:06 +02:00
|
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdAcpiDefaultOemId ## CONSUMES
|
|
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdAcpiDefaultOemTableId ## CONSUMES
|
|
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdAcpiDefaultOemRevision ## CONSUMES
|
|
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdAcpiDefaultCreatorId ## CONSUMES
|
|
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdAcpiDefaultCreatorRevision ## CONSUMES
|
MdeModulePkg: AcpiTableDxe: make 4 GB table allocation limit optional
AARCH64 systems never require compatibility with legacy ACPI OSes, and
may not have any 32-bit addressable system RAM. To support ACPI on these
systems, we need to be able to relax the 4 GB allocation restriction.
So add a PCD PcdAcpiExposedTableVersions containing a bitmask describing
which ACPI versions are targeted, and wire it up it up to the memory
allocation calls in AcpiTableDxe/AcpiTableProtocol.c. I.e., if ACPI v1.0b
is not among the supported versions, the memory allocations are not limited
to 4 GB, and only table types that carry 64-bit addresses are emitted.
Note that this will inhibit the publishing of any tables that carry only
32-bit addresses, i.e., RSDPv1, RSDTv1 and RSDTv3.
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Reviewed-by: "Yao, Jiewen" <jiewen.yao@intel.com>
Reviewed-by: Star Zeng <star.zeng@intel.com>
2016-02-17 15:37:58 +01:00
|
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdAcpiExposedTableVersions ## CONSUMES
|
2013-09-16 04:20:52 +02:00
|
|
|
|
2009-03-20 21:58:47 +01:00
|
|
|
[Protocols]
|
2014-08-28 08:34:06 +02:00
|
|
|
gEfiAcpiTableProtocolGuid ## PRODUCES
|
|
|
|
gEfiAcpiSdtProtocolGuid ## PRODUCES
|
2009-03-20 21:58:47 +01:00
|
|
|
|
|
|
|
[Depex]
|
|
|
|
TRUE
|
|
|
|
|
2014-08-28 08:34:06 +02:00
|
|
|
[UserExtensions.TianoCore."ExtraFiles"]
|
|
|
|
AcpiTableDxeExtra.uni
|