]> git.proxmox.com Git - mirror_edk2.git/blob - EmbeddedPkg/Include/Library/AcpiLib.h
EmbeddedPkg/AcpiLib: add GICC table init macro for ACPI 6.0
[mirror_edk2.git] / EmbeddedPkg / Include / Library / AcpiLib.h
1 /** @file
2 Helper Library for ACPI
3
4 Copyright (c) 2014-2016, ARM Ltd. All rights reserved.
5
6 This program and the accompanying materials
7 are licensed and made available under the terms and conditions of the BSD License
8 which accompanies this distribution. The full text of the license may be found at
9 http://opensource.org/licenses/bsd-license.php
10
11 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
13
14 **/
15
16 #ifndef __ACPI_LIB_H__
17 #define __ACPI_LIB_H__
18
19 #include <Uefi.h>
20
21 #include <IndustryStandard/Acpi10.h>
22
23 //
24 // Macros for the Generic Address Space
25 //
26 #define NULL_GAS { EFI_ACPI_5_0_SYSTEM_MEMORY, 0, 0, EFI_ACPI_5_0_UNDEFINED, 0L }
27 #define ARM_GAS8(Address) { EFI_ACPI_5_0_SYSTEM_MEMORY, 8, 0, EFI_ACPI_5_0_BYTE, Address }
28 #define ARM_GAS16(Address) { EFI_ACPI_5_0_SYSTEM_MEMORY, 16, 0, EFI_ACPI_5_0_WORD, Address }
29 #define ARM_GAS32(Address) { EFI_ACPI_5_0_SYSTEM_MEMORY, 32, 0, EFI_ACPI_5_0_DWORD, Address }
30 #define ARM_GASN(Address) { EFI_ACPI_5_0_SYSTEM_MEMORY, 0, 0, EFI_ACPI_5_0_DWORD, Address }
31
32 //
33 // Macros for the Multiple APIC Description Table (MADT)
34 //
35 #define EFI_ACPI_5_0_GIC_DISTRIBUTOR_INIT(GicDistHwId, GicDistBase, GicDistVector) \
36 { \
37 EFI_ACPI_5_0_GICD, sizeof (EFI_ACPI_5_0_GIC_DISTRIBUTOR_STRUCTURE), EFI_ACPI_RESERVED_WORD, \
38 GicDistHwId, GicDistBase, GicDistVector, EFI_ACPI_RESERVED_DWORD \
39 }
40
41 #define EFI_ACPI_6_0_GIC_DISTRIBUTOR_INIT(GicDistHwId, GicDistBase, GicDistVector, GicVersion) \
42 { \
43 EFI_ACPI_6_0_GICD, sizeof (EFI_ACPI_6_0_GIC_DISTRIBUTOR_STRUCTURE), EFI_ACPI_RESERVED_WORD, \
44 GicDistHwId, GicDistBase, GicDistVector, GicVersion, \
45 {EFI_ACPI_RESERVED_BYTE, EFI_ACPI_RESERVED_BYTE, EFI_ACPI_RESERVED_BYTE} \
46 }
47
48 // Note the parking protocol is configured by UEFI if required
49 #define EFI_ACPI_5_0_GIC_STRUCTURE_INIT(GicId, AcpiCpuId, Flags, PmuIrq, GicBase) \
50 { \
51 EFI_ACPI_5_0_GIC, sizeof (EFI_ACPI_5_0_GIC_STRUCTURE), EFI_ACPI_RESERVED_WORD, \
52 GicId, AcpiCpuId, Flags, 0, PmuIrq, 0, GicBase \
53 }
54
55 // Note the parking protocol is configured by UEFI if required
56 #define EFI_ACPI_5_1_GICC_STRUCTURE_INIT(GicId, AcpiCpuUid, Mpidr, Flags, PmuIrq, \
57 GicBase, GicVBase, GicHBase, GsivId, GicRBase) \
58 { \
59 EFI_ACPI_5_1_GIC, sizeof (EFI_ACPI_5_1_GIC_STRUCTURE), EFI_ACPI_RESERVED_WORD, \
60 GicId, AcpiCpuUid, Flags, 0, PmuIrq, 0, GicBase, GicVBase, GicHBase, \
61 GsivId, GicRBase, Mpidr \
62 }
63
64 #define EFI_ACPI_6_0_GICC_STRUCTURE_INIT(GicId, AcpiCpuUid, Mpidr, Flags, PmuIrq, \
65 GicBase, GicVBase, GicHBase, GsivId, GicRBase, Efficiency) \
66 { \
67 EFI_ACPI_6_0_GIC, sizeof (EFI_ACPI_6_0_GIC_STRUCTURE), EFI_ACPI_RESERVED_WORD, \
68 GicId, AcpiCpuUid, Flags, 0, PmuIrq, 0, GicBase, GicVBase, GicHBase, \
69 GsivId, GicRBase, Mpidr, Efficiency, \
70 {EFI_ACPI_RESERVED_BYTE, EFI_ACPI_RESERVED_BYTE, EFI_ACPI_RESERVED_BYTE} \
71 }
72
73 #define EFI_ACPI_6_0_GIC_MSI_FRAME_INIT(GicMsiFrameId, PhysicalBaseAddress, Flags, SPICount, SPIBase) \
74 { \
75 EFI_ACPI_6_0_GIC_MSI_FRAME, sizeof (EFI_ACPI_6_0_GIC_MSI_FRAME_STRUCTURE), EFI_ACPI_RESERVED_WORD, \
76 GicMsiFrameId, PhysicalBaseAddress, Flags, SPICount, SPIBase \
77 }
78
79 //
80 // SBSA Generic Watchdog
81 //
82 #define EFI_ACPI_5_1_SBSA_GENERIC_WATCHDOG_STRUCTURE_INIT(RefreshFramePhysicalAddress, \
83 ControlFramePhysicalAddress, WatchdogTimerGSIV, WatchdogTimerFlags) \
84 { \
85 EFI_ACPI_5_1_GTDT_SBSA_GENERIC_WATCHDOG, sizeof(EFI_ACPI_5_1_GTDT_SBSA_GENERIC_WATCHDOG_STRUCTURE), \
86 EFI_ACPI_RESERVED_BYTE, RefreshFramePhysicalAddress, ControlFramePhysicalAddress, \
87 WatchdogTimerGSIV, WatchdogTimerFlags \
88 }
89
90 typedef
91 BOOLEAN
92 (EFIAPI *EFI_LOCATE_ACPI_CHECK) (
93 IN EFI_ACPI_DESCRIPTION_HEADER *AcpiHeader
94 );
95
96 /**
97 Locate and Install the ACPI tables from the Firmware Volume if it verifies
98 the function condition.
99
100 @param AcpiFile Guid of the ACPI file into the Firmware Volume
101 @param CheckAcpiTableFunction Function that checks if the ACPI table should be installed
102
103 @return EFI_SUCCESS The function completed successfully.
104 @return EFI_NOT_FOUND The protocol could not be located.
105 @return EFI_OUT_OF_RESOURCES There are not enough resources to find the protocol.
106
107 **/
108 EFI_STATUS
109 LocateAndInstallAcpiFromFvConditional (
110 IN CONST EFI_GUID* AcpiFile,
111 IN EFI_LOCATE_ACPI_CHECK CheckAcpiTableFunction
112 );
113
114 /**
115 Locate and Install the ACPI tables from the Firmware Volume
116
117 @param AcpiFile Guid of the ACPI file into the Firmware Volume
118
119 @return EFI_SUCCESS The function completed successfully.
120 @return EFI_NOT_FOUND The protocol could not be located.
121 @return EFI_OUT_OF_RESOURCES There are not enough resources to find the protocol.
122
123 **/
124 EFI_STATUS
125 LocateAndInstallAcpiFromFv (
126 IN CONST EFI_GUID* AcpiFile
127 );
128
129 #endif // __ACPI_LIB_H__