4 Copyright (c) 2016 - 2019, ARM Limited. All rights reserved.
5 SPDX-License-Identifier: BSD-2-Clause-Patent
8 - ACPI 6.2 Specification - Errata A, September 2017
11 #include <IndustryStandard/Acpi.h>
12 #include <Library/PrintLib.h>
13 #include <Library/UefiLib.h>
14 #include "AcpiParser.h"
15 #include "AcpiTableParser.h"
18 STATIC CONST UINT64
* SlitSystemLocalityCount
;
19 STATIC ACPI_DESCRIPTION_HEADER_INFO AcpiHdrInfo
;
22 An ACPI_PARSER array describing the ACPI SLIT table.
24 STATIC CONST ACPI_PARSER SlitParser
[] = {
25 PARSE_ACPI_HEADER (&AcpiHdrInfo
),
26 {L
"Number of System Localities", 8, 36, L
"0x%lx", NULL
,
27 (VOID
**)&SlitSystemLocalityCount
, NULL
, NULL
}
31 Macro to get the value of a System Locality
33 #define SLIT_ELEMENT(Ptr, i, j) *(Ptr + (MultU64x64 (i, LocalityCount)) + j)
36 This function parses the ACPI SLIT table.
37 When trace is enabled this function parses the SLIT table and
38 traces the ACPI table fields.
40 This function also validates System Localities for the following:
41 - Diagonal elements have a normalized value of 10
42 - Relative distance from System Locality at i*N+j is same as
45 @param [in] Trace If TRUE, trace the ACPI fields.
46 @param [in] Ptr Pointer to the start of the buffer.
47 @param [in] AcpiTableLength Length of the ACPI table.
48 @param [in] AcpiTableRevision Revision of the ACPI table.
55 IN UINT32 AcpiTableLength
,
56 IN UINT8 AcpiTableRevision
64 CHAR16 Buffer
[80]; // Used for AsciiName param of ParseAcpi
76 PARSER_PARAMS (SlitParser
)
79 // Check if the values used to control the parsing logic have been
81 if (SlitSystemLocalityCount
== NULL
) {
82 IncrementErrorCount ();
84 L
"ERROR: Insufficient table length. AcpiTableLength = %d.\n",
90 LocalityPtr
= Ptr
+ Offset
;
91 LocalityCount
= *SlitSystemLocalityCount
;
93 // We only print the Localities if the count is less than 16
94 // If the locality count is more than 16 then refer to the
96 if (LocalityCount
< 16) {
100 L
"Entry[0x%lx][0x%lx]",
104 PrintFieldName (0, Buffer
);
107 for (Index
= 0; Index
< LocalityCount
; Index
++) {
108 Print (L
" (%3d) ", Index
);
111 for (Count
= 0; Count
< LocalityCount
; Count
++) {
112 Print (L
" (%3d) ", Count
);
113 for (Index
= 0; Index
< LocalityCount
; Index
++) {
114 Print (L
" %3d ", SLIT_ELEMENT (LocalityPtr
, Count
, Index
));
121 for (Count
= 0; Count
< LocalityCount
; Count
++) {
122 for (Index
= 0; Index
< LocalityCount
; Index
++) {
123 // Element[x][x] must be equal to 10
124 if ((Count
== Index
) && (SLIT_ELEMENT (LocalityPtr
, Count
,Index
) != 10)) {
125 IncrementErrorCount ();
127 L
"ERROR: Diagonal Element[0x%lx][0x%lx] (%3d)."
128 L
" Normalized Value is not 10\n",
131 SLIT_ELEMENT (LocalityPtr
, Count
, Index
)
134 // Element[i][j] must be equal to Element[j][i]
135 if (SLIT_ELEMENT (LocalityPtr
, Count
, Index
) !=
136 SLIT_ELEMENT (LocalityPtr
, Index
, Count
)) {
137 IncrementErrorCount ();
139 L
"ERROR: Relative distances for Element[0x%lx][0x%lx] (%3d) and \n"
140 L
"Element[0x%lx][0x%lx] (%3d) do not match.\n",
143 SLIT_ELEMENT (LocalityPtr
, Count
, Index
),
146 SLIT_ELEMENT (LocalityPtr
, Index
, Count
)