169450Smsmith/******************************************************************************
269450Smsmith *
3167802Sjkim * Name: actbl1.h - Additional ACPI table definitions
469450Smsmith *
569450Smsmith *****************************************************************************/
669450Smsmith
7217365Sjkim/*
8281075Sdim * Copyright (C) 2000 - 2015, Intel Corp.
970243Smsmith * All rights reserved.
1069450Smsmith *
11217365Sjkim * Redistribution and use in source and binary forms, with or without
12217365Sjkim * modification, are permitted provided that the following conditions
13217365Sjkim * are met:
14217365Sjkim * 1. Redistributions of source code must retain the above copyright
15217365Sjkim *    notice, this list of conditions, and the following disclaimer,
16217365Sjkim *    without modification.
17217365Sjkim * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18217365Sjkim *    substantially similar to the "NO WARRANTY" disclaimer below
19217365Sjkim *    ("Disclaimer") and any redistribution must be conditioned upon
20217365Sjkim *    including a substantially similar Disclaimer requirement for further
21217365Sjkim *    binary redistribution.
22217365Sjkim * 3. Neither the names of the above-listed copyright holders nor the names
23217365Sjkim *    of any contributors may be used to endorse or promote products derived
24217365Sjkim *    from this software without specific prior written permission.
2569450Smsmith *
26217365Sjkim * Alternatively, this software may be distributed under the terms of the
27217365Sjkim * GNU General Public License ("GPL") version 2 as published by the Free
28217365Sjkim * Software Foundation.
2969450Smsmith *
30217365Sjkim * NO WARRANTY
31217365Sjkim * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32217365Sjkim * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33217365Sjkim * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34217365Sjkim * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35217365Sjkim * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36217365Sjkim * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37217365Sjkim * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38217365Sjkim * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39217365Sjkim * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40217365Sjkim * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41217365Sjkim * POSSIBILITY OF SUCH DAMAGES.
42217365Sjkim */
4369450Smsmith
4469450Smsmith#ifndef __ACTBL1_H__
4569450Smsmith#define __ACTBL1_H__
4669450Smsmith
47167802Sjkim
48167802Sjkim/*******************************************************************************
49167802Sjkim *
50197104Sjkim * Additional ACPI Tables (1)
51167802Sjkim *
52167802Sjkim * These tables are not consumed directly by the ACPICA subsystem, but are
53167802Sjkim * included here to support device drivers and the AML disassembler.
54167802Sjkim *
55197104Sjkim * The tables in this file are fully defined within the ACPI specification.
56197104Sjkim *
57167802Sjkim ******************************************************************************/
58167802Sjkim
59167802Sjkim
60167802Sjkim/*
61197104Sjkim * Values for description table header signatures for tables defined in this
62197104Sjkim * file. Useful because they make it more difficult to inadvertently type in
63197104Sjkim * the wrong signature.
64167802Sjkim */
65193267Sjkim#define ACPI_SIG_BERT           "BERT"      /* Boot Error Record Table */
66167802Sjkim#define ACPI_SIG_CPEP           "CPEP"      /* Corrected Platform Error Polling table */
67167802Sjkim#define ACPI_SIG_ECDT           "ECDT"      /* Embedded Controller Boot Resources Table */
68193267Sjkim#define ACPI_SIG_EINJ           "EINJ"      /* Error Injection table */
69193267Sjkim#define ACPI_SIG_ERST           "ERST"      /* Error Record Serialization Table */
70193267Sjkim#define ACPI_SIG_HEST           "HEST"      /* Hardware Error Source Table */
71167802Sjkim#define ACPI_SIG_MADT           "APIC"      /* Multiple APIC Description Table */
72197104Sjkim#define ACPI_SIG_MSCT           "MSCT"      /* Maximum System Characteristics Table */
73167802Sjkim#define ACPI_SIG_SBST           "SBST"      /* Smart Battery Specification Table */
74167802Sjkim#define ACPI_SIG_SLIT           "SLIT"      /* System Locality Distance Information Table */
75167802Sjkim#define ACPI_SIG_SRAT           "SRAT"      /* System Resource Affinity Table */
76284460Sjkim#define ACPI_SIG_NFIT           "NFIT"      /* NVDIMM Firmware Interface Table */
77167802Sjkim
78167802Sjkim
79167802Sjkim/*
80167802Sjkim * All tables must be byte-packed to match the ACPI specification, since
81167802Sjkim * the tables are provided by the system BIOS.
82167802Sjkim */
8369450Smsmith#pragma pack(1)
8469450Smsmith
8591116Smsmith/*
86239340Sjkim * Note: C bitfields are not used for this reason:
87239340Sjkim *
88239340Sjkim * "Bitfields are great and easy to read, but unfortunately the C language
89239340Sjkim * does not specify the layout of bitfields in memory, which means they are
90239340Sjkim * essentially useless for dealing with packed data in on-disk formats or
91239340Sjkim * binary wire protocols." (Or ACPI tables and buffers.) "If you ask me,
92239340Sjkim * this decision was a design error in C. Ritchie could have picked an order
93239340Sjkim * and stuck with it." Norman Ramsey.
94239340Sjkim * See http://stackoverflow.com/a/1053662/41661
9591116Smsmith */
96167802Sjkim
97167802Sjkim
98197104Sjkim/*******************************************************************************
99197104Sjkim *
100197104Sjkim * Common subtable headers
101197104Sjkim *
102197104Sjkim ******************************************************************************/
103167802Sjkim
104197104Sjkim/* Generic subtable header (used in MADT, SRAT, etc.) */
105197104Sjkim
106167802Sjkimtypedef struct acpi_subtable_header
10769450Smsmith{
108167802Sjkim    UINT8                   Type;
109167802Sjkim    UINT8                   Length;
110151937Sjkim
111167802Sjkim} ACPI_SUBTABLE_HEADER;
11269450Smsmith
11369450Smsmith
114197104Sjkim/* Subtable header for WHEA tables (EINJ, ERST, WDAT) */
115193267Sjkim
116193267Sjkimtypedef struct acpi_whea_header
117193267Sjkim{
118193267Sjkim    UINT8                   Action;
119193267Sjkim    UINT8                   Instruction;
120193267Sjkim    UINT8                   Flags;
121193267Sjkim    UINT8                   Reserved;
122193267Sjkim    ACPI_GENERIC_ADDRESS    RegisterRegion;
123193267Sjkim    UINT64                  Value;              /* Value used with Read/Write register */
124193267Sjkim    UINT64                  Mask;               /* Bitmask required for this register instruction */
125193267Sjkim
126193267Sjkim} ACPI_WHEA_HEADER;
127193267Sjkim
128193267Sjkim
129167802Sjkim/*******************************************************************************
130167802Sjkim *
131197104Sjkim * BERT - Boot Error Record Table (ACPI 4.0)
132197104Sjkim *        Version 1
133167802Sjkim *
134167802Sjkim ******************************************************************************/
135167802Sjkim
136193267Sjkimtypedef struct acpi_table_bert
137193267Sjkim{
138193267Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
139193267Sjkim    UINT32                  RegionLength;       /* Length of the boot error region */
140238381Sjkim    UINT64                  Address;            /* Physical address of the error region */
141193267Sjkim
142193267Sjkim} ACPI_TABLE_BERT;
143193267Sjkim
144193267Sjkim
145197104Sjkim/* Boot Error Region (not a subtable, pointed to by Address field above) */
146193267Sjkim
147193267Sjkimtypedef struct acpi_bert_region
148193267Sjkim{
149197104Sjkim    UINT32                  BlockStatus;        /* Type of error information */
150197104Sjkim    UINT32                  RawDataOffset;      /* Offset to raw error data */
151197104Sjkim    UINT32                  RawDataLength;      /* Length of raw error data */
152197104Sjkim    UINT32                  DataLength;         /* Length of generic error data */
153197104Sjkim    UINT32                  ErrorSeverity;      /* Severity code */
154193267Sjkim
155193267Sjkim} ACPI_BERT_REGION;
156193267Sjkim
157197104Sjkim/* Values for BlockStatus flags above */
158193267Sjkim
159193267Sjkim#define ACPI_BERT_UNCORRECTABLE             (1)
160197104Sjkim#define ACPI_BERT_CORRECTABLE               (1<<1)
161197104Sjkim#define ACPI_BERT_MULTIPLE_UNCORRECTABLE    (1<<2)
162197104Sjkim#define ACPI_BERT_MULTIPLE_CORRECTABLE      (1<<3)
163197104Sjkim#define ACPI_BERT_ERROR_ENTRY_COUNT         (0xFF<<4) /* 8 bits, error count */
164193267Sjkim
165197104Sjkim/* Values for ErrorSeverity above */
166193267Sjkim
167197104Sjkimenum AcpiBertErrorSeverity
168167802Sjkim{
169197104Sjkim    ACPI_BERT_ERROR_CORRECTABLE     = 0,
170197104Sjkim    ACPI_BERT_ERROR_FATAL           = 1,
171197104Sjkim    ACPI_BERT_ERROR_CORRECTED       = 2,
172197104Sjkim    ACPI_BERT_ERROR_NONE            = 3,
173197104Sjkim    ACPI_BERT_ERROR_RESERVED        = 4     /* 4 and greater are reserved */
174197104Sjkim};
175167802Sjkim
176197104Sjkim/*
177197104Sjkim * Note: The generic error data that follows the ErrorSeverity field above
178197104Sjkim * uses the ACPI_HEST_GENERIC_DATA defined under the HEST table below
179197104Sjkim */
180167802Sjkim
181167802Sjkim
182167802Sjkim/*******************************************************************************
183167802Sjkim *
184197104Sjkim * CPEP - Corrected Platform Error Polling table (ACPI 4.0)
185197104Sjkim *        Version 1
186167802Sjkim *
187167802Sjkim ******************************************************************************/
188167802Sjkim
189167802Sjkimtypedef struct acpi_table_cpep
190167802Sjkim{
191167802Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
192167802Sjkim    UINT64                  Reserved;
193167802Sjkim
194167802Sjkim} ACPI_TABLE_CPEP;
195167802Sjkim
196167802Sjkim
197167802Sjkim/* Subtable */
198167802Sjkim
199167802Sjkimtypedef struct acpi_cpep_polling
200167802Sjkim{
201197104Sjkim    ACPI_SUBTABLE_HEADER    Header;
202167802Sjkim    UINT8                   Id;                 /* Processor ID */
203167802Sjkim    UINT8                   Eid;                /* Processor EID */
204167802Sjkim    UINT32                  Interval;           /* Polling interval (msec) */
205167802Sjkim
206167802Sjkim} ACPI_CPEP_POLLING;
207167802Sjkim
208167802Sjkim
209167802Sjkim/*******************************************************************************
210167802Sjkim *
211167802Sjkim * ECDT - Embedded Controller Boot Resources Table
212197104Sjkim *        Version 1
213167802Sjkim *
214167802Sjkim ******************************************************************************/
215167802Sjkim
216167802Sjkimtypedef struct acpi_table_ecdt
217167802Sjkim{
218167802Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
219167802Sjkim    ACPI_GENERIC_ADDRESS    Control;            /* Address of EC command/status register */
220167802Sjkim    ACPI_GENERIC_ADDRESS    Data;               /* Address of EC data register */
221167802Sjkim    UINT32                  Uid;                /* Unique ID - must be same as the EC _UID method */
222167802Sjkim    UINT8                   Gpe;                /* The GPE for the EC */
223167802Sjkim    UINT8                   Id[1];              /* Full namepath of the EC in the ACPI namespace */
224167802Sjkim
225167802Sjkim} ACPI_TABLE_ECDT;
226167802Sjkim
227167802Sjkim
228167802Sjkim/*******************************************************************************
229167802Sjkim *
230197104Sjkim * EINJ - Error Injection Table (ACPI 4.0)
231197104Sjkim *        Version 1
232193267Sjkim *
233193267Sjkim ******************************************************************************/
234193267Sjkim
235193267Sjkimtypedef struct acpi_table_einj
236193267Sjkim{
237193267Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
238193267Sjkim    UINT32                  HeaderLength;
239197104Sjkim    UINT8                   Flags;
240197104Sjkim    UINT8                   Reserved[3];
241193267Sjkim    UINT32                  Entries;
242193267Sjkim
243193267Sjkim} ACPI_TABLE_EINJ;
244193267Sjkim
245197104Sjkim
246193267Sjkim/* EINJ Injection Instruction Entries (actions) */
247193267Sjkim
248193267Sjkimtypedef struct acpi_einj_entry
249193267Sjkim{
250193267Sjkim    ACPI_WHEA_HEADER        WheaHeader;         /* Common header for WHEA tables */
251193267Sjkim
252193267Sjkim} ACPI_EINJ_ENTRY;
253193267Sjkim
254197104Sjkim/* Masks for Flags field above */
255197104Sjkim
256197104Sjkim#define ACPI_EINJ_PRESERVE          (1)
257197104Sjkim
258193267Sjkim/* Values for Action field above */
259193267Sjkim
260193267Sjkimenum AcpiEinjActions
261193267Sjkim{
262228110Sjkim    ACPI_EINJ_BEGIN_OPERATION               = 0,
263228110Sjkim    ACPI_EINJ_GET_TRIGGER_TABLE             = 1,
264228110Sjkim    ACPI_EINJ_SET_ERROR_TYPE                = 2,
265228110Sjkim    ACPI_EINJ_GET_ERROR_TYPE                = 3,
266228110Sjkim    ACPI_EINJ_END_OPERATION                 = 4,
267228110Sjkim    ACPI_EINJ_EXECUTE_OPERATION             = 5,
268228110Sjkim    ACPI_EINJ_CHECK_BUSY_STATUS             = 6,
269228110Sjkim    ACPI_EINJ_GET_COMMAND_STATUS            = 7,
270228110Sjkim    ACPI_EINJ_SET_ERROR_TYPE_WITH_ADDRESS   = 8,
271228110Sjkim    ACPI_EINJ_ACTION_RESERVED               = 9,     /* 9 and greater are reserved */
272228110Sjkim    ACPI_EINJ_TRIGGER_ERROR                 = 0xFF   /* Except for this value */
273193267Sjkim};
274193267Sjkim
275193267Sjkim/* Values for Instruction field above */
276193267Sjkim
277193267Sjkimenum AcpiEinjInstructions
278193267Sjkim{
279193267Sjkim    ACPI_EINJ_READ_REGISTER         = 0,
280193267Sjkim    ACPI_EINJ_READ_REGISTER_VALUE   = 1,
281193267Sjkim    ACPI_EINJ_WRITE_REGISTER        = 2,
282193267Sjkim    ACPI_EINJ_WRITE_REGISTER_VALUE  = 3,
283193267Sjkim    ACPI_EINJ_NOOP                  = 4,
284228110Sjkim    ACPI_EINJ_FLUSH_CACHELINE       = 5,
285228110Sjkim    ACPI_EINJ_INSTRUCTION_RESERVED  = 6     /* 6 and greater are reserved */
286193267Sjkim};
287193267Sjkim
288228110Sjkimtypedef struct acpi_einj_error_type_with_addr
289228110Sjkim{
290228110Sjkim    UINT32                  ErrorType;
291228110Sjkim    UINT32                  VendorStructOffset;
292228110Sjkim    UINT32                  Flags;
293228110Sjkim    UINT32                  ApicId;
294228110Sjkim    UINT64                  Address;
295228110Sjkim    UINT64                  Range;
296228110Sjkim    UINT32                  PcieId;
297197104Sjkim
298228110Sjkim} ACPI_EINJ_ERROR_TYPE_WITH_ADDR;
299228110Sjkim
300228110Sjkimtypedef struct acpi_einj_vendor
301228110Sjkim{
302228110Sjkim    UINT32                  Length;
303228110Sjkim    UINT32                  PcieId;
304228110Sjkim    UINT16                  VendorId;
305228110Sjkim    UINT16                  DeviceId;
306228110Sjkim    UINT8                   RevisionId;
307228110Sjkim    UINT8                   Reserved[3];
308228110Sjkim
309228110Sjkim} ACPI_EINJ_VENDOR;
310228110Sjkim
311228110Sjkim
312193267Sjkim/* EINJ Trigger Error Action Table */
313193267Sjkim
314193267Sjkimtypedef struct acpi_einj_trigger
315193267Sjkim{
316193267Sjkim    UINT32                  HeaderSize;
317193267Sjkim    UINT32                  Revision;
318193267Sjkim    UINT32                  TableSize;
319193267Sjkim    UINT32                  EntryCount;
320193267Sjkim
321193267Sjkim} ACPI_EINJ_TRIGGER;
322193267Sjkim
323197104Sjkim/* Command status return values */
324193267Sjkim
325197104Sjkimenum AcpiEinjCommandStatus
326197104Sjkim{
327197104Sjkim    ACPI_EINJ_SUCCESS               = 0,
328197104Sjkim    ACPI_EINJ_FAILURE               = 1,
329197104Sjkim    ACPI_EINJ_INVALID_ACCESS        = 2,
330197104Sjkim    ACPI_EINJ_STATUS_RESERVED       = 3     /* 3 and greater are reserved */
331197104Sjkim};
332197104Sjkim
333197104Sjkim
334197104Sjkim/* Error types returned from ACPI_EINJ_GET_ERROR_TYPE (bitfield) */
335197104Sjkim
336197104Sjkim#define ACPI_EINJ_PROCESSOR_CORRECTABLE     (1)
337197104Sjkim#define ACPI_EINJ_PROCESSOR_UNCORRECTABLE   (1<<1)
338197104Sjkim#define ACPI_EINJ_PROCESSOR_FATAL           (1<<2)
339197104Sjkim#define ACPI_EINJ_MEMORY_CORRECTABLE        (1<<3)
340197104Sjkim#define ACPI_EINJ_MEMORY_UNCORRECTABLE      (1<<4)
341197104Sjkim#define ACPI_EINJ_MEMORY_FATAL              (1<<5)
342197104Sjkim#define ACPI_EINJ_PCIX_CORRECTABLE          (1<<6)
343197104Sjkim#define ACPI_EINJ_PCIX_UNCORRECTABLE        (1<<7)
344197104Sjkim#define ACPI_EINJ_PCIX_FATAL                (1<<8)
345197104Sjkim#define ACPI_EINJ_PLATFORM_CORRECTABLE      (1<<9)
346197104Sjkim#define ACPI_EINJ_PLATFORM_UNCORRECTABLE    (1<<10)
347197104Sjkim#define ACPI_EINJ_PLATFORM_FATAL            (1<<11)
348228110Sjkim#define ACPI_EINJ_VENDOR_DEFINED            (1<<31)
349197104Sjkim
350197104Sjkim
351193267Sjkim/*******************************************************************************
352193267Sjkim *
353197104Sjkim * ERST - Error Record Serialization Table (ACPI 4.0)
354197104Sjkim *        Version 1
355193267Sjkim *
356193267Sjkim ******************************************************************************/
357193267Sjkim
358193267Sjkimtypedef struct acpi_table_erst
359193267Sjkim{
360193267Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
361193267Sjkim    UINT32                  HeaderLength;
362193267Sjkim    UINT32                  Reserved;
363193267Sjkim    UINT32                  Entries;
364193267Sjkim
365193267Sjkim} ACPI_TABLE_ERST;
366193267Sjkim
367197104Sjkim
368193267Sjkim/* ERST Serialization Entries (actions) */
369193267Sjkim
370193267Sjkimtypedef struct acpi_erst_entry
371193267Sjkim{
372193267Sjkim    ACPI_WHEA_HEADER        WheaHeader;         /* Common header for WHEA tables */
373193267Sjkim
374193267Sjkim} ACPI_ERST_ENTRY;
375193267Sjkim
376197104Sjkim/* Masks for Flags field above */
377197104Sjkim
378197104Sjkim#define ACPI_ERST_PRESERVE          (1)
379197104Sjkim
380193267Sjkim/* Values for Action field above */
381193267Sjkim
382193267Sjkimenum AcpiErstActions
383193267Sjkim{
384197104Sjkim    ACPI_ERST_BEGIN_WRITE           = 0,
385197104Sjkim    ACPI_ERST_BEGIN_READ            = 1,
386197104Sjkim    ACPI_ERST_BEGIN_CLEAR           = 2,
387197104Sjkim    ACPI_ERST_END                   = 3,
388193267Sjkim    ACPI_ERST_SET_RECORD_OFFSET     = 4,
389193267Sjkim    ACPI_ERST_EXECUTE_OPERATION     = 5,
390193267Sjkim    ACPI_ERST_CHECK_BUSY_STATUS     = 6,
391193267Sjkim    ACPI_ERST_GET_COMMAND_STATUS    = 7,
392197104Sjkim    ACPI_ERST_GET_RECORD_ID         = 8,
393197104Sjkim    ACPI_ERST_SET_RECORD_ID         = 9,
394193267Sjkim    ACPI_ERST_GET_RECORD_COUNT      = 10,
395193267Sjkim    ACPI_ERST_BEGIN_DUMMY_WRIITE    = 11,
396193267Sjkim    ACPI_ERST_NOT_USED              = 12,
397193267Sjkim    ACPI_ERST_GET_ERROR_RANGE       = 13,
398193267Sjkim    ACPI_ERST_GET_ERROR_LENGTH      = 14,
399193267Sjkim    ACPI_ERST_GET_ERROR_ATTRIBUTES  = 15,
400193267Sjkim    ACPI_ERST_ACTION_RESERVED       = 16    /* 16 and greater are reserved */
401193267Sjkim};
402193267Sjkim
403193267Sjkim/* Values for Instruction field above */
404193267Sjkim
405193267Sjkimenum AcpiErstInstructions
406193267Sjkim{
407193267Sjkim    ACPI_ERST_READ_REGISTER         = 0,
408193267Sjkim    ACPI_ERST_READ_REGISTER_VALUE   = 1,
409193267Sjkim    ACPI_ERST_WRITE_REGISTER        = 2,
410193267Sjkim    ACPI_ERST_WRITE_REGISTER_VALUE  = 3,
411193267Sjkim    ACPI_ERST_NOOP                  = 4,
412193267Sjkim    ACPI_ERST_LOAD_VAR1             = 5,
413193267Sjkim    ACPI_ERST_LOAD_VAR2             = 6,
414193267Sjkim    ACPI_ERST_STORE_VAR1            = 7,
415193267Sjkim    ACPI_ERST_ADD                   = 8,
416193267Sjkim    ACPI_ERST_SUBTRACT              = 9,
417193267Sjkim    ACPI_ERST_ADD_VALUE             = 10,
418193267Sjkim    ACPI_ERST_SUBTRACT_VALUE        = 11,
419193267Sjkim    ACPI_ERST_STALL                 = 12,
420193267Sjkim    ACPI_ERST_STALL_WHILE_TRUE      = 13,
421193267Sjkim    ACPI_ERST_SKIP_NEXT_IF_TRUE     = 14,
422193267Sjkim    ACPI_ERST_GOTO                  = 15,
423193267Sjkim    ACPI_ERST_SET_SRC_ADDRESS_BASE  = 16,
424193267Sjkim    ACPI_ERST_SET_DST_ADDRESS_BASE  = 17,
425193267Sjkim    ACPI_ERST_MOVE_DATA             = 18,
426193267Sjkim    ACPI_ERST_INSTRUCTION_RESERVED  = 19    /* 19 and greater are reserved */
427193267Sjkim};
428193267Sjkim
429197104Sjkim/* Command status return values */
430193267Sjkim
431197104Sjkimenum AcpiErstCommandStatus
432197104Sjkim{
433197104Sjkim    ACPI_ERST_SUCESS                = 0,
434197104Sjkim    ACPI_ERST_NO_SPACE              = 1,
435197104Sjkim    ACPI_ERST_NOT_AVAILABLE         = 2,
436197104Sjkim    ACPI_ERST_FAILURE               = 3,
437197104Sjkim    ACPI_ERST_RECORD_EMPTY          = 4,
438197104Sjkim    ACPI_ERST_NOT_FOUND             = 5,
439197104Sjkim    ACPI_ERST_STATUS_RESERVED       = 6     /* 6 and greater are reserved */
440197104Sjkim};
441197104Sjkim
442197104Sjkim
443197104Sjkim/* Error Record Serialization Information */
444197104Sjkim
445197104Sjkimtypedef struct acpi_erst_info
446197104Sjkim{
447197104Sjkim    UINT16                  Signature;          /* Should be "ER" */
448197104Sjkim    UINT8                   Data[48];
449197104Sjkim
450197104Sjkim} ACPI_ERST_INFO;
451197104Sjkim
452197104Sjkim
453193267Sjkim/*******************************************************************************
454193267Sjkim *
455197104Sjkim * HEST - Hardware Error Source Table (ACPI 4.0)
456197104Sjkim *        Version 1
457193267Sjkim *
458193267Sjkim ******************************************************************************/
459193267Sjkim
460193267Sjkimtypedef struct acpi_table_hest
461193267Sjkim{
462193267Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
463193267Sjkim    UINT32                  ErrorSourceCount;
464193267Sjkim
465193267Sjkim} ACPI_TABLE_HEST;
466193267Sjkim
467193267Sjkim
468193267Sjkim/* HEST subtable header */
469193267Sjkim
470193267Sjkimtypedef struct acpi_hest_header
471193267Sjkim{
472193267Sjkim    UINT16                  Type;
473197104Sjkim    UINT16                  SourceId;
474193267Sjkim
475193267Sjkim} ACPI_HEST_HEADER;
476193267Sjkim
477193267Sjkim
478193267Sjkim/* Values for Type field above for subtables */
479193267Sjkim
480193267Sjkimenum AcpiHestTypes
481193267Sjkim{
482197104Sjkim    ACPI_HEST_TYPE_IA32_CHECK           = 0,
483197104Sjkim    ACPI_HEST_TYPE_IA32_CORRECTED_CHECK = 1,
484197104Sjkim    ACPI_HEST_TYPE_IA32_NMI             = 2,
485197104Sjkim    ACPI_HEST_TYPE_NOT_USED3            = 3,
486197104Sjkim    ACPI_HEST_TYPE_NOT_USED4            = 4,
487197104Sjkim    ACPI_HEST_TYPE_NOT_USED5            = 5,
488197104Sjkim    ACPI_HEST_TYPE_AER_ROOT_PORT        = 6,
489197104Sjkim    ACPI_HEST_TYPE_AER_ENDPOINT         = 7,
490197104Sjkim    ACPI_HEST_TYPE_AER_BRIDGE           = 8,
491197104Sjkim    ACPI_HEST_TYPE_GENERIC_ERROR        = 9,
492197104Sjkim    ACPI_HEST_TYPE_RESERVED             = 10    /* 10 and greater are reserved */
493193267Sjkim};
494193267Sjkim
495193267Sjkim
496193267Sjkim/*
497197104Sjkim * HEST substructures contained in subtables
498193267Sjkim */
499193267Sjkim
500197104Sjkim/*
501197104Sjkim * IA32 Error Bank(s) - Follows the ACPI_HEST_IA_MACHINE_CHECK and
502197104Sjkim * ACPI_HEST_IA_CORRECTED structures.
503197104Sjkim */
504197104Sjkimtypedef struct acpi_hest_ia_error_bank
505193267Sjkim{
506193267Sjkim    UINT8                   BankNumber;
507193267Sjkim    UINT8                   ClearStatusOnInit;
508193267Sjkim    UINT8                   StatusFormat;
509197104Sjkim    UINT8                   Reserved;
510193267Sjkim    UINT32                  ControlRegister;
511197104Sjkim    UINT64                  ControlData;
512193267Sjkim    UINT32                  StatusRegister;
513193267Sjkim    UINT32                  AddressRegister;
514193267Sjkim    UINT32                  MiscRegister;
515193267Sjkim
516197104Sjkim} ACPI_HEST_IA_ERROR_BANK;
517193267Sjkim
518193267Sjkim
519197104Sjkim/* Common HEST sub-structure for PCI/AER structures below (6,7,8) */
520193267Sjkim
521193267Sjkimtypedef struct acpi_hest_aer_common
522193267Sjkim{
523197104Sjkim    UINT16                  Reserved1;
524193267Sjkim    UINT8                   Flags;
525193267Sjkim    UINT8                   Enabled;
526197104Sjkim    UINT32                  RecordsToPreallocate;
527193267Sjkim    UINT32                  MaxSectionsPerRecord;
528281075Sdim    UINT32                  Bus;                    /* Bus and Segment numbers */
529193267Sjkim    UINT16                  Device;
530193267Sjkim    UINT16                  Function;
531193267Sjkim    UINT16                  DeviceControl;
532197104Sjkim    UINT16                  Reserved2;
533197104Sjkim    UINT32                  UncorrectableMask;
534197104Sjkim    UINT32                  UncorrectableSeverity;
535197104Sjkim    UINT32                  CorrectableMask;
536197104Sjkim    UINT32                  AdvancedCapabilities;
537193267Sjkim
538193267Sjkim} ACPI_HEST_AER_COMMON;
539193267Sjkim
540197104Sjkim/* Masks for HEST Flags fields */
541193267Sjkim
542197104Sjkim#define ACPI_HEST_FIRMWARE_FIRST        (1)
543197104Sjkim#define ACPI_HEST_GLOBAL                (1<<1)
544197104Sjkim
545281075Sdim/*
546281075Sdim * Macros to access the bus/segment numbers in Bus field above:
547281075Sdim *  Bus number is encoded in bits 7:0
548281075Sdim *  Segment number is encoded in bits 23:8
549281075Sdim */
550281075Sdim#define ACPI_HEST_BUS(Bus)              ((Bus) & 0xFF)
551281075Sdim#define ACPI_HEST_SEGMENT(Bus)          (((Bus) >> 8) & 0xFFFF)
552197104Sjkim
553281075Sdim
554193267Sjkim/* Hardware Error Notification */
555193267Sjkim
556193267Sjkimtypedef struct acpi_hest_notify
557193267Sjkim{
558193267Sjkim    UINT8                   Type;
559193267Sjkim    UINT8                   Length;
560193267Sjkim    UINT16                  ConfigWriteEnable;
561193267Sjkim    UINT32                  PollInterval;
562193267Sjkim    UINT32                  Vector;
563193267Sjkim    UINT32                  PollingThresholdValue;
564193267Sjkim    UINT32                  PollingThresholdWindow;
565193267Sjkim    UINT32                  ErrorThresholdValue;
566193267Sjkim    UINT32                  ErrorThresholdWindow;
567193267Sjkim
568193267Sjkim} ACPI_HEST_NOTIFY;
569193267Sjkim
570193267Sjkim/* Values for Notify Type field above */
571193267Sjkim
572193267Sjkimenum AcpiHestNotifyTypes
573193267Sjkim{
574193267Sjkim    ACPI_HEST_NOTIFY_POLLED     = 0,
575193267Sjkim    ACPI_HEST_NOTIFY_EXTERNAL   = 1,
576193267Sjkim    ACPI_HEST_NOTIFY_LOCAL      = 2,
577193267Sjkim    ACPI_HEST_NOTIFY_SCI        = 3,
578193267Sjkim    ACPI_HEST_NOTIFY_NMI        = 4,
579240716Sjkim    ACPI_HEST_NOTIFY_CMCI       = 5,    /* ACPI 5.0 */
580240716Sjkim    ACPI_HEST_NOTIFY_MCE        = 6,    /* ACPI 5.0 */
581240716Sjkim    ACPI_HEST_NOTIFY_RESERVED   = 7     /* 7 and greater are reserved */
582193267Sjkim};
583193267Sjkim
584197104Sjkim/* Values for ConfigWriteEnable bitfield above */
585193267Sjkim
586197104Sjkim#define ACPI_HEST_TYPE                  (1)
587197104Sjkim#define ACPI_HEST_POLL_INTERVAL         (1<<1)
588197104Sjkim#define ACPI_HEST_POLL_THRESHOLD_VALUE  (1<<2)
589197104Sjkim#define ACPI_HEST_POLL_THRESHOLD_WINDOW (1<<3)
590197104Sjkim#define ACPI_HEST_ERR_THRESHOLD_VALUE   (1<<4)
591197104Sjkim#define ACPI_HEST_ERR_THRESHOLD_WINDOW  (1<<5)
592197104Sjkim
593197104Sjkim
594193267Sjkim/*
595193267Sjkim * HEST subtables
596193267Sjkim */
597193267Sjkim
598197104Sjkim/* 0: IA32 Machine Check Exception */
599193267Sjkim
600197104Sjkimtypedef struct acpi_hest_ia_machine_check
601193267Sjkim{
602193267Sjkim    ACPI_HEST_HEADER        Header;
603197104Sjkim    UINT16                  Reserved1;
604193267Sjkim    UINT8                   Flags;
605197104Sjkim    UINT8                   Enabled;
606197104Sjkim    UINT32                  RecordsToPreallocate;
607193267Sjkim    UINT32                  MaxSectionsPerRecord;
608193267Sjkim    UINT64                  GlobalCapabilityData;
609193267Sjkim    UINT64                  GlobalControlData;
610193267Sjkim    UINT8                   NumHardwareBanks;
611197104Sjkim    UINT8                   Reserved3[7];
612193267Sjkim
613197104Sjkim} ACPI_HEST_IA_MACHINE_CHECK;
614193267Sjkim
615193267Sjkim
616197104Sjkim/* 1: IA32 Corrected Machine Check */
617193267Sjkim
618197104Sjkimtypedef struct acpi_hest_ia_corrected
619193267Sjkim{
620193267Sjkim    ACPI_HEST_HEADER        Header;
621197104Sjkim    UINT16                  Reserved1;
622193267Sjkim    UINT8                   Flags;
623193267Sjkim    UINT8                   Enabled;
624197104Sjkim    UINT32                  RecordsToPreallocate;
625193267Sjkim    UINT32                  MaxSectionsPerRecord;
626193267Sjkim    ACPI_HEST_NOTIFY        Notify;
627193267Sjkim    UINT8                   NumHardwareBanks;
628197104Sjkim    UINT8                   Reserved2[3];
629193267Sjkim
630197104Sjkim} ACPI_HEST_IA_CORRECTED;
631193267Sjkim
632193267Sjkim
633197104Sjkim/* 2: IA32 Non-Maskable Interrupt */
634193267Sjkim
635197104Sjkimtypedef struct acpi_hest_ia_nmi
636193267Sjkim{
637193267Sjkim    ACPI_HEST_HEADER        Header;
638193267Sjkim    UINT32                  Reserved;
639197104Sjkim    UINT32                  RecordsToPreallocate;
640193267Sjkim    UINT32                  MaxSectionsPerRecord;
641193267Sjkim    UINT32                  MaxRawDataLength;
642193267Sjkim
643197104Sjkim} ACPI_HEST_IA_NMI;
644193267Sjkim
645193267Sjkim
646197104Sjkim/* 3,4,5: Not used */
647193267Sjkim
648193267Sjkim/* 6: PCI Express Root Port AER */
649193267Sjkim
650193267Sjkimtypedef struct acpi_hest_aer_root
651193267Sjkim{
652193267Sjkim    ACPI_HEST_HEADER        Header;
653193267Sjkim    ACPI_HEST_AER_COMMON    Aer;
654193267Sjkim    UINT32                  RootErrorCommand;
655193267Sjkim
656193267Sjkim} ACPI_HEST_AER_ROOT;
657193267Sjkim
658193267Sjkim
659193267Sjkim/* 7: PCI Express AER (AER Endpoint) */
660193267Sjkim
661193267Sjkimtypedef struct acpi_hest_aer
662193267Sjkim{
663193267Sjkim    ACPI_HEST_HEADER        Header;
664193267Sjkim    ACPI_HEST_AER_COMMON    Aer;
665193267Sjkim
666193267Sjkim} ACPI_HEST_AER;
667193267Sjkim
668193267Sjkim
669193267Sjkim/* 8: PCI Express/PCI-X Bridge AER */
670193267Sjkim
671193267Sjkimtypedef struct acpi_hest_aer_bridge
672193267Sjkim{
673193267Sjkim    ACPI_HEST_HEADER        Header;
674193267Sjkim    ACPI_HEST_AER_COMMON    Aer;
675197104Sjkim    UINT32                  UncorrectableMask2;
676197104Sjkim    UINT32                  UncorrectableSeverity2;
677197104Sjkim    UINT32                  AdvancedCapabilities2;
678193267Sjkim
679193267Sjkim} ACPI_HEST_AER_BRIDGE;
680193267Sjkim
681193267Sjkim
682193267Sjkim/* 9: Generic Hardware Error Source */
683193267Sjkim
684193267Sjkimtypedef struct acpi_hest_generic
685193267Sjkim{
686193267Sjkim    ACPI_HEST_HEADER        Header;
687193267Sjkim    UINT16                  RelatedSourceId;
688197104Sjkim    UINT8                   Reserved;
689193267Sjkim    UINT8                   Enabled;
690197104Sjkim    UINT32                  RecordsToPreallocate;
691193267Sjkim    UINT32                  MaxSectionsPerRecord;
692193267Sjkim    UINT32                  MaxRawDataLength;
693193267Sjkim    ACPI_GENERIC_ADDRESS    ErrorStatusAddress;
694193267Sjkim    ACPI_HEST_NOTIFY        Notify;
695197104Sjkim    UINT32                  ErrorBlockLength;
696193267Sjkim
697193267Sjkim} ACPI_HEST_GENERIC;
698193267Sjkim
699193267Sjkim
700197104Sjkim/* Generic Error Status block */
701167802Sjkim
702197104Sjkimtypedef struct acpi_hest_generic_status
703167802Sjkim{
704197104Sjkim    UINT32                  BlockStatus;
705197104Sjkim    UINT32                  RawDataOffset;
706197104Sjkim    UINT32                  RawDataLength;
707197104Sjkim    UINT32                  DataLength;
708197104Sjkim    UINT32                  ErrorSeverity;
709167802Sjkim
710197104Sjkim} ACPI_HEST_GENERIC_STATUS;
711167802Sjkim
712197104Sjkim/* Values for BlockStatus flags above */
713167802Sjkim
714197104Sjkim#define ACPI_HEST_UNCORRECTABLE             (1)
715197104Sjkim#define ACPI_HEST_CORRECTABLE               (1<<1)
716197104Sjkim#define ACPI_HEST_MULTIPLE_UNCORRECTABLE    (1<<2)
717197104Sjkim#define ACPI_HEST_MULTIPLE_CORRECTABLE      (1<<3)
718197104Sjkim#define ACPI_HEST_ERROR_ENTRY_COUNT         (0xFF<<4) /* 8 bits, error count */
719167802Sjkim
720167802Sjkim
721197104Sjkim/* Generic Error Data entry */
722167802Sjkim
723197104Sjkimtypedef struct acpi_hest_generic_data
724193267Sjkim{
725197104Sjkim    UINT8                   SectionType[16];
726197104Sjkim    UINT32                  ErrorSeverity;
727197104Sjkim    UINT16                  Revision;
728197104Sjkim    UINT8                   ValidationBits;
729193267Sjkim    UINT8                   Flags;
730197104Sjkim    UINT32                  ErrorDataLength;
731197104Sjkim    UINT8                   FruId[16];
732197104Sjkim    UINT8                   FruText[20];
733193267Sjkim
734197104Sjkim} ACPI_HEST_GENERIC_DATA;
735193267Sjkim
736193267Sjkim
737193267Sjkim/*******************************************************************************
738193267Sjkim *
739167802Sjkim * MADT - Multiple APIC Description Table
740197104Sjkim *        Version 3
741167802Sjkim *
742167802Sjkim ******************************************************************************/
743167802Sjkim
744167802Sjkimtypedef struct acpi_table_madt
745167802Sjkim{
746167802Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
747167802Sjkim    UINT32                  Address;            /* Physical address of local APIC */
748167802Sjkim    UINT32                  Flags;
749167802Sjkim
750167802Sjkim} ACPI_TABLE_MADT;
751167802Sjkim
752197104Sjkim/* Masks for Flags field above */
753167802Sjkim
754197104Sjkim#define ACPI_MADT_PCAT_COMPAT       (1)         /* 00: System also has dual 8259s */
755167802Sjkim
756167802Sjkim/* Values for PCATCompat flag */
757167802Sjkim
758167802Sjkim#define ACPI_MADT_DUAL_PIC          0
759167802Sjkim#define ACPI_MADT_MULTIPLE_APIC     1
760167802Sjkim
761167802Sjkim
762197104Sjkim/* Values for MADT subtable type in ACPI_SUBTABLE_HEADER */
763167802Sjkim
764167802Sjkimenum AcpiMadtType
765167802Sjkim{
766281075Sdim    ACPI_MADT_TYPE_LOCAL_APIC               = 0,
767281075Sdim    ACPI_MADT_TYPE_IO_APIC                  = 1,
768281075Sdim    ACPI_MADT_TYPE_INTERRUPT_OVERRIDE       = 2,
769281075Sdim    ACPI_MADT_TYPE_NMI_SOURCE               = 3,
770281075Sdim    ACPI_MADT_TYPE_LOCAL_APIC_NMI           = 4,
771281075Sdim    ACPI_MADT_TYPE_LOCAL_APIC_OVERRIDE      = 5,
772281075Sdim    ACPI_MADT_TYPE_IO_SAPIC                 = 6,
773281075Sdim    ACPI_MADT_TYPE_LOCAL_SAPIC              = 7,
774281075Sdim    ACPI_MADT_TYPE_INTERRUPT_SOURCE         = 8,
775281075Sdim    ACPI_MADT_TYPE_LOCAL_X2APIC             = 9,
776281075Sdim    ACPI_MADT_TYPE_LOCAL_X2APIC_NMI         = 10,
777281075Sdim    ACPI_MADT_TYPE_GENERIC_INTERRUPT        = 11,
778281075Sdim    ACPI_MADT_TYPE_GENERIC_DISTRIBUTOR      = 12,
779281075Sdim    ACPI_MADT_TYPE_GENERIC_MSI_FRAME        = 13,
780281075Sdim    ACPI_MADT_TYPE_GENERIC_REDISTRIBUTOR    = 14,
781284460Sjkim    ACPI_MADT_TYPE_GENERIC_TRANSLATOR       = 15,
782284460Sjkim    ACPI_MADT_TYPE_RESERVED                 = 16    /* 16 and greater are reserved */
783167802Sjkim};
784167802Sjkim
785167802Sjkim
786167802Sjkim/*
787281075Sdim * MADT Subtables, correspond to Type in ACPI_SUBTABLE_HEADER
788167802Sjkim */
789167802Sjkim
790167802Sjkim/* 0: Processor Local APIC */
791167802Sjkim
792167802Sjkimtypedef struct acpi_madt_local_apic
793167802Sjkim{
794167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
795167802Sjkim    UINT8                   ProcessorId;        /* ACPI processor id */
796167802Sjkim    UINT8                   Id;                 /* Processor's local APIC id */
797167802Sjkim    UINT32                  LapicFlags;
798167802Sjkim
799167802Sjkim} ACPI_MADT_LOCAL_APIC;
800167802Sjkim
801197104Sjkim
802167802Sjkim/* 1: IO APIC */
803167802Sjkim
804167802Sjkimtypedef struct acpi_madt_io_apic
805167802Sjkim{
806167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
807167802Sjkim    UINT8                   Id;                 /* I/O APIC ID */
808167802Sjkim    UINT8                   Reserved;           /* Reserved - must be zero */
809167802Sjkim    UINT32                  Address;            /* APIC physical address */
810167802Sjkim    UINT32                  GlobalIrqBase;      /* Global system interrupt where INTI lines start */
811167802Sjkim
812167802Sjkim} ACPI_MADT_IO_APIC;
813167802Sjkim
814197104Sjkim
815167802Sjkim/* 2: Interrupt Override */
816167802Sjkim
817167802Sjkimtypedef struct acpi_madt_interrupt_override
818167802Sjkim{
819167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
820167802Sjkim    UINT8                   Bus;                /* 0 - ISA */
821167802Sjkim    UINT8                   SourceIrq;          /* Interrupt source (IRQ) */
822167802Sjkim    UINT32                  GlobalIrq;          /* Global system interrupt */
823167802Sjkim    UINT16                  IntiFlags;
824167802Sjkim
825167802Sjkim} ACPI_MADT_INTERRUPT_OVERRIDE;
826167802Sjkim
827197104Sjkim
828167802Sjkim/* 3: NMI Source */
829167802Sjkim
830167802Sjkimtypedef struct acpi_madt_nmi_source
831167802Sjkim{
832167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
833167802Sjkim    UINT16                  IntiFlags;
834167802Sjkim    UINT32                  GlobalIrq;          /* Global system interrupt */
835167802Sjkim
836167802Sjkim} ACPI_MADT_NMI_SOURCE;
837167802Sjkim
838197104Sjkim
839167802Sjkim/* 4: Local APIC NMI */
840167802Sjkim
841167802Sjkimtypedef struct acpi_madt_local_apic_nmi
842167802Sjkim{
843167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
844167802Sjkim    UINT8                   ProcessorId;        /* ACPI processor id */
845167802Sjkim    UINT16                  IntiFlags;
846167802Sjkim    UINT8                   Lint;               /* LINTn to which NMI is connected */
847167802Sjkim
848167802Sjkim} ACPI_MADT_LOCAL_APIC_NMI;
849167802Sjkim
850197104Sjkim
851167802Sjkim/* 5: Address Override */
852167802Sjkim
853167802Sjkimtypedef struct acpi_madt_local_apic_override
854167802Sjkim{
855167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
856167802Sjkim    UINT16                  Reserved;           /* Reserved, must be zero */
857167802Sjkim    UINT64                  Address;            /* APIC physical address */
858167802Sjkim
859167802Sjkim} ACPI_MADT_LOCAL_APIC_OVERRIDE;
860167802Sjkim
861197104Sjkim
862167802Sjkim/* 6: I/O Sapic */
863167802Sjkim
864167802Sjkimtypedef struct acpi_madt_io_sapic
865167802Sjkim{
866167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
867167802Sjkim    UINT8                   Id;                 /* I/O SAPIC ID */
868167802Sjkim    UINT8                   Reserved;           /* Reserved, must be zero */
869167802Sjkim    UINT32                  GlobalIrqBase;      /* Global interrupt for SAPIC start */
870167802Sjkim    UINT64                  Address;            /* SAPIC physical address */
871167802Sjkim
872167802Sjkim} ACPI_MADT_IO_SAPIC;
873167802Sjkim
874197104Sjkim
875167802Sjkim/* 7: Local Sapic */
876167802Sjkim
877167802Sjkimtypedef struct acpi_madt_local_sapic
878167802Sjkim{
879167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
880167802Sjkim    UINT8                   ProcessorId;        /* ACPI processor id */
881167802Sjkim    UINT8                   Id;                 /* SAPIC ID */
882167802Sjkim    UINT8                   Eid;                /* SAPIC EID */
883167802Sjkim    UINT8                   Reserved[3];        /* Reserved, must be zero */
884167802Sjkim    UINT32                  LapicFlags;
885167802Sjkim    UINT32                  Uid;                /* Numeric UID - ACPI 3.0 */
886167802Sjkim    char                    UidString[1];       /* String UID  - ACPI 3.0 */
887167802Sjkim
888167802Sjkim} ACPI_MADT_LOCAL_SAPIC;
889167802Sjkim
890197104Sjkim
891167802Sjkim/* 8: Platform Interrupt Source */
892167802Sjkim
893167802Sjkimtypedef struct acpi_madt_interrupt_source
894167802Sjkim{
895167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
896167802Sjkim    UINT16                  IntiFlags;
897167802Sjkim    UINT8                   Type;               /* 1=PMI, 2=INIT, 3=corrected */
898167802Sjkim    UINT8                   Id;                 /* Processor ID */
899167802Sjkim    UINT8                   Eid;                /* Processor EID */
900167802Sjkim    UINT8                   IoSapicVector;      /* Vector value for PMI interrupts */
901167802Sjkim    UINT32                  GlobalIrq;          /* Global system interrupt */
902167802Sjkim    UINT32                  Flags;              /* Interrupt Source Flags */
903167802Sjkim
904167802Sjkim} ACPI_MADT_INTERRUPT_SOURCE;
905167802Sjkim
906197104Sjkim/* Masks for Flags field above */
907167802Sjkim
908167802Sjkim#define ACPI_MADT_CPEI_OVERRIDE     (1)
909167802Sjkim
910167802Sjkim
911197104Sjkim/* 9: Processor Local X2APIC (ACPI 4.0) */
912197104Sjkim
913193267Sjkimtypedef struct acpi_madt_local_x2apic
914193267Sjkim{
915193267Sjkim    ACPI_SUBTABLE_HEADER    Header;
916193267Sjkim    UINT16                  Reserved;           /* Reserved - must be zero */
917193267Sjkim    UINT32                  LocalApicId;        /* Processor x2APIC ID  */
918193267Sjkim    UINT32                  LapicFlags;
919193267Sjkim    UINT32                  Uid;                /* ACPI processor UID */
920193267Sjkim
921193267Sjkim} ACPI_MADT_LOCAL_X2APIC;
922193267Sjkim
923193267Sjkim
924197104Sjkim/* 10: Local X2APIC NMI (ACPI 4.0) */
925197104Sjkim
926193267Sjkimtypedef struct acpi_madt_local_x2apic_nmi
927193267Sjkim{
928193267Sjkim    ACPI_SUBTABLE_HEADER    Header;
929193267Sjkim    UINT16                  IntiFlags;
930193267Sjkim    UINT32                  Uid;                /* ACPI processor UID */
931193267Sjkim    UINT8                   Lint;               /* LINTn to which NMI is connected */
932193267Sjkim    UINT8                   Reserved[3];        /* Reserved - must be zero */
933193267Sjkim
934193267Sjkim} ACPI_MADT_LOCAL_X2APIC_NMI;
935193267Sjkim
936193267Sjkim
937284460Sjkim/* 11: Generic Interrupt (ACPI 5.0 + ACPI 6.0 changes) */
938228110Sjkim
939228110Sjkimtypedef struct acpi_madt_generic_interrupt
940228110Sjkim{
941228110Sjkim    ACPI_SUBTABLE_HEADER    Header;
942228110Sjkim    UINT16                  Reserved;           /* Reserved - must be zero */
943281075Sdim    UINT32                  CpuInterfaceNumber;
944228110Sjkim    UINT32                  Uid;
945228110Sjkim    UINT32                  Flags;
946228110Sjkim    UINT32                  ParkingVersion;
947228110Sjkim    UINT32                  PerformanceInterrupt;
948228110Sjkim    UINT64                  ParkedAddress;
949228110Sjkim    UINT64                  BaseAddress;
950281075Sdim    UINT64                  GicvBaseAddress;
951281075Sdim    UINT64                  GichBaseAddress;
952281075Sdim    UINT32                  VgicInterrupt;
953281075Sdim    UINT64                  GicrBaseAddress;
954281075Sdim    UINT64                  ArmMpidr;
955284460Sjkim    UINT8                   EfficiencyClass;
956284460Sjkim    UINT8                   Reserved2[3];
957228110Sjkim
958228110Sjkim} ACPI_MADT_GENERIC_INTERRUPT;
959228110Sjkim
960281075Sdim/* Masks for Flags field above */
961228110Sjkim
962281075Sdim/* ACPI_MADT_ENABLED                    (1)      Processor is usable if set */
963281075Sdim#define ACPI_MADT_PERFORMANCE_IRQ_MODE  (1<<1)  /* 01: Performance Interrupt Mode */
964281075Sdim#define ACPI_MADT_VGIC_IRQ_MODE         (1<<2)  /* 02: VGIC Maintenance Interrupt mode */
965281075Sdim
966281075Sdim
967284460Sjkim/* 12: Generic Distributor (ACPI 5.0 + ACPI 6.0 changes) */
968228110Sjkim
969228110Sjkimtypedef struct acpi_madt_generic_distributor
970228110Sjkim{
971228110Sjkim    ACPI_SUBTABLE_HEADER    Header;
972228110Sjkim    UINT16                  Reserved;           /* Reserved - must be zero */
973228110Sjkim    UINT32                  GicId;
974228110Sjkim    UINT64                  BaseAddress;
975228110Sjkim    UINT32                  GlobalIrqBase;
976284460Sjkim    UINT8                   Version;
977284460Sjkim    UINT8                   Reserved2[3];          /* Reserved - must be zero */
978228110Sjkim
979228110Sjkim} ACPI_MADT_GENERIC_DISTRIBUTOR;
980228110Sjkim
981228110Sjkim
982281075Sdim/* 13: Generic MSI Frame (ACPI 5.1) */
983281075Sdim
984281075Sdimtypedef struct acpi_madt_generic_msi_frame
985281075Sdim{
986281075Sdim    ACPI_SUBTABLE_HEADER    Header;
987281075Sdim    UINT16                  Reserved;           /* Reserved - must be zero */
988281075Sdim    UINT32                  MsiFrameId;
989281075Sdim    UINT64                  BaseAddress;
990281075Sdim    UINT32                  Flags;
991281075Sdim    UINT16                  SpiCount;
992281075Sdim    UINT16                  SpiBase;
993281075Sdim
994281075Sdim} ACPI_MADT_GENERIC_MSI_FRAME;
995281075Sdim
996281075Sdim/* Masks for Flags field above */
997281075Sdim
998281075Sdim#define ACPI_MADT_OVERRIDE_SPI_VALUES   (1)
999281075Sdim
1000281075Sdim
1001281075Sdim/* 14: Generic Redistributor (ACPI 5.1) */
1002281075Sdim
1003281075Sdimtypedef struct acpi_madt_generic_redistributor
1004281075Sdim{
1005281075Sdim    ACPI_SUBTABLE_HEADER    Header;
1006281075Sdim    UINT16                  Reserved;           /* reserved - must be zero */
1007281075Sdim    UINT64                  BaseAddress;
1008281075Sdim    UINT32                  Length;
1009281075Sdim
1010281075Sdim} ACPI_MADT_GENERIC_REDISTRIBUTOR;
1011281075Sdim
1012281075Sdim
1013284460Sjkim/* 15: Generic Translator (ACPI 6.0) */
1014284460Sjkim
1015284460Sjkimtypedef struct acpi_madt_generic_translator
1016284460Sjkim{
1017284460Sjkim    ACPI_SUBTABLE_HEADER    Header;
1018284460Sjkim    UINT16                  Reserved;           /* reserved - must be zero */
1019284460Sjkim    UINT32                  TranslationId;
1020284460Sjkim    UINT64                  BaseAddress;
1021284460Sjkim    UINT32                  Reserved2;
1022284460Sjkim
1023284460Sjkim} ACPI_MADT_GENERIC_TRANSLATOR;
1024284460Sjkim
1025284460Sjkim
1026167802Sjkim/*
1027167802Sjkim * Common flags fields for MADT subtables
1028167802Sjkim */
1029167802Sjkim
1030281075Sdim/* MADT Local APIC flags */
1031167802Sjkim
1032167802Sjkim#define ACPI_MADT_ENABLED           (1)         /* 00: Processor is usable if set */
1033167802Sjkim
1034167802Sjkim/* MADT MPS INTI flags (IntiFlags) */
1035167802Sjkim
1036167802Sjkim#define ACPI_MADT_POLARITY_MASK     (3)         /* 00-01: Polarity of APIC I/O input signals */
1037167802Sjkim#define ACPI_MADT_TRIGGER_MASK      (3<<2)      /* 02-03: Trigger mode of APIC input signals */
1038167802Sjkim
1039167802Sjkim/* Values for MPS INTI flags */
1040167802Sjkim
1041167802Sjkim#define ACPI_MADT_POLARITY_CONFORMS       0
1042167802Sjkim#define ACPI_MADT_POLARITY_ACTIVE_HIGH    1
1043167802Sjkim#define ACPI_MADT_POLARITY_RESERVED       2
1044167802Sjkim#define ACPI_MADT_POLARITY_ACTIVE_LOW     3
1045167802Sjkim
1046167802Sjkim#define ACPI_MADT_TRIGGER_CONFORMS        (0)
1047167802Sjkim#define ACPI_MADT_TRIGGER_EDGE            (1<<2)
1048167802Sjkim#define ACPI_MADT_TRIGGER_RESERVED        (2<<2)
1049167802Sjkim#define ACPI_MADT_TRIGGER_LEVEL           (3<<2)
1050167802Sjkim
1051167802Sjkim
1052167802Sjkim/*******************************************************************************
1053167802Sjkim *
1054197104Sjkim * MSCT - Maximum System Characteristics Table (ACPI 4.0)
1055197104Sjkim *        Version 1
1056167802Sjkim *
1057167802Sjkim ******************************************************************************/
1058167802Sjkim
1059197104Sjkimtypedef struct acpi_table_msct
1060167802Sjkim{
1061167802Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1062197104Sjkim    UINT32                  ProximityOffset;    /* Location of proximity info struct(s) */
1063197104Sjkim    UINT32                  MaxProximityDomains;/* Max number of proximity domains */
1064197104Sjkim    UINT32                  MaxClockDomains;    /* Max number of clock domains */
1065197104Sjkim    UINT64                  MaxAddress;         /* Max physical address in system */
1066167802Sjkim
1067197104Sjkim} ACPI_TABLE_MSCT;
1068167802Sjkim
1069167802Sjkim
1070197104Sjkim/* Subtable - Maximum Proximity Domain Information. Version 1 */
1071167802Sjkim
1072197104Sjkimtypedef struct acpi_msct_proximity
1073167802Sjkim{
1074197104Sjkim    UINT8                   Revision;
1075197104Sjkim    UINT8                   Length;
1076197104Sjkim    UINT32                  RangeStart;         /* Start of domain range */
1077197104Sjkim    UINT32                  RangeEnd;           /* End of domain range */
1078197104Sjkim    UINT32                  ProcessorCapacity;
1079197104Sjkim    UINT64                  MemoryCapacity;     /* In bytes */
1080167802Sjkim
1081197104Sjkim} ACPI_MSCT_PROXIMITY;
1082167802Sjkim
1083167802Sjkim
1084167802Sjkim/*******************************************************************************
1085167802Sjkim *
1086284460Sjkim * NFIT - NVDIMM Interface Table (ACPI 6.0)
1087284460Sjkim *        Version 1
1088284460Sjkim *
1089284460Sjkim ******************************************************************************/
1090284460Sjkim
1091284460Sjkimtypedef struct acpi_table_nfit
1092284460Sjkim{
1093284460Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1094284460Sjkim    UINT32                  Reserved;           /* Reserved, must be zero */
1095284460Sjkim
1096284460Sjkim} ACPI_TABLE_NFIT;
1097284460Sjkim
1098284460Sjkim/* Subtable header for NFIT */
1099284460Sjkim
1100284460Sjkimtypedef struct acpi_nfit_header
1101284460Sjkim{
1102284460Sjkim    UINT16                   Type;
1103284460Sjkim    UINT16                   Length;
1104284460Sjkim
1105284460Sjkim} ACPI_NFIT_HEADER;
1106284460Sjkim
1107284460Sjkim
1108284460Sjkim/* Values for subtable type in ACPI_NFIT_HEADER */
1109284460Sjkim
1110284460Sjkimenum AcpiNfitType
1111284460Sjkim{
1112284460Sjkim    ACPI_NFIT_TYPE_SYSTEM_ADDRESS       = 0,
1113284460Sjkim    ACPI_NFIT_TYPE_MEMORY_MAP           = 1,
1114284460Sjkim    ACPI_NFIT_TYPE_INTERLEAVE           = 2,
1115284460Sjkim    ACPI_NFIT_TYPE_SMBIOS               = 3,
1116284460Sjkim    ACPI_NFIT_TYPE_CONTROL_REGION       = 4,
1117284460Sjkim    ACPI_NFIT_TYPE_DATA_REGION          = 5,
1118284460Sjkim    ACPI_NFIT_TYPE_FLUSH_ADDRESS        = 6,
1119284460Sjkim    ACPI_NFIT_TYPE_RESERVED             = 7     /* 7 and greater are reserved */
1120284460Sjkim};
1121284460Sjkim
1122284460Sjkim/*
1123284460Sjkim * NFIT Subtables
1124284460Sjkim */
1125284460Sjkim
1126284460Sjkim/* 0: System Physical Address Range Structure */
1127284460Sjkim
1128284460Sjkimtypedef struct acpi_nfit_system_address
1129284460Sjkim{
1130284460Sjkim    ACPI_NFIT_HEADER        Header;
1131284460Sjkim    UINT16                  RangeIndex;
1132284460Sjkim    UINT16                  Flags;
1133284460Sjkim    UINT32                  Reserved;           /* Reseved, must be zero */
1134284460Sjkim    UINT32                  ProximityDomain;
1135284460Sjkim    UINT8                   RangeGuid[16];
1136284460Sjkim    UINT64                  Address;
1137284460Sjkim    UINT64                  Length;
1138284460Sjkim    UINT64                  MemoryMapping;
1139284460Sjkim
1140284460Sjkim} ACPI_NFIT_SYSTEM_ADDRESS;
1141284460Sjkim
1142284460Sjkim/* Flags */
1143284460Sjkim
1144284460Sjkim#define ACPI_NFIT_ADD_ONLINE_ONLY       (1)     /* 00: Add/Online Operation Only */
1145284460Sjkim#define ACPI_NFIT_PROXIMITY_VALID       (1<<1)  /* 01: Proximity Domain Valid */
1146284460Sjkim
1147284460Sjkim/* Range Type GUIDs appear in the include/acuuid.h file */
1148284460Sjkim
1149284460Sjkim
1150284460Sjkim/* 1: Memory Device to System Address Range Map Structure */
1151284460Sjkim
1152284460Sjkimtypedef struct acpi_nfit_memory_map
1153284460Sjkim{
1154284460Sjkim    ACPI_NFIT_HEADER        Header;
1155284460Sjkim    UINT32                  DeviceHandle;
1156284460Sjkim    UINT16                  PhysicalId;
1157284460Sjkim    UINT16                  RegionId;
1158284460Sjkim    UINT16                  RangeIndex;
1159284460Sjkim    UINT16                  RegionIndex;
1160284460Sjkim    UINT64                  RegionSize;
1161284460Sjkim    UINT64                  RegionOffset;
1162284460Sjkim    UINT64                  Address;
1163284460Sjkim    UINT16                  InterleaveIndex;
1164284460Sjkim    UINT16                  InterleaveWays;
1165284460Sjkim    UINT16                  Flags;
1166284460Sjkim    UINT16                  Reserved;           /* Reserved, must be zero */
1167284460Sjkim
1168284460Sjkim} ACPI_NFIT_MEMORY_MAP;
1169284460Sjkim
1170284460Sjkim/* Flags */
1171284460Sjkim
1172284460Sjkim#define ACPI_NFIT_MEM_SAVE_FAILED       (1)     /* 00: Last SAVE to Memory Device failed */
1173284460Sjkim#define ACPI_NFIT_MEM_RESTORE_FAILED    (1<<1)  /* 01: Last RESTORE from Memory Device failed */
1174284460Sjkim#define ACPI_NFIT_MEM_FLUSH_FAILED      (1<<2)  /* 02: Platform flush failed */
1175284460Sjkim#define ACPI_NFIT_MEM_ARMED             (1<<3)  /* 03: Memory Device observed to be not armed */
1176284460Sjkim#define ACPI_NFIT_MEM_HEALTH_OBSERVED   (1<<4)  /* 04: Memory Device observed SMART/health events */
1177284460Sjkim#define ACPI_NFIT_MEM_HEALTH_ENABLED    (1<<5)  /* 05: SMART/health events enabled */
1178284460Sjkim
1179284460Sjkim
1180284460Sjkim/* 2: Interleave Structure */
1181284460Sjkim
1182284460Sjkimtypedef struct acpi_nfit_interleave
1183284460Sjkim{
1184284460Sjkim    ACPI_NFIT_HEADER        Header;
1185284460Sjkim    UINT16                  InterleaveIndex;
1186284460Sjkim    UINT16                  Reserved;           /* Reserved, must be zero */
1187284460Sjkim    UINT32                  LineCount;
1188284460Sjkim    UINT32                  LineSize;
1189284460Sjkim    UINT32                  LineOffset[1];      /* Variable length */
1190284460Sjkim
1191284460Sjkim} ACPI_NFIT_INTERLEAVE;
1192284460Sjkim
1193284460Sjkim
1194284460Sjkim/* 3: SMBIOS Management Information Structure */
1195284460Sjkim
1196284460Sjkimtypedef struct acpi_nfit_smbios
1197284460Sjkim{
1198284460Sjkim    ACPI_NFIT_HEADER        Header;
1199284460Sjkim    UINT32                  Reserved;           /* Reserved, must be zero */
1200284460Sjkim    UINT8                   Data[1];            /* Variable length */
1201284460Sjkim
1202284460Sjkim} ACPI_NFIT_SMBIOS;
1203284460Sjkim
1204284460Sjkim
1205284460Sjkim/* 4: NVDIMM Control Region Structure */
1206284460Sjkim
1207284460Sjkimtypedef struct acpi_nfit_control_region
1208284460Sjkim{
1209284460Sjkim    ACPI_NFIT_HEADER        Header;
1210284460Sjkim    UINT16                  RegionIndex;
1211284460Sjkim    UINT16                  VendorId;
1212284460Sjkim    UINT16                  DeviceId;
1213284460Sjkim    UINT16                  RevisionId;
1214284460Sjkim    UINT16                  SubsystemVendorId;
1215284460Sjkim    UINT16                  SubsystemDeviceId;
1216284460Sjkim    UINT16                  SubsystemRevisionId;
1217284460Sjkim    UINT8                   Reserved[6];        /* Reserved, must be zero */
1218284460Sjkim    UINT32                  SerialNumber;
1219284460Sjkim    UINT16                  Code;
1220284460Sjkim    UINT16                  Windows;
1221284460Sjkim    UINT64                  WindowSize;
1222284460Sjkim    UINT64                  CommandOffset;
1223284460Sjkim    UINT64                  CommandSize;
1224284460Sjkim    UINT64                  StatusOffset;
1225284460Sjkim    UINT64                  StatusSize;
1226284460Sjkim    UINT16                  Flags;
1227284460Sjkim    UINT8                   Reserved1[6];       /* Reserved, must be zero */
1228284460Sjkim
1229284460Sjkim} ACPI_NFIT_CONTROL_REGION;
1230284460Sjkim
1231284460Sjkim/* Flags */
1232284460Sjkim
1233284460Sjkim#define ACPI_NFIT_CONTROL_BUFFERED      (1)     /* Block Data Windows implementation is buffered */
1234284460Sjkim
1235284460Sjkim
1236284460Sjkim/* 5: NVDIMM Block Data Window Region Structure */
1237284460Sjkim
1238284460Sjkimtypedef struct acpi_nfit_data_region
1239284460Sjkim{
1240284460Sjkim    ACPI_NFIT_HEADER        Header;
1241284460Sjkim    UINT16                  RegionIndex;
1242284460Sjkim    UINT16                  Windows;
1243284460Sjkim    UINT64                  Offset;
1244284460Sjkim    UINT64                  Size;
1245284460Sjkim    UINT64                  Capacity;
1246284460Sjkim    UINT64                  StartAddress;
1247284460Sjkim
1248284460Sjkim} ACPI_NFIT_DATA_REGION;
1249284460Sjkim
1250284460Sjkim
1251284460Sjkim/* 6: Flush Hint Address Structure */
1252284460Sjkim
1253284460Sjkimtypedef struct acpi_nfit_flush_address
1254284460Sjkim{
1255284460Sjkim    ACPI_NFIT_HEADER        Header;
1256284460Sjkim    UINT32                  DeviceHandle;
1257284460Sjkim    UINT16                  HintCount;
1258284460Sjkim    UINT8                   Reserved[6];        /* Reserved, must be zero */
1259284460Sjkim    UINT64                  HintAddress[1];     /* Variable length */
1260284460Sjkim
1261284460Sjkim} ACPI_NFIT_FLUSH_ADDRESS;
1262284460Sjkim
1263284460Sjkim
1264284460Sjkim/*******************************************************************************
1265284460Sjkim *
1266167802Sjkim * SBST - Smart Battery Specification Table
1267197104Sjkim *        Version 1
1268167802Sjkim *
1269167802Sjkim ******************************************************************************/
1270167802Sjkim
1271167802Sjkimtypedef struct acpi_table_sbst
1272167802Sjkim{
1273167802Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1274167802Sjkim    UINT32                  WarningLevel;
1275167802Sjkim    UINT32                  LowLevel;
1276167802Sjkim    UINT32                  CriticalLevel;
1277167802Sjkim
1278167802Sjkim} ACPI_TABLE_SBST;
1279167802Sjkim
1280167802Sjkim
1281167802Sjkim/*******************************************************************************
1282167802Sjkim *
1283167802Sjkim * SLIT - System Locality Distance Information Table
1284197104Sjkim *        Version 1
1285167802Sjkim *
1286167802Sjkim ******************************************************************************/
1287167802Sjkim
1288167802Sjkimtypedef struct acpi_table_slit
1289167802Sjkim{
1290167802Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1291167802Sjkim    UINT64                  LocalityCount;
1292167802Sjkim    UINT8                   Entry[1];           /* Real size = localities^2 */
1293167802Sjkim
1294167802Sjkim} ACPI_TABLE_SLIT;
1295167802Sjkim
1296167802Sjkim
1297167802Sjkim/*******************************************************************************
1298167802Sjkim *
1299167802Sjkim * SRAT - System Resource Affinity Table
1300197104Sjkim *        Version 3
1301167802Sjkim *
1302167802Sjkim ******************************************************************************/
1303167802Sjkim
1304167802Sjkimtypedef struct acpi_table_srat
1305167802Sjkim{
1306167802Sjkim    ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1307167802Sjkim    UINT32                  TableRevision;      /* Must be value '1' */
1308167802Sjkim    UINT64                  Reserved;           /* Reserved, must be zero */
1309167802Sjkim
1310167802Sjkim} ACPI_TABLE_SRAT;
1311167802Sjkim
1312167802Sjkim/* Values for subtable type in ACPI_SUBTABLE_HEADER */
1313167802Sjkim
1314167802Sjkimenum AcpiSratType
1315167802Sjkim{
1316193267Sjkim    ACPI_SRAT_TYPE_CPU_AFFINITY         = 0,
1317193267Sjkim    ACPI_SRAT_TYPE_MEMORY_AFFINITY      = 1,
1318193267Sjkim    ACPI_SRAT_TYPE_X2APIC_CPU_AFFINITY  = 2,
1319281075Sdim    ACPI_SRAT_TYPE_GICC_AFFINITY        = 3,
1320281075Sdim    ACPI_SRAT_TYPE_RESERVED             = 4     /* 4 and greater are reserved */
1321167802Sjkim};
1322167802Sjkim
1323193267Sjkim/*
1324281075Sdim * SRAT Subtables, correspond to Type in ACPI_SUBTABLE_HEADER
1325193267Sjkim */
1326167802Sjkim
1327193267Sjkim/* 0: Processor Local APIC/SAPIC Affinity */
1328193267Sjkim
1329167802Sjkimtypedef struct acpi_srat_cpu_affinity
1330167802Sjkim{
1331167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
1332167802Sjkim    UINT8                   ProximityDomainLo;
1333167802Sjkim    UINT8                   ApicId;
1334167802Sjkim    UINT32                  Flags;
1335167802Sjkim    UINT8                   LocalSapicEid;
1336167802Sjkim    UINT8                   ProximityDomainHi[3];
1337281075Sdim    UINT32                  ClockDomain;
1338167802Sjkim
1339167802Sjkim} ACPI_SRAT_CPU_AFFINITY;
1340167802Sjkim
1341197104Sjkim/* Flags */
1342197104Sjkim
1343197104Sjkim#define ACPI_SRAT_CPU_USE_AFFINITY  (1)         /* 00: Use affinity structure */
1344197104Sjkim
1345197104Sjkim
1346193267Sjkim/* 1: Memory Affinity */
1347167802Sjkim
1348167802Sjkimtypedef struct acpi_srat_mem_affinity
1349167802Sjkim{
1350167802Sjkim    ACPI_SUBTABLE_HEADER    Header;
1351167802Sjkim    UINT32                  ProximityDomain;
1352167802Sjkim    UINT16                  Reserved;           /* Reserved, must be zero */
1353167802Sjkim    UINT64                  BaseAddress;
1354167802Sjkim    UINT64                  Length;
1355193267Sjkim    UINT32                  Reserved1;
1356167802Sjkim    UINT32                  Flags;
1357193267Sjkim    UINT64                  Reserved2;          /* Reserved, must be zero */
1358167802Sjkim
1359167802Sjkim} ACPI_SRAT_MEM_AFFINITY;
1360167802Sjkim
1361167802Sjkim/* Flags */
1362167802Sjkim
1363167802Sjkim#define ACPI_SRAT_MEM_ENABLED       (1)         /* 00: Use affinity structure */
1364167802Sjkim#define ACPI_SRAT_MEM_HOT_PLUGGABLE (1<<1)      /* 01: Memory region is hot pluggable */
1365167802Sjkim#define ACPI_SRAT_MEM_NON_VOLATILE  (1<<2)      /* 02: Memory region is non-volatile */
1366167802Sjkim
1367167802Sjkim
1368197104Sjkim/* 2: Processor Local X2_APIC Affinity (ACPI 4.0) */
1369197104Sjkim
1370193267Sjkimtypedef struct acpi_srat_x2apic_cpu_affinity
1371167802Sjkim{
1372193267Sjkim    ACPI_SUBTABLE_HEADER    Header;
1373193267Sjkim    UINT16                  Reserved;           /* Reserved, must be zero */
1374193267Sjkim    UINT32                  ProximityDomain;
1375193267Sjkim    UINT32                  ApicId;
1376193267Sjkim    UINT32                  Flags;
1377197104Sjkim    UINT32                  ClockDomain;
1378197104Sjkim    UINT32                  Reserved2;
1379167802Sjkim
1380193267Sjkim} ACPI_SRAT_X2APIC_CPU_AFFINITY;
1381167802Sjkim
1382193267Sjkim/* Flags for ACPI_SRAT_CPU_AFFINITY and ACPI_SRAT_X2APIC_CPU_AFFINITY */
1383193267Sjkim
1384193267Sjkim#define ACPI_SRAT_CPU_ENABLED       (1)         /* 00: Use affinity structure */
1385193267Sjkim
1386193267Sjkim
1387281075Sdim/* 3: GICC Affinity (ACPI 5.1) */
1388281075Sdim
1389281075Sdimtypedef struct acpi_srat_gicc_affinity
1390281075Sdim{
1391281075Sdim    ACPI_SUBTABLE_HEADER    Header;
1392281075Sdim    UINT32                  ProximityDomain;
1393281075Sdim    UINT32                  AcpiProcessorUid;
1394281075Sdim    UINT32                  Flags;
1395281075Sdim    UINT32                  ClockDomain;
1396281075Sdim
1397281075Sdim} ACPI_SRAT_GICC_AFFINITY;
1398281075Sdim
1399281075Sdim/* Flags for ACPI_SRAT_GICC_AFFINITY */
1400281075Sdim
1401281075Sdim#define ACPI_SRAT_GICC_ENABLED     (1)         /* 00: Use affinity structure */
1402281075Sdim
1403284460Sjkim
1404167802Sjkim/* Reset to default packing */
1405167802Sjkim
140669450Smsmith#pragma pack()
140769450Smsmith
140869450Smsmith#endif /* __ACTBL1_H__ */
1409