1 /******************************************************************************
2  *
3  * Name: actbl2.h - ACPI Table Definitions (tables not in ACPI spec)
4  *
5  *****************************************************************************/
6 
7 /*
8  * Copyright (C) 2000 - 2014, Intel Corp.
9  * All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  * 1. Redistributions of source code must retain the above copyright
15  *    notice, this list of conditions, and the following disclaimer,
16  *    without modification.
17  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18  *    substantially similar to the "NO WARRANTY" disclaimer below
19  *    ("Disclaimer") and any redistribution must be conditioned upon
20  *    including a substantially similar Disclaimer requirement for further
21  *    binary redistribution.
22  * 3. Neither the names of the above-listed copyright holders nor the names
23  *    of any contributors may be used to endorse or promote products derived
24  *    from this software without specific prior written permission.
25  *
26  * Alternatively, this software may be distributed under the terms of the
27  * GNU General Public License ("GPL") version 2 as published by the Free
28  * Software Foundation.
29  *
30  * NO WARRANTY
31  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41  * POSSIBILITY OF SUCH DAMAGES.
42  */
43 
44 #ifndef __ACTBL2_H__
45 #define __ACTBL2_H__
46 
47 
48 /*******************************************************************************
49  *
50  * Additional ACPI Tables (2)
51  *
52  * These tables are not consumed directly by the ACPICA subsystem, but are
53  * included here to support device drivers and the AML disassembler.
54  *
55  * The tables in this file are defined by third-party specifications, and are
56  * not defined directly by the ACPI specification itself.
57  *
58  ******************************************************************************/
59 
60 
61 /*
62  * Values for description table header signatures for tables defined in this
63  * file. Useful because they make it more difficult to inadvertently type in
64  * the wrong signature.
65  */
66 #define ACPI_SIG_ASF            "ASF!"      /* Alert Standard Format table */
67 #define ACPI_SIG_BOOT           "BOOT"      /* Simple Boot Flag Table */
68 #define ACPI_SIG_CSRT           "CSRT"      /* Core System Resource Table */
69 #define ACPI_SIG_DBG2           "DBG2"      /* Debug Port table type 2 */
70 #define ACPI_SIG_DBGP           "DBGP"      /* Debug Port table */
71 #define ACPI_SIG_DMAR           "DMAR"      /* DMA Remapping table */
72 #define ACPI_SIG_HPET           "HPET"      /* High Precision Event Timer table */
73 #define ACPI_SIG_IBFT           "IBFT"      /* iSCSI Boot Firmware Table */
74 #define ACPI_SIG_IVRS           "IVRS"      /* I/O Virtualization Reporting Structure */
75 #define ACPI_SIG_MCFG           "MCFG"      /* PCI Memory Mapped Configuration table */
76 #define ACPI_SIG_MCHI           "MCHI"      /* Management Controller Host Interface table */
77 #define ACPI_SIG_MTMR           "MTMR"      /* MID Timer table */
78 #define ACPI_SIG_SLIC           "SLIC"      /* Software Licensing Description Table */
79 #define ACPI_SIG_SPCR           "SPCR"      /* Serial Port Console Redirection table */
80 #define ACPI_SIG_SPMI           "SPMI"      /* Server Platform Management Interface table */
81 #define ACPI_SIG_TCPA           "TCPA"      /* Trusted Computing Platform Alliance table */
82 #define ACPI_SIG_UEFI           "UEFI"      /* Uefi Boot Optimization Table */
83 #define ACPI_SIG_VRTC           "VRTC"      /* Virtual Real Time Clock Table */
84 #define ACPI_SIG_WAET           "WAET"      /* Windows ACPI Emulated devices Table */
85 #define ACPI_SIG_WDAT           "WDAT"      /* Watchdog Action Table */
86 #define ACPI_SIG_WDDT           "WDDT"      /* Watchdog Timer Description Table */
87 #define ACPI_SIG_WDRT           "WDRT"      /* Watchdog Resource Table */
88 
89 #ifdef ACPI_UNDEFINED_TABLES
90 /*
91  * These tables have been seen in the field, but no definition has been found
92  */
93 #define ACPI_SIG_ATKG           "ATKG"
94 #define ACPI_SIG_GSCI           "GSCI"      /* GMCH SCI table */
95 #define ACPI_SIG_IEIT           "IEIT"
96 #endif
97 
98 /*
99  * All tables must be byte-packed to match the ACPI specification, since
100  * the tables are provided by the system BIOS.
101  */
102 #pragma pack(1)
103 
104 /*
105  * Note: C bitfields are not used for this reason:
106  *
107  * "Bitfields are great and easy to read, but unfortunately the C language
108  * does not specify the layout of bitfields in memory, which means they are
109  * essentially useless for dealing with packed data in on-disk formats or
110  * binary wire protocols." (Or ACPI tables and buffers.) "If you ask me,
111  * this decision was a design error in C. Ritchie could have picked an order
112  * and stuck with it." Norman Ramsey.
113  * See http://stackoverflow.com/a/1053662/41661
114  */
115 
116 
117 /*******************************************************************************
118  *
119  * ASF - Alert Standard Format table (Signature "ASF!")
120  *       Revision 0x10
121  *
122  * Conforms to the Alert Standard Format Specification V2.0, 23 April 2003
123  *
124  ******************************************************************************/
125 
126 typedef struct acpi_table_asf
127 {
128     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
129 
130 } ACPI_TABLE_ASF;
131 
132 
133 /* ASF subtable header */
134 
135 typedef struct acpi_asf_header
136 {
137     UINT8                   Type;
138     UINT8                   Reserved;
139     UINT16                  Length;
140 
141 } ACPI_ASF_HEADER;
142 
143 
144 /* Values for Type field above */
145 
146 enum AcpiAsfType
147 {
148     ACPI_ASF_TYPE_INFO          = 0,
149     ACPI_ASF_TYPE_ALERT         = 1,
150     ACPI_ASF_TYPE_CONTROL       = 2,
151     ACPI_ASF_TYPE_BOOT          = 3,
152     ACPI_ASF_TYPE_ADDRESS       = 4,
153     ACPI_ASF_TYPE_RESERVED      = 5
154 };
155 
156 /*
157  * ASF subtables
158  */
159 
160 /* 0: ASF Information */
161 
162 typedef struct acpi_asf_info
163 {
164     ACPI_ASF_HEADER         Header;
165     UINT8                   MinResetValue;
166     UINT8                   MinPollInterval;
167     UINT16                  SystemId;
168     UINT32                  MfgId;
169     UINT8                   Flags;
170     UINT8                   Reserved2[3];
171 
172 } ACPI_ASF_INFO;
173 
174 /* Masks for Flags field above */
175 
176 #define ACPI_ASF_SMBUS_PROTOCOLS    (1)
177 
178 
179 /* 1: ASF Alerts */
180 
181 typedef struct acpi_asf_alert
182 {
183     ACPI_ASF_HEADER         Header;
184     UINT8                   AssertMask;
185     UINT8                   DeassertMask;
186     UINT8                   Alerts;
187     UINT8                   DataLength;
188 
189 } ACPI_ASF_ALERT;
190 
191 typedef struct acpi_asf_alert_data
192 {
193     UINT8                   Address;
194     UINT8                   Command;
195     UINT8                   Mask;
196     UINT8                   Value;
197     UINT8                   SensorType;
198     UINT8                   Type;
199     UINT8                   Offset;
200     UINT8                   SourceType;
201     UINT8                   Severity;
202     UINT8                   SensorNumber;
203     UINT8                   Entity;
204     UINT8                   Instance;
205 
206 } ACPI_ASF_ALERT_DATA;
207 
208 
209 /* 2: ASF Remote Control */
210 
211 typedef struct acpi_asf_remote
212 {
213     ACPI_ASF_HEADER         Header;
214     UINT8                   Controls;
215     UINT8                   DataLength;
216     UINT16                  Reserved2;
217 
218 } ACPI_ASF_REMOTE;
219 
220 typedef struct acpi_asf_control_data
221 {
222     UINT8                   Function;
223     UINT8                   Address;
224     UINT8                   Command;
225     UINT8                   Value;
226 
227 } ACPI_ASF_CONTROL_DATA;
228 
229 
230 /* 3: ASF RMCP Boot Options */
231 
232 typedef struct acpi_asf_rmcp
233 {
234     ACPI_ASF_HEADER         Header;
235     UINT8                   Capabilities[7];
236     UINT8                   CompletionCode;
237     UINT32                  EnterpriseId;
238     UINT8                   Command;
239     UINT16                  Parameter;
240     UINT16                  BootOptions;
241     UINT16                  OemParameters;
242 
243 } ACPI_ASF_RMCP;
244 
245 
246 /* 4: ASF Address */
247 
248 typedef struct acpi_asf_address
249 {
250     ACPI_ASF_HEADER         Header;
251     UINT8                   EpromAddress;
252     UINT8                   Devices;
253 
254 } ACPI_ASF_ADDRESS;
255 
256 
257 /*******************************************************************************
258  *
259  * BOOT - Simple Boot Flag Table
260  *        Version 1
261  *
262  * Conforms to the "Simple Boot Flag Specification", Version 2.1
263  *
264  ******************************************************************************/
265 
266 typedef struct acpi_table_boot
267 {
268     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
269     UINT8                   CmosIndex;          /* Index in CMOS RAM for the boot register */
270     UINT8                   Reserved[3];
271 
272 } ACPI_TABLE_BOOT;
273 
274 
275 /*******************************************************************************
276  *
277  * CSRT - Core System Resource Table
278  *        Version 0
279  *
280  * Conforms to the "Core System Resource Table (CSRT)", November 14, 2011
281  *
282  ******************************************************************************/
283 
284 typedef struct acpi_table_csrt
285 {
286     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
287 
288 } ACPI_TABLE_CSRT;
289 
290 
291 /* Resource Group subtable */
292 
293 typedef struct acpi_csrt_group
294 {
295     UINT32                  Length;
296     UINT32                  VendorId;
297     UINT32                  SubvendorId;
298     UINT16                  DeviceId;
299     UINT16                  SubdeviceId;
300     UINT16                  Revision;
301     UINT16                  Reserved;
302     UINT32                  SharedInfoLength;
303 
304     /* Shared data immediately follows (Length = SharedInfoLength) */
305 
306 } ACPI_CSRT_GROUP;
307 
308 /* Shared Info subtable */
309 
310 typedef struct acpi_csrt_shared_info
311 {
312     UINT16                  MajorVersion;
313     UINT16                  MinorVersion;
314     UINT32                  MmioBaseLow;
315     UINT32                  MmioBaseHigh;
316     UINT32                  GsiInterrupt;
317     UINT8                   InterruptPolarity;
318     UINT8                   InterruptMode;
319     UINT8                   NumChannels;
320     UINT8                   DmaAddressWidth;
321     UINT16                  BaseRequestLine;
322     UINT16                  NumHandshakeSignals;
323     UINT32                  MaxBlockSize;
324 
325     /* Resource descriptors immediately follow (Length = Group Length - SharedInfoLength) */
326 
327 } ACPI_CSRT_SHARED_INFO;
328 
329 /* Resource Descriptor subtable */
330 
331 typedef struct acpi_csrt_descriptor
332 {
333     UINT32                  Length;
334     UINT16                  Type;
335     UINT16                  Subtype;
336     UINT32                  Uid;
337 
338     /* Resource-specific information immediately follows */
339 
340 } ACPI_CSRT_DESCRIPTOR;
341 
342 
343 /* Resource Types */
344 
345 #define ACPI_CSRT_TYPE_INTERRUPT    0x0001
346 #define ACPI_CSRT_TYPE_TIMER        0x0002
347 #define ACPI_CSRT_TYPE_DMA          0x0003
348 
349 /* Resource Subtypes */
350 
351 #define ACPI_CSRT_XRUPT_LINE        0x0000
352 #define ACPI_CSRT_XRUPT_CONTROLLER  0x0001
353 #define ACPI_CSRT_TIMER             0x0000
354 #define ACPI_CSRT_DMA_CHANNEL       0x0000
355 #define ACPI_CSRT_DMA_CONTROLLER    0x0001
356 
357 
358 /*******************************************************************************
359  *
360  * DBG2 - Debug Port Table 2
361  *        Version 0 (Both main table and subtables)
362  *
363  * Conforms to "Microsoft Debug Port Table 2 (DBG2)", May 22 2012.
364  *
365  ******************************************************************************/
366 
367 typedef struct acpi_table_dbg2
368 {
369     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
370     UINT32                  InfoOffset;
371     UINT32                  InfoCount;
372 
373 } ACPI_TABLE_DBG2;
374 
375 
376 typedef struct acpi_dbg2_header
377 {
378     UINT32                  InfoOffset;
379     UINT32                  InfoCount;
380 
381 } ACPI_DBG2_HEADER;
382 
383 
384 /* Debug Device Information Subtable */
385 
386 typedef struct acpi_dbg2_device
387 {
388     UINT8                   Revision;
389     UINT16                  Length;
390     UINT8                   RegisterCount;      /* Number of BaseAddress registers */
391     UINT16                  NamepathLength;
392     UINT16                  NamepathOffset;
393     UINT16                  OemDataLength;
394     UINT16                  OemDataOffset;
395     UINT16                  PortType;
396     UINT16                  PortSubtype;
397     UINT16                  Reserved;
398     UINT16                  BaseAddressOffset;
399     UINT16                  AddressSizeOffset;
400     /*
401      * Data that follows:
402      *    BaseAddress (required) - Each in 12-byte Generic Address Structure format.
403      *    AddressSize (required) - Array of UINT32 sizes corresponding to each BaseAddress register.
404      *    Namepath    (required) - Null terminated string. Single dot if not supported.
405      *    OemData     (optional) - Length is OemDataLength.
406      */
407 } ACPI_DBG2_DEVICE;
408 
409 /* Types for PortType field above */
410 
411 #define ACPI_DBG2_SERIAL_PORT       0x8000
412 #define ACPI_DBG2_1394_PORT         0x8001
413 #define ACPI_DBG2_USB_PORT          0x8002
414 #define ACPI_DBG2_NET_PORT          0x8003
415 
416 /* Subtypes for PortSubtype field above */
417 
418 #define ACPI_DBG2_16550_COMPATIBLE  0x0000
419 #define ACPI_DBG2_16550_SUBSET      0x0001
420 
421 #define ACPI_DBG2_1394_STANDARD     0x0000
422 
423 #define ACPI_DBG2_USB_XHCI          0x0000
424 #define ACPI_DBG2_USB_EHCI          0x0001
425 
426 
427 /*******************************************************************************
428  *
429  * DBGP - Debug Port table
430  *        Version 1
431  *
432  * Conforms to the "Debug Port Specification", Version 1.00, 2/9/2000
433  *
434  ******************************************************************************/
435 
436 typedef struct acpi_table_dbgp
437 {
438     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
439     UINT8                   Type;               /* 0=full 16550, 1=subset of 16550 */
440     UINT8                   Reserved[3];
441     ACPI_GENERIC_ADDRESS    DebugPort;
442 
443 } ACPI_TABLE_DBGP;
444 
445 
446 /*******************************************************************************
447  *
448  * DMAR - DMA Remapping table
449  *        Version 1
450  *
451  * Conforms to "Intel Virtualization Technology for Directed I/O",
452  * Version 1.2, Sept. 2008
453  *
454  ******************************************************************************/
455 
456 typedef struct acpi_table_dmar
457 {
458     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
459     UINT8                   Width;              /* Host Address Width */
460     UINT8                   Flags;
461     UINT8                   Reserved[10];
462 
463 } ACPI_TABLE_DMAR;
464 
465 /* Masks for Flags field above */
466 
467 #define ACPI_DMAR_INTR_REMAP        (1)
468 
469 
470 /* DMAR subtable header */
471 
472 typedef struct acpi_dmar_header
473 {
474     UINT16                  Type;
475     UINT16                  Length;
476 
477 } ACPI_DMAR_HEADER;
478 
479 /* Values for subtable type in ACPI_DMAR_HEADER */
480 
481 enum AcpiDmarType
482 {
483     ACPI_DMAR_TYPE_HARDWARE_UNIT        = 0,
484     ACPI_DMAR_TYPE_RESERVED_MEMORY      = 1,
485     ACPI_DMAR_TYPE_ATSR                 = 2,
486     ACPI_DMAR_HARDWARE_AFFINITY         = 3,
487     ACPI_DMAR_TYPE_RESERVED             = 4     /* 4 and greater are reserved */
488 };
489 
490 
491 /* DMAR Device Scope structure */
492 
493 typedef struct acpi_dmar_device_scope
494 {
495     UINT8                   EntryType;
496     UINT8                   Length;
497     UINT16                  Reserved;
498     UINT8                   EnumerationId;
499     UINT8                   Bus;
500 
501 } ACPI_DMAR_DEVICE_SCOPE;
502 
503 /* Values for EntryType in ACPI_DMAR_DEVICE_SCOPE */
504 
505 enum AcpiDmarScopeType
506 {
507     ACPI_DMAR_SCOPE_TYPE_NOT_USED       = 0,
508     ACPI_DMAR_SCOPE_TYPE_ENDPOINT       = 1,
509     ACPI_DMAR_SCOPE_TYPE_BRIDGE         = 2,
510     ACPI_DMAR_SCOPE_TYPE_IOAPIC         = 3,
511     ACPI_DMAR_SCOPE_TYPE_HPET           = 4,
512     ACPI_DMAR_SCOPE_TYPE_RESERVED       = 5     /* 5 and greater are reserved */
513 };
514 
515 typedef struct acpi_dmar_pci_path
516 {
517     UINT8                   Device;
518     UINT8                   Function;
519 
520 } ACPI_DMAR_PCI_PATH;
521 
522 
523 /*
524  * DMAR Sub-tables, correspond to Type in ACPI_DMAR_HEADER
525  */
526 
527 /* 0: Hardware Unit Definition */
528 
529 typedef struct acpi_dmar_hardware_unit
530 {
531     ACPI_DMAR_HEADER        Header;
532     UINT8                   Flags;
533     UINT8                   Reserved;
534     UINT16                  Segment;
535     UINT64                  Address;            /* Register Base Address */
536 
537 } ACPI_DMAR_HARDWARE_UNIT;
538 
539 /* Masks for Flags field above */
540 
541 #define ACPI_DMAR_INCLUDE_ALL       (1)
542 
543 
544 /* 1: Reserved Memory Defininition */
545 
546 typedef struct acpi_dmar_reserved_memory
547 {
548     ACPI_DMAR_HEADER        Header;
549     UINT16                  Reserved;
550     UINT16                  Segment;
551     UINT64                  BaseAddress;        /* 4K aligned base address */
552     UINT64                  EndAddress;         /* 4K aligned limit address */
553 
554 } ACPI_DMAR_RESERVED_MEMORY;
555 
556 /* Masks for Flags field above */
557 
558 #define ACPI_DMAR_ALLOW_ALL         (1)
559 
560 
561 /* 2: Root Port ATS Capability Reporting Structure */
562 
563 typedef struct acpi_dmar_atsr
564 {
565     ACPI_DMAR_HEADER        Header;
566     UINT8                   Flags;
567     UINT8                   Reserved;
568     UINT16                  Segment;
569 
570 } ACPI_DMAR_ATSR;
571 
572 /* Masks for Flags field above */
573 
574 #define ACPI_DMAR_ALL_PORTS         (1)
575 
576 
577 /* 3: Remapping Hardware Static Affinity Structure */
578 
579 typedef struct acpi_dmar_rhsa
580 {
581     ACPI_DMAR_HEADER        Header;
582     UINT32                  Reserved;
583     UINT64                  BaseAddress;
584     UINT32                  ProximityDomain;
585 
586 } ACPI_DMAR_RHSA;
587 
588 
589 /*******************************************************************************
590  *
591  * HPET - High Precision Event Timer table
592  *        Version 1
593  *
594  * Conforms to "IA-PC HPET (High Precision Event Timers) Specification",
595  * Version 1.0a, October 2004
596  *
597  ******************************************************************************/
598 
599 typedef struct acpi_table_hpet
600 {
601     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
602     UINT32                  Id;                 /* Hardware ID of event timer block */
603     ACPI_GENERIC_ADDRESS    Address;            /* Address of event timer block */
604     UINT8                   Sequence;           /* HPET sequence number */
605     UINT16                  MinimumTick;        /* Main counter min tick, periodic mode */
606     UINT8                   Flags;
607 
608 } ACPI_TABLE_HPET;
609 
610 /* Masks for Flags field above */
611 
612 #define ACPI_HPET_PAGE_PROTECT_MASK (3)
613 
614 /* Values for Page Protect flags */
615 
616 enum AcpiHpetPageProtect
617 {
618     ACPI_HPET_NO_PAGE_PROTECT       = 0,
619     ACPI_HPET_PAGE_PROTECT4         = 1,
620     ACPI_HPET_PAGE_PROTECT64        = 2
621 };
622 
623 
624 /*******************************************************************************
625  *
626  * IBFT - Boot Firmware Table
627  *        Version 1
628  *
629  * Conforms to "iSCSI Boot Firmware Table (iBFT) as Defined in ACPI 3.0b
630  * Specification", Version 1.01, March 1, 2007
631  *
632  * Note: It appears that this table is not intended to appear in the RSDT/XSDT.
633  * Therefore, it is not currently supported by the disassembler.
634  *
635  ******************************************************************************/
636 
637 typedef struct acpi_table_ibft
638 {
639     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
640     UINT8                   Reserved[12];
641 
642 } ACPI_TABLE_IBFT;
643 
644 
645 /* IBFT common subtable header */
646 
647 typedef struct acpi_ibft_header
648 {
649     UINT8                   Type;
650     UINT8                   Version;
651     UINT16                  Length;
652     UINT8                   Index;
653     UINT8                   Flags;
654 
655 } ACPI_IBFT_HEADER;
656 
657 /* Values for Type field above */
658 
659 enum AcpiIbftType
660 {
661     ACPI_IBFT_TYPE_NOT_USED         = 0,
662     ACPI_IBFT_TYPE_CONTROL          = 1,
663     ACPI_IBFT_TYPE_INITIATOR        = 2,
664     ACPI_IBFT_TYPE_NIC              = 3,
665     ACPI_IBFT_TYPE_TARGET           = 4,
666     ACPI_IBFT_TYPE_EXTENSIONS       = 5,
667     ACPI_IBFT_TYPE_RESERVED         = 6     /* 6 and greater are reserved */
668 };
669 
670 
671 /* IBFT subtables */
672 
673 typedef struct acpi_ibft_control
674 {
675     ACPI_IBFT_HEADER        Header;
676     UINT16                  Extensions;
677     UINT16                  InitiatorOffset;
678     UINT16                  Nic0Offset;
679     UINT16                  Target0Offset;
680     UINT16                  Nic1Offset;
681     UINT16                  Target1Offset;
682 
683 } ACPI_IBFT_CONTROL;
684 
685 typedef struct acpi_ibft_initiator
686 {
687     ACPI_IBFT_HEADER        Header;
688     UINT8                   SnsServer[16];
689     UINT8                   SlpServer[16];
690     UINT8                   PrimaryServer[16];
691     UINT8                   SecondaryServer[16];
692     UINT16                  NameLength;
693     UINT16                  NameOffset;
694 
695 } ACPI_IBFT_INITIATOR;
696 
697 typedef struct acpi_ibft_nic
698 {
699     ACPI_IBFT_HEADER        Header;
700     UINT8                   IpAddress[16];
701     UINT8                   SubnetMaskPrefix;
702     UINT8                   Origin;
703     UINT8                   Gateway[16];
704     UINT8                   PrimaryDns[16];
705     UINT8                   SecondaryDns[16];
706     UINT8                   Dhcp[16];
707     UINT16                  Vlan;
708     UINT8                   MacAddress[6];
709     UINT16                  PciAddress;
710     UINT16                  NameLength;
711     UINT16                  NameOffset;
712 
713 } ACPI_IBFT_NIC;
714 
715 typedef struct acpi_ibft_target
716 {
717     ACPI_IBFT_HEADER        Header;
718     UINT8                   TargetIpAddress[16];
719     UINT16                  TargetIpSocket;
720     UINT8                   TargetBootLun[8];
721     UINT8                   ChapType;
722     UINT8                   NicAssociation;
723     UINT16                  TargetNameLength;
724     UINT16                  TargetNameOffset;
725     UINT16                  ChapNameLength;
726     UINT16                  ChapNameOffset;
727     UINT16                  ChapSecretLength;
728     UINT16                  ChapSecretOffset;
729     UINT16                  ReverseChapNameLength;
730     UINT16                  ReverseChapNameOffset;
731     UINT16                  ReverseChapSecretLength;
732     UINT16                  ReverseChapSecretOffset;
733 
734 } ACPI_IBFT_TARGET;
735 
736 
737 /*******************************************************************************
738  *
739  * IVRS - I/O Virtualization Reporting Structure
740  *        Version 1
741  *
742  * Conforms to "AMD I/O Virtualization Technology (IOMMU) Specification",
743  * Revision 1.26, February 2009.
744  *
745  ******************************************************************************/
746 
747 typedef struct acpi_table_ivrs
748 {
749     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
750     UINT32                  Info;               /* Common virtualization info */
751     UINT64                  Reserved;
752 
753 } ACPI_TABLE_IVRS;
754 
755 /* Values for Info field above */
756 
757 #define ACPI_IVRS_PHYSICAL_SIZE     0x00007F00  /* 7 bits, physical address size */
758 #define ACPI_IVRS_VIRTUAL_SIZE      0x003F8000  /* 7 bits, virtual address size */
759 #define ACPI_IVRS_ATS_RESERVED      0x00400000  /* ATS address translation range reserved */
760 
761 
762 /* IVRS subtable header */
763 
764 typedef struct acpi_ivrs_header
765 {
766     UINT8                   Type;               /* Subtable type */
767     UINT8                   Flags;
768     UINT16                  Length;             /* Subtable length */
769     UINT16                  DeviceId;           /* ID of IOMMU */
770 
771 } ACPI_IVRS_HEADER;
772 
773 /* Values for subtable Type above */
774 
775 enum AcpiIvrsType
776 {
777     ACPI_IVRS_TYPE_HARDWARE         = 0x10,
778     ACPI_IVRS_TYPE_MEMORY1          = 0x20,
779     ACPI_IVRS_TYPE_MEMORY2          = 0x21,
780     ACPI_IVRS_TYPE_MEMORY3          = 0x22
781 };
782 
783 /* Masks for Flags field above for IVHD subtable */
784 
785 #define ACPI_IVHD_TT_ENABLE         (1)
786 #define ACPI_IVHD_PASS_PW           (1<<1)
787 #define ACPI_IVHD_RES_PASS_PW       (1<<2)
788 #define ACPI_IVHD_ISOC              (1<<3)
789 #define ACPI_IVHD_IOTLB             (1<<4)
790 
791 /* Masks for Flags field above for IVMD subtable */
792 
793 #define ACPI_IVMD_UNITY             (1)
794 #define ACPI_IVMD_READ              (1<<1)
795 #define ACPI_IVMD_WRITE             (1<<2)
796 #define ACPI_IVMD_EXCLUSION_RANGE   (1<<3)
797 
798 
799 /*
800  * IVRS subtables, correspond to Type in ACPI_IVRS_HEADER
801  */
802 
803 /* 0x10: I/O Virtualization Hardware Definition Block (IVHD) */
804 
805 typedef struct acpi_ivrs_hardware
806 {
807     ACPI_IVRS_HEADER        Header;
808     UINT16                  CapabilityOffset;   /* Offset for IOMMU control fields */
809     UINT64                  BaseAddress;        /* IOMMU control registers */
810     UINT16                  PciSegmentGroup;
811     UINT16                  Info;               /* MSI number and unit ID */
812     UINT32                  Reserved;
813 
814 } ACPI_IVRS_HARDWARE;
815 
816 /* Masks for Info field above */
817 
818 #define ACPI_IVHD_MSI_NUMBER_MASK   0x001F      /* 5 bits, MSI message number */
819 #define ACPI_IVHD_UNIT_ID_MASK      0x1F00      /* 5 bits, UnitID */
820 
821 
822 /*
823  * Device Entries for IVHD subtable, appear after ACPI_IVRS_HARDWARE structure.
824  * Upper two bits of the Type field are the (encoded) length of the structure.
825  * Currently, only 4 and 8 byte entries are defined. 16 and 32 byte entries
826  * are reserved for future use but not defined.
827  */
828 typedef struct acpi_ivrs_de_header
829 {
830     UINT8                   Type;
831     UINT16                  Id;
832     UINT8                   DataSetting;
833 
834 } ACPI_IVRS_DE_HEADER;
835 
836 /* Length of device entry is in the top two bits of Type field above */
837 
838 #define ACPI_IVHD_ENTRY_LENGTH      0xC0
839 
840 /* Values for device entry Type field above */
841 
842 enum AcpiIvrsDeviceEntryType
843 {
844     /* 4-byte device entries, all use ACPI_IVRS_DEVICE4 */
845 
846     ACPI_IVRS_TYPE_PAD4             = 0,
847     ACPI_IVRS_TYPE_ALL              = 1,
848     ACPI_IVRS_TYPE_SELECT           = 2,
849     ACPI_IVRS_TYPE_START            = 3,
850     ACPI_IVRS_TYPE_END              = 4,
851 
852     /* 8-byte device entries */
853 
854     ACPI_IVRS_TYPE_PAD8             = 64,
855     ACPI_IVRS_TYPE_NOT_USED         = 65,
856     ACPI_IVRS_TYPE_ALIAS_SELECT     = 66, /* Uses ACPI_IVRS_DEVICE8A */
857     ACPI_IVRS_TYPE_ALIAS_START      = 67, /* Uses ACPI_IVRS_DEVICE8A */
858     ACPI_IVRS_TYPE_EXT_SELECT       = 70, /* Uses ACPI_IVRS_DEVICE8B */
859     ACPI_IVRS_TYPE_EXT_START        = 71, /* Uses ACPI_IVRS_DEVICE8B */
860     ACPI_IVRS_TYPE_SPECIAL          = 72  /* Uses ACPI_IVRS_DEVICE8C */
861 };
862 
863 /* Values for Data field above */
864 
865 #define ACPI_IVHD_INIT_PASS         (1)
866 #define ACPI_IVHD_EINT_PASS         (1<<1)
867 #define ACPI_IVHD_NMI_PASS          (1<<2)
868 #define ACPI_IVHD_SYSTEM_MGMT       (3<<4)
869 #define ACPI_IVHD_LINT0_PASS        (1<<6)
870 #define ACPI_IVHD_LINT1_PASS        (1<<7)
871 
872 
873 /* Types 0-4: 4-byte device entry */
874 
875 typedef struct acpi_ivrs_device4
876 {
877     ACPI_IVRS_DE_HEADER     Header;
878 
879 } ACPI_IVRS_DEVICE4;
880 
881 /* Types 66-67: 8-byte device entry */
882 
883 typedef struct acpi_ivrs_device8a
884 {
885     ACPI_IVRS_DE_HEADER     Header;
886     UINT8                   Reserved1;
887     UINT16                  UsedId;
888     UINT8                   Reserved2;
889 
890 } ACPI_IVRS_DEVICE8A;
891 
892 /* Types 70-71: 8-byte device entry */
893 
894 typedef struct acpi_ivrs_device8b
895 {
896     ACPI_IVRS_DE_HEADER     Header;
897     UINT32                  ExtendedData;
898 
899 } ACPI_IVRS_DEVICE8B;
900 
901 /* Values for ExtendedData above */
902 
903 #define ACPI_IVHD_ATS_DISABLED      (1<<31)
904 
905 /* Type 72: 8-byte device entry */
906 
907 typedef struct acpi_ivrs_device8c
908 {
909     ACPI_IVRS_DE_HEADER     Header;
910     UINT8                   Handle;
911     UINT16                  UsedId;
912     UINT8                   Variety;
913 
914 } ACPI_IVRS_DEVICE8C;
915 
916 /* Values for Variety field above */
917 
918 #define ACPI_IVHD_IOAPIC            1
919 #define ACPI_IVHD_HPET              2
920 
921 
922 /* 0x20, 0x21, 0x22: I/O Virtualization Memory Definition Block (IVMD) */
923 
924 typedef struct acpi_ivrs_memory
925 {
926     ACPI_IVRS_HEADER        Header;
927     UINT16                  AuxData;
928     UINT64                  Reserved;
929     UINT64                  StartAddress;
930     UINT64                  MemoryLength;
931 
932 } ACPI_IVRS_MEMORY;
933 
934 
935 /*******************************************************************************
936  *
937  * MCFG - PCI Memory Mapped Configuration table and sub-table
938  *        Version 1
939  *
940  * Conforms to "PCI Firmware Specification", Revision 3.0, June 20, 2005
941  *
942  ******************************************************************************/
943 
944 typedef struct acpi_table_mcfg
945 {
946     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
947     UINT8                   Reserved[8];
948 
949 } ACPI_TABLE_MCFG;
950 
951 
952 /* Subtable */
953 
954 typedef struct acpi_mcfg_allocation
955 {
956     UINT64                  Address;            /* Base address, processor-relative */
957     UINT16                  PciSegment;         /* PCI segment group number */
958     UINT8                   StartBusNumber;     /* Starting PCI Bus number */
959     UINT8                   EndBusNumber;       /* Final PCI Bus number */
960     UINT32                  Reserved;
961 
962 } ACPI_MCFG_ALLOCATION;
963 
964 
965 /*******************************************************************************
966  *
967  * MCHI - Management Controller Host Interface Table
968  *        Version 1
969  *
970  * Conforms to "Management Component Transport Protocol (MCTP) Host
971  * Interface Specification", Revision 1.0.0a, October 13, 2009
972  *
973  ******************************************************************************/
974 
975 typedef struct acpi_table_mchi
976 {
977     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
978     UINT8                   InterfaceType;
979     UINT8                   Protocol;
980     UINT64                  ProtocolData;
981     UINT8                   InterruptType;
982     UINT8                   Gpe;
983     UINT8                   PciDeviceFlag;
984     UINT32                  GlobalInterrupt;
985     ACPI_GENERIC_ADDRESS    ControlRegister;
986     UINT8                   PciSegment;
987     UINT8                   PciBus;
988     UINT8                   PciDevice;
989     UINT8                   PciFunction;
990 
991 } ACPI_TABLE_MCHI;
992 
993 
994 /*******************************************************************************
995  *
996  * MTMR - MID Timer Table
997  *        Version 1
998  *
999  * Conforms to "Simple Firmware Interface Specification",
1000  * Draft 0.8.2, Oct 19, 2010
1001  * NOTE: The ACPI MTMR is equivalent to the SFI MTMR table.
1002  *
1003  ******************************************************************************/
1004 
1005 typedef struct acpi_table_mtmr
1006 {
1007     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1008 
1009 } ACPI_TABLE_MTMR;
1010 
1011 /* MTMR entry */
1012 
1013 typedef struct acpi_mtmr_entry
1014 {
1015     ACPI_GENERIC_ADDRESS    PhysicalAddress;
1016     UINT32                  Frequency;
1017     UINT32                  Irq;
1018 
1019 } ACPI_MTMR_ENTRY;
1020 
1021 
1022 /*******************************************************************************
1023  *
1024  * SLIC - Software Licensing Description Table
1025  *        Version 1
1026  *
1027  * Conforms to "OEM Activation 2.0 for Windows Vista Operating Systems",
1028  * Copyright 2006
1029  *
1030  ******************************************************************************/
1031 
1032 /* Basic SLIC table is only the common ACPI header */
1033 
1034 typedef struct acpi_table_slic
1035 {
1036     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1037 
1038 } ACPI_TABLE_SLIC;
1039 
1040 
1041 /* Common SLIC subtable header */
1042 
1043 typedef struct acpi_slic_header
1044 {
1045     UINT32                  Type;
1046     UINT32                  Length;
1047 
1048 } ACPI_SLIC_HEADER;
1049 
1050 /* Values for Type field above */
1051 
1052 enum AcpiSlicType
1053 {
1054     ACPI_SLIC_TYPE_PUBLIC_KEY           = 0,
1055     ACPI_SLIC_TYPE_WINDOWS_MARKER       = 1,
1056     ACPI_SLIC_TYPE_RESERVED             = 2    /* 2 and greater are reserved */
1057 };
1058 
1059 
1060 /*
1061  * SLIC Sub-tables, correspond to Type in ACPI_SLIC_HEADER
1062  */
1063 
1064 /* 0: Public Key Structure */
1065 
1066 typedef struct acpi_slic_key
1067 {
1068     ACPI_SLIC_HEADER        Header;
1069     UINT8                   KeyType;
1070     UINT8                   Version;
1071     UINT16                  Reserved;
1072     UINT32                  Algorithm;
1073     char                    Magic[4];
1074     UINT32                  BitLength;
1075     UINT32                  Exponent;
1076     UINT8                   Modulus[128];
1077 
1078 } ACPI_SLIC_KEY;
1079 
1080 
1081 /* 1: Windows Marker Structure */
1082 
1083 typedef struct acpi_slic_marker
1084 {
1085     ACPI_SLIC_HEADER        Header;
1086     UINT32                  Version;
1087     char                    OemId[ACPI_OEM_ID_SIZE];            /* ASCII OEM identification */
1088     char                    OemTableId[ACPI_OEM_TABLE_ID_SIZE]; /* ASCII OEM table identification */
1089     char                    WindowsFlag[8];
1090     UINT32                  SlicVersion;
1091     UINT8                   Reserved[16];
1092     UINT8                   Signature[128];
1093 
1094 } ACPI_SLIC_MARKER;
1095 
1096 
1097 /*******************************************************************************
1098  *
1099  * SPCR - Serial Port Console Redirection table
1100  *        Version 1
1101  *
1102  * Conforms to "Serial Port Console Redirection Table",
1103  * Version 1.00, January 11, 2002
1104  *
1105  ******************************************************************************/
1106 
1107 typedef struct acpi_table_spcr
1108 {
1109     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1110     UINT8                   InterfaceType;      /* 0=full 16550, 1=subset of 16550 */
1111     UINT8                   Reserved[3];
1112     ACPI_GENERIC_ADDRESS    SerialPort;
1113     UINT8                   InterruptType;
1114     UINT8                   PcInterrupt;
1115     UINT32                  Interrupt;
1116     UINT8                   BaudRate;
1117     UINT8                   Parity;
1118     UINT8                   StopBits;
1119     UINT8                   FlowControl;
1120     UINT8                   TerminalType;
1121     UINT8                   Reserved1;
1122     UINT16                  PciDeviceId;
1123     UINT16                  PciVendorId;
1124     UINT8                   PciBus;
1125     UINT8                   PciDevice;
1126     UINT8                   PciFunction;
1127     UINT32                  PciFlags;
1128     UINT8                   PciSegment;
1129     UINT32                  Reserved2;
1130 
1131 } ACPI_TABLE_SPCR;
1132 
1133 /* Masks for PciFlags field above */
1134 
1135 #define ACPI_SPCR_DO_NOT_DISABLE    (1)
1136 
1137 
1138 /*******************************************************************************
1139  *
1140  * SPMI - Server Platform Management Interface table
1141  *        Version 5
1142  *
1143  * Conforms to "Intelligent Platform Management Interface Specification
1144  * Second Generation v2.0", Document Revision 1.0, February 12, 2004 with
1145  * June 12, 2009 markup.
1146  *
1147  ******************************************************************************/
1148 
1149 typedef struct acpi_table_spmi
1150 {
1151     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1152     UINT8                   InterfaceType;
1153     UINT8                   Reserved;           /* Must be 1 */
1154     UINT16                  SpecRevision;       /* Version of IPMI */
1155     UINT8                   InterruptType;
1156     UINT8                   GpeNumber;          /* GPE assigned */
1157     UINT8                   Reserved1;
1158     UINT8                   PciDeviceFlag;
1159     UINT32                  Interrupt;
1160     ACPI_GENERIC_ADDRESS    IpmiRegister;
1161     UINT8                   PciSegment;
1162     UINT8                   PciBus;
1163     UINT8                   PciDevice;
1164     UINT8                   PciFunction;
1165     UINT8                   Reserved2;
1166 
1167 } ACPI_TABLE_SPMI;
1168 
1169 /* Values for InterfaceType above */
1170 
1171 enum AcpiSpmiInterfaceTypes
1172 {
1173     ACPI_SPMI_NOT_USED              = 0,
1174     ACPI_SPMI_KEYBOARD              = 1,
1175     ACPI_SPMI_SMI                   = 2,
1176     ACPI_SPMI_BLOCK_TRANSFER        = 3,
1177     ACPI_SPMI_SMBUS                 = 4,
1178     ACPI_SPMI_RESERVED              = 5         /* 5 and above are reserved */
1179 };
1180 
1181 
1182 /*******************************************************************************
1183  *
1184  * TCPA - Trusted Computing Platform Alliance table
1185  *        Version 1
1186  *
1187  * Conforms to "TCG PC Specific Implementation Specification",
1188  * Version 1.1, August 18, 2003
1189  *
1190  ******************************************************************************/
1191 
1192 typedef struct acpi_table_tcpa
1193 {
1194     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1195     UINT16                  Reserved;
1196     UINT32                  MaxLogLength;       /* Maximum length for the event log area */
1197     UINT64                  LogAddress;         /* Address of the event log area */
1198 
1199 } ACPI_TABLE_TCPA;
1200 
1201 
1202 /*******************************************************************************
1203  *
1204  * UEFI - UEFI Boot optimization Table
1205  *        Version 1
1206  *
1207  * Conforms to "Unified Extensible Firmware Interface Specification",
1208  * Version 2.3, May 8, 2009
1209  *
1210  ******************************************************************************/
1211 
1212 typedef struct acpi_table_uefi
1213 {
1214     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1215     UINT8                   Identifier[16];     /* UUID identifier */
1216     UINT16                  DataOffset;         /* Offset of remaining data in table */
1217 
1218 } ACPI_TABLE_UEFI;
1219 
1220 
1221 /*******************************************************************************
1222  *
1223  * VRTC - Virtual Real Time Clock Table
1224  *        Version 1
1225  *
1226  * Conforms to "Simple Firmware Interface Specification",
1227  * Draft 0.8.2, Oct 19, 2010
1228  * NOTE: The ACPI VRTC is equivalent to The SFI MRTC table.
1229  *
1230  ******************************************************************************/
1231 
1232 typedef struct acpi_table_vrtc
1233 {
1234     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1235 
1236 } ACPI_TABLE_VRTC;
1237 
1238 /* VRTC entry */
1239 
1240 typedef struct acpi_vrtc_entry
1241 {
1242     ACPI_GENERIC_ADDRESS    PhysicalAddress;
1243     UINT32                  Irq;
1244 
1245 } ACPI_VRTC_ENTRY;
1246 
1247 
1248 /*******************************************************************************
1249  *
1250  * WAET - Windows ACPI Emulated devices Table
1251  *        Version 1
1252  *
1253  * Conforms to "Windows ACPI Emulated Devices Table", version 1.0, April 6, 2009
1254  *
1255  ******************************************************************************/
1256 
1257 typedef struct acpi_table_waet
1258 {
1259     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1260     UINT32                  Flags;
1261 
1262 } ACPI_TABLE_WAET;
1263 
1264 /* Masks for Flags field above */
1265 
1266 #define ACPI_WAET_RTC_NO_ACK        (1)         /* RTC requires no int acknowledge */
1267 #define ACPI_WAET_TIMER_ONE_READ    (1<<1)      /* PM timer requires only one read */
1268 
1269 
1270 /*******************************************************************************
1271  *
1272  * WDAT - Watchdog Action Table
1273  *        Version 1
1274  *
1275  * Conforms to "Hardware Watchdog Timers Design Specification",
1276  * Copyright 2006 Microsoft Corporation.
1277  *
1278  ******************************************************************************/
1279 
1280 typedef struct acpi_table_wdat
1281 {
1282     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1283     UINT32                  HeaderLength;       /* Watchdog Header Length */
1284     UINT16                  PciSegment;         /* PCI Segment number */
1285     UINT8                   PciBus;             /* PCI Bus number */
1286     UINT8                   PciDevice;          /* PCI Device number */
1287     UINT8                   PciFunction;        /* PCI Function number */
1288     UINT8                   Reserved[3];
1289     UINT32                  TimerPeriod;        /* Period of one timer count (msec) */
1290     UINT32                  MaxCount;           /* Maximum counter value supported */
1291     UINT32                  MinCount;           /* Minimum counter value */
1292     UINT8                   Flags;
1293     UINT8                   Reserved2[3];
1294     UINT32                  Entries;            /* Number of watchdog entries that follow */
1295 
1296 } ACPI_TABLE_WDAT;
1297 
1298 /* Masks for Flags field above */
1299 
1300 #define ACPI_WDAT_ENABLED           (1)
1301 #define ACPI_WDAT_STOPPED           0x80
1302 
1303 
1304 /* WDAT Instruction Entries (actions) */
1305 
1306 typedef struct acpi_wdat_entry
1307 {
1308     UINT8                   Action;
1309     UINT8                   Instruction;
1310     UINT16                  Reserved;
1311     ACPI_GENERIC_ADDRESS    RegisterRegion;
1312     UINT32                  Value;              /* Value used with Read/Write register */
1313     UINT32                  Mask;               /* Bitmask required for this register instruction */
1314 
1315 } ACPI_WDAT_ENTRY;
1316 
1317 /* Values for Action field above */
1318 
1319 enum AcpiWdatActions
1320 {
1321     ACPI_WDAT_RESET                 = 1,
1322     ACPI_WDAT_GET_CURRENT_COUNTDOWN = 4,
1323     ACPI_WDAT_GET_COUNTDOWN         = 5,
1324     ACPI_WDAT_SET_COUNTDOWN         = 6,
1325     ACPI_WDAT_GET_RUNNING_STATE     = 8,
1326     ACPI_WDAT_SET_RUNNING_STATE     = 9,
1327     ACPI_WDAT_GET_STOPPED_STATE     = 10,
1328     ACPI_WDAT_SET_STOPPED_STATE     = 11,
1329     ACPI_WDAT_GET_REBOOT            = 16,
1330     ACPI_WDAT_SET_REBOOT            = 17,
1331     ACPI_WDAT_GET_SHUTDOWN          = 18,
1332     ACPI_WDAT_SET_SHUTDOWN          = 19,
1333     ACPI_WDAT_GET_STATUS            = 32,
1334     ACPI_WDAT_SET_STATUS            = 33,
1335     ACPI_WDAT_ACTION_RESERVED       = 34    /* 34 and greater are reserved */
1336 };
1337 
1338 /* Values for Instruction field above */
1339 
1340 enum AcpiWdatInstructions
1341 {
1342     ACPI_WDAT_READ_VALUE            = 0,
1343     ACPI_WDAT_READ_COUNTDOWN        = 1,
1344     ACPI_WDAT_WRITE_VALUE           = 2,
1345     ACPI_WDAT_WRITE_COUNTDOWN       = 3,
1346     ACPI_WDAT_INSTRUCTION_RESERVED  = 4,    /* 4 and greater are reserved */
1347     ACPI_WDAT_PRESERVE_REGISTER     = 0x80  /* Except for this value */
1348 };
1349 
1350 
1351 /*******************************************************************************
1352  *
1353  * WDDT - Watchdog Descriptor Table
1354  *        Version 1
1355  *
1356  * Conforms to "Using the Intel ICH Family Watchdog Timer (WDT)",
1357  * Version 001, September 2002
1358  *
1359  ******************************************************************************/
1360 
1361 typedef struct acpi_table_wddt
1362 {
1363     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1364     UINT16                  SpecVersion;
1365     UINT16                  TableVersion;
1366     UINT16                  PciVendorId;
1367     ACPI_GENERIC_ADDRESS    Address;
1368     UINT16                  MaxCount;           /* Maximum counter value supported */
1369     UINT16                  MinCount;           /* Minimum counter value supported */
1370     UINT16                  Period;
1371     UINT16                  Status;
1372     UINT16                  Capability;
1373 
1374 } ACPI_TABLE_WDDT;
1375 
1376 /* Flags for Status field above */
1377 
1378 #define ACPI_WDDT_AVAILABLE     (1)
1379 #define ACPI_WDDT_ACTIVE        (1<<1)
1380 #define ACPI_WDDT_TCO_OS_OWNED  (1<<2)
1381 #define ACPI_WDDT_USER_RESET    (1<<11)
1382 #define ACPI_WDDT_WDT_RESET     (1<<12)
1383 #define ACPI_WDDT_POWER_FAIL    (1<<13)
1384 #define ACPI_WDDT_UNKNOWN_RESET (1<<14)
1385 
1386 /* Flags for Capability field above */
1387 
1388 #define ACPI_WDDT_AUTO_RESET    (1)
1389 #define ACPI_WDDT_ALERT_SUPPORT (1<<1)
1390 
1391 
1392 /*******************************************************************************
1393  *
1394  * WDRT - Watchdog Resource Table
1395  *        Version 1
1396  *
1397  * Conforms to "Watchdog Timer Hardware Requirements for Windows Server 2003",
1398  * Version 1.01, August 28, 2006
1399  *
1400  ******************************************************************************/
1401 
1402 typedef struct acpi_table_wdrt
1403 {
1404     ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
1405     ACPI_GENERIC_ADDRESS    ControlRegister;
1406     ACPI_GENERIC_ADDRESS    CountRegister;
1407     UINT16                  PciDeviceId;
1408     UINT16                  PciVendorId;
1409     UINT8                   PciBus;             /* PCI Bus number */
1410     UINT8                   PciDevice;          /* PCI Device number */
1411     UINT8                   PciFunction;        /* PCI Function number */
1412     UINT8                   PciSegment;         /* PCI Segment number */
1413     UINT16                  MaxCount;           /* Maximum counter value supported */
1414     UINT8                   Units;
1415 
1416 } ACPI_TABLE_WDRT;
1417 
1418 
1419 /* Reset to default packing */
1420 
1421 #pragma pack()
1422 
1423 #endif /* __ACTBL2_H__ */
1424