xref: /onnv-gate/usr/src/uts/intel/sys/acpi/amlresrc.h (revision 0:68f95e015346)
1*0Sstevel@tonic-gate 
2*0Sstevel@tonic-gate /******************************************************************************
3*0Sstevel@tonic-gate  *
4*0Sstevel@tonic-gate  * Module Name: amlresrc.h - AML resource descriptors
5*0Sstevel@tonic-gate  *              $Revision: 29 $
6*0Sstevel@tonic-gate  *
7*0Sstevel@tonic-gate  *****************************************************************************/
8*0Sstevel@tonic-gate 
9*0Sstevel@tonic-gate /******************************************************************************
10*0Sstevel@tonic-gate  *
11*0Sstevel@tonic-gate  * 1. Copyright Notice
12*0Sstevel@tonic-gate  *
13*0Sstevel@tonic-gate  * Some or all of this work - Copyright (c) 1999 - 2005, Intel Corp.
14*0Sstevel@tonic-gate  * All rights reserved.
15*0Sstevel@tonic-gate  *
16*0Sstevel@tonic-gate  * 2. License
17*0Sstevel@tonic-gate  *
18*0Sstevel@tonic-gate  * 2.1. This is your license from Intel Corp. under its intellectual property
19*0Sstevel@tonic-gate  * rights.  You may have additional license terms from the party that provided
20*0Sstevel@tonic-gate  * you this software, covering your right to use that party's intellectual
21*0Sstevel@tonic-gate  * property rights.
22*0Sstevel@tonic-gate  *
23*0Sstevel@tonic-gate  * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
24*0Sstevel@tonic-gate  * copy of the source code appearing in this file ("Covered Code") an
25*0Sstevel@tonic-gate  * irrevocable, perpetual, worldwide license under Intel's copyrights in the
26*0Sstevel@tonic-gate  * base code distributed originally by Intel ("Original Intel Code") to copy,
27*0Sstevel@tonic-gate  * make derivatives, distribute, use and display any portion of the Covered
28*0Sstevel@tonic-gate  * Code in any form, with the right to sublicense such rights; and
29*0Sstevel@tonic-gate  *
30*0Sstevel@tonic-gate  * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
31*0Sstevel@tonic-gate  * license (with the right to sublicense), under only those claims of Intel
32*0Sstevel@tonic-gate  * patents that are infringed by the Original Intel Code, to make, use, sell,
33*0Sstevel@tonic-gate  * offer to sell, and import the Covered Code and derivative works thereof
34*0Sstevel@tonic-gate  * solely to the minimum extent necessary to exercise the above copyright
35*0Sstevel@tonic-gate  * license, and in no event shall the patent license extend to any additions
36*0Sstevel@tonic-gate  * to or modifications of the Original Intel Code.  No other license or right
37*0Sstevel@tonic-gate  * is granted directly or by implication, estoppel or otherwise;
38*0Sstevel@tonic-gate  *
39*0Sstevel@tonic-gate  * The above copyright and patent license is granted only if the following
40*0Sstevel@tonic-gate  * conditions are met:
41*0Sstevel@tonic-gate  *
42*0Sstevel@tonic-gate  * 3. Conditions
43*0Sstevel@tonic-gate  *
44*0Sstevel@tonic-gate  * 3.1. Redistribution of Source with Rights to Further Distribute Source.
45*0Sstevel@tonic-gate  * Redistribution of source code of any substantial portion of the Covered
46*0Sstevel@tonic-gate  * Code or modification with rights to further distribute source must include
47*0Sstevel@tonic-gate  * the above Copyright Notice, the above License, this list of Conditions,
48*0Sstevel@tonic-gate  * and the following Disclaimer and Export Compliance provision.  In addition,
49*0Sstevel@tonic-gate  * Licensee must cause all Covered Code to which Licensee contributes to
50*0Sstevel@tonic-gate  * contain a file documenting the changes Licensee made to create that Covered
51*0Sstevel@tonic-gate  * Code and the date of any change.  Licensee must include in that file the
52*0Sstevel@tonic-gate  * documentation of any changes made by any predecessor Licensee.  Licensee
53*0Sstevel@tonic-gate  * must include a prominent statement that the modification is derived,
54*0Sstevel@tonic-gate  * directly or indirectly, from Original Intel Code.
55*0Sstevel@tonic-gate  *
56*0Sstevel@tonic-gate  * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
57*0Sstevel@tonic-gate  * Redistribution of source code of any substantial portion of the Covered
58*0Sstevel@tonic-gate  * Code or modification without rights to further distribute source must
59*0Sstevel@tonic-gate  * include the following Disclaimer and Export Compliance provision in the
60*0Sstevel@tonic-gate  * documentation and/or other materials provided with distribution.  In
61*0Sstevel@tonic-gate  * addition, Licensee may not authorize further sublicense of source of any
62*0Sstevel@tonic-gate  * portion of the Covered Code, and must include terms to the effect that the
63*0Sstevel@tonic-gate  * license from Licensee to its licensee is limited to the intellectual
64*0Sstevel@tonic-gate  * property embodied in the software Licensee provides to its licensee, and
65*0Sstevel@tonic-gate  * not to intellectual property embodied in modifications its licensee may
66*0Sstevel@tonic-gate  * make.
67*0Sstevel@tonic-gate  *
68*0Sstevel@tonic-gate  * 3.3. Redistribution of Executable. Redistribution in executable form of any
69*0Sstevel@tonic-gate  * substantial portion of the Covered Code or modification must reproduce the
70*0Sstevel@tonic-gate  * above Copyright Notice, and the following Disclaimer and Export Compliance
71*0Sstevel@tonic-gate  * provision in the documentation and/or other materials provided with the
72*0Sstevel@tonic-gate  * distribution.
73*0Sstevel@tonic-gate  *
74*0Sstevel@tonic-gate  * 3.4. Intel retains all right, title, and interest in and to the Original
75*0Sstevel@tonic-gate  * Intel Code.
76*0Sstevel@tonic-gate  *
77*0Sstevel@tonic-gate  * 3.5. Neither the name Intel nor any other trademark owned or controlled by
78*0Sstevel@tonic-gate  * Intel shall be used in advertising or otherwise to promote the sale, use or
79*0Sstevel@tonic-gate  * other dealings in products derived from or relating to the Covered Code
80*0Sstevel@tonic-gate  * without prior written authorization from Intel.
81*0Sstevel@tonic-gate  *
82*0Sstevel@tonic-gate  * 4. Disclaimer and Export Compliance
83*0Sstevel@tonic-gate  *
84*0Sstevel@tonic-gate  * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
85*0Sstevel@tonic-gate  * HERE.  ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
86*0Sstevel@tonic-gate  * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT,  ASSISTANCE,
87*0Sstevel@tonic-gate  * INSTALLATION, TRAINING OR OTHER SERVICES.  INTEL WILL NOT PROVIDE ANY
88*0Sstevel@tonic-gate  * UPDATES, ENHANCEMENTS OR EXTENSIONS.  INTEL SPECIFICALLY DISCLAIMS ANY
89*0Sstevel@tonic-gate  * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
90*0Sstevel@tonic-gate  * PARTICULAR PURPOSE.
91*0Sstevel@tonic-gate  *
92*0Sstevel@tonic-gate  * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
93*0Sstevel@tonic-gate  * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
94*0Sstevel@tonic-gate  * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
95*0Sstevel@tonic-gate  * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
96*0Sstevel@tonic-gate  * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
97*0Sstevel@tonic-gate  * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES.  THESE LIMITATIONS
98*0Sstevel@tonic-gate  * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
99*0Sstevel@tonic-gate  * LIMITED REMEDY.
100*0Sstevel@tonic-gate  *
101*0Sstevel@tonic-gate  * 4.3. Licensee shall not export, either directly or indirectly, any of this
102*0Sstevel@tonic-gate  * software or system incorporating such software without first obtaining any
103*0Sstevel@tonic-gate  * required license or other approval from the U. S. Department of Commerce or
104*0Sstevel@tonic-gate  * any other agency or department of the United States Government.  In the
105*0Sstevel@tonic-gate  * event Licensee exports any such software from the United States or
106*0Sstevel@tonic-gate  * re-exports any such software from a foreign destination, Licensee shall
107*0Sstevel@tonic-gate  * ensure that the distribution and export/re-export of the software is in
108*0Sstevel@tonic-gate  * compliance with all laws, regulations, orders, or other restrictions of the
109*0Sstevel@tonic-gate  * U.S. Export Administration Regulations. Licensee agrees that neither it nor
110*0Sstevel@tonic-gate  * any of its subsidiaries will export/re-export any technical data, process,
111*0Sstevel@tonic-gate  * software, or service, directly or indirectly, to any country for which the
112*0Sstevel@tonic-gate  * United States government or any agency thereof requires an export license,
113*0Sstevel@tonic-gate  * other governmental approval, or letter of assurance, without first obtaining
114*0Sstevel@tonic-gate  * such license, approval or letter.
115*0Sstevel@tonic-gate  *
116*0Sstevel@tonic-gate  *****************************************************************************/
117*0Sstevel@tonic-gate 
118*0Sstevel@tonic-gate 
119*0Sstevel@tonic-gate #ifndef __AMLRESRC_H
120*0Sstevel@tonic-gate #define __AMLRESRC_H
121*0Sstevel@tonic-gate 
122*0Sstevel@tonic-gate 
123*0Sstevel@tonic-gate #define ASL_RESNAME_ADDRESS                     "_ADR"
124*0Sstevel@tonic-gate #define ASL_RESNAME_ALIGNMENT                   "_ALN"
125*0Sstevel@tonic-gate #define ASL_RESNAME_ADDRESSSPACE                "_ASI"
126*0Sstevel@tonic-gate #define ASL_RESNAME_ACCESSSIZE                  "_ASZ"
127*0Sstevel@tonic-gate #define ASL_RESNAME_TYPESPECIFICATTRIBUTES      "_ATT"
128*0Sstevel@tonic-gate #define ASL_RESNAME_BASEADDRESS                 "_BAS"
129*0Sstevel@tonic-gate #define ASL_RESNAME_BUSMASTER                   "_BM_"  /* Master(1), Slave(0) */
130*0Sstevel@tonic-gate #define ASL_RESNAME_DECODE                      "_DEC"
131*0Sstevel@tonic-gate #define ASL_RESNAME_DMA                         "_DMA"
132*0Sstevel@tonic-gate #define ASL_RESNAME_DMATYPE                     "_TYP"  /* Compatible(0), A(1), B(2), F(3) */
133*0Sstevel@tonic-gate #define ASL_RESNAME_GRANULARITY                 "_GRA"
134*0Sstevel@tonic-gate #define ASL_RESNAME_INTERRUPT                   "_INT"
135*0Sstevel@tonic-gate #define ASL_RESNAME_INTERRUPTLEVEL              "_LL_"  /* ActiveLo(1), ActiveHi(0) */
136*0Sstevel@tonic-gate #define ASL_RESNAME_INTERRUPTSHARE              "_SHR"  /* Shareable(1), NoShare(0) */
137*0Sstevel@tonic-gate #define ASL_RESNAME_INTERRUPTTYPE               "_HE_"  /* Edge(1), Level(0) */
138*0Sstevel@tonic-gate #define ASL_RESNAME_LENGTH                      "_LEN"
139*0Sstevel@tonic-gate #define ASL_RESNAME_MEMATTRIBUTES               "_MTP"  /* Memory(0), Reserved(1), ACPI(2), NVS(3) */
140*0Sstevel@tonic-gate #define ASL_RESNAME_MEMTYPE                     "_MEM"  /* NonCache(0), Cacheable(1) Cache+combine(2), Cache+prefetch(3) */
141*0Sstevel@tonic-gate #define ASL_RESNAME_MAXADDR                     "_MAX"
142*0Sstevel@tonic-gate #define ASL_RESNAME_MINADDR                     "_MIN"
143*0Sstevel@tonic-gate #define ASL_RESNAME_MAXTYPE                     "_MAF"
144*0Sstevel@tonic-gate #define ASL_RESNAME_MINTYPE                     "_MIF"
145*0Sstevel@tonic-gate #define ASL_RESNAME_REGISTERBITOFFSET           "_RBO"
146*0Sstevel@tonic-gate #define ASL_RESNAME_REGISTERBITWIDTH            "_RBW"
147*0Sstevel@tonic-gate #define ASL_RESNAME_RANGETYPE                   "_RNG"
148*0Sstevel@tonic-gate #define ASL_RESNAME_READWRITETYPE               "_RW_"  /* ReadOnly(0), Writeable (1) */
149*0Sstevel@tonic-gate #define ASL_RESNAME_TRANSLATION                 "_TRA"
150*0Sstevel@tonic-gate #define ASL_RESNAME_TRANSTYPE                   "_TRS"  /* Sparse(1), Dense(0) */
151*0Sstevel@tonic-gate #define ASL_RESNAME_TYPE                        "_TTP"  /* Translation(1), Static (0) */
152*0Sstevel@tonic-gate #define ASL_RESNAME_XFERTYPE                    "_SIZ"  /* 8(0), 8And16(1), 16(2) */
153*0Sstevel@tonic-gate 
154*0Sstevel@tonic-gate 
155*0Sstevel@tonic-gate /* Default sizes for "small" resource descriptors */
156*0Sstevel@tonic-gate 
157*0Sstevel@tonic-gate #define ASL_RDESC_IRQ_SIZE                      0x02
158*0Sstevel@tonic-gate #define ASL_RDESC_DMA_SIZE                      0x02
159*0Sstevel@tonic-gate #define ASL_RDESC_ST_DEPEND_SIZE                0x00
160*0Sstevel@tonic-gate #define ASL_RDESC_END_DEPEND_SIZE               0x00
161*0Sstevel@tonic-gate #define ASL_RDESC_IO_SIZE                       0x07
162*0Sstevel@tonic-gate #define ASL_RDESC_FIXED_IO_SIZE                 0x03
163*0Sstevel@tonic-gate #define ASL_RDESC_END_TAG_SIZE                  0x01
164*0Sstevel@tonic-gate 
165*0Sstevel@tonic-gate 
166*0Sstevel@tonic-gate typedef struct asl_resource_node
167*0Sstevel@tonic-gate {
168*0Sstevel@tonic-gate     UINT32                      BufferLength;
169*0Sstevel@tonic-gate     void                        *Buffer;
170*0Sstevel@tonic-gate     struct asl_resource_node    *Next;
171*0Sstevel@tonic-gate 
172*0Sstevel@tonic-gate } ASL_RESOURCE_NODE;
173*0Sstevel@tonic-gate 
174*0Sstevel@tonic-gate 
175*0Sstevel@tonic-gate /*
176*0Sstevel@tonic-gate  * Resource descriptors defined in the ACPI specification.
177*0Sstevel@tonic-gate  *
178*0Sstevel@tonic-gate  * Packing/alignment must be BYTE because these descriptors
179*0Sstevel@tonic-gate  * are used to overlay the AML byte stream.
180*0Sstevel@tonic-gate  */
181*0Sstevel@tonic-gate #pragma pack(1)
182*0Sstevel@tonic-gate 
183*0Sstevel@tonic-gate typedef struct asl_irq_format_desc
184*0Sstevel@tonic-gate {
185*0Sstevel@tonic-gate     UINT8                       DescriptorType;
186*0Sstevel@tonic-gate     UINT16                      IrqMask;
187*0Sstevel@tonic-gate     UINT8                       Flags;
188*0Sstevel@tonic-gate 
189*0Sstevel@tonic-gate } ASL_IRQ_FORMAT_DESC;
190*0Sstevel@tonic-gate 
191*0Sstevel@tonic-gate 
192*0Sstevel@tonic-gate typedef struct asl_irq_noflags_desc
193*0Sstevel@tonic-gate {
194*0Sstevel@tonic-gate     UINT8                       DescriptorType;
195*0Sstevel@tonic-gate     UINT16                      IrqMask;
196*0Sstevel@tonic-gate 
197*0Sstevel@tonic-gate } ASL_IRQ_NOFLAGS_DESC;
198*0Sstevel@tonic-gate 
199*0Sstevel@tonic-gate 
200*0Sstevel@tonic-gate typedef struct asl_dma_format_desc
201*0Sstevel@tonic-gate {
202*0Sstevel@tonic-gate     UINT8                       DescriptorType;
203*0Sstevel@tonic-gate     UINT8                       DmaChannelMask;
204*0Sstevel@tonic-gate     UINT8                       Flags;
205*0Sstevel@tonic-gate 
206*0Sstevel@tonic-gate } ASL_DMA_FORMAT_DESC;
207*0Sstevel@tonic-gate 
208*0Sstevel@tonic-gate 
209*0Sstevel@tonic-gate typedef struct asl_start_dependent_desc
210*0Sstevel@tonic-gate {
211*0Sstevel@tonic-gate     UINT8                       DescriptorType;
212*0Sstevel@tonic-gate     UINT8                       Flags;
213*0Sstevel@tonic-gate 
214*0Sstevel@tonic-gate } ASL_START_DEPENDENT_DESC;
215*0Sstevel@tonic-gate 
216*0Sstevel@tonic-gate 
217*0Sstevel@tonic-gate typedef struct asl_start_dependent_noprio_desc
218*0Sstevel@tonic-gate {
219*0Sstevel@tonic-gate     UINT8                       DescriptorType;
220*0Sstevel@tonic-gate 
221*0Sstevel@tonic-gate } ASL_START_DEPENDENT_NOPRIO_DESC;
222*0Sstevel@tonic-gate 
223*0Sstevel@tonic-gate 
224*0Sstevel@tonic-gate typedef struct asl_end_dependent_desc
225*0Sstevel@tonic-gate {
226*0Sstevel@tonic-gate     UINT8                       DescriptorType;
227*0Sstevel@tonic-gate 
228*0Sstevel@tonic-gate } ASL_END_DEPENDENT_DESC;
229*0Sstevel@tonic-gate 
230*0Sstevel@tonic-gate 
231*0Sstevel@tonic-gate typedef struct asl_io_port_desc
232*0Sstevel@tonic-gate {
233*0Sstevel@tonic-gate     UINT8                       DescriptorType;
234*0Sstevel@tonic-gate     UINT8                       Information;
235*0Sstevel@tonic-gate     UINT16                      AddressMin;
236*0Sstevel@tonic-gate     UINT16                      AddressMax;
237*0Sstevel@tonic-gate     UINT8                       Alignment;
238*0Sstevel@tonic-gate     UINT8                       Length;
239*0Sstevel@tonic-gate 
240*0Sstevel@tonic-gate } ASL_IO_PORT_DESC;
241*0Sstevel@tonic-gate 
242*0Sstevel@tonic-gate 
243*0Sstevel@tonic-gate typedef struct asl_fixed_io_port_desc
244*0Sstevel@tonic-gate {
245*0Sstevel@tonic-gate     UINT8                       DescriptorType;
246*0Sstevel@tonic-gate     UINT16                      BaseAddress;
247*0Sstevel@tonic-gate     UINT8                       Length;
248*0Sstevel@tonic-gate 
249*0Sstevel@tonic-gate } ASL_FIXED_IO_PORT_DESC;
250*0Sstevel@tonic-gate 
251*0Sstevel@tonic-gate 
252*0Sstevel@tonic-gate typedef struct asl_small_vendor_desc
253*0Sstevel@tonic-gate {
254*0Sstevel@tonic-gate     UINT8                       DescriptorType;
255*0Sstevel@tonic-gate     UINT8                       VendorDefined[7];
256*0Sstevel@tonic-gate 
257*0Sstevel@tonic-gate } ASL_SMALL_VENDOR_DESC;
258*0Sstevel@tonic-gate 
259*0Sstevel@tonic-gate 
260*0Sstevel@tonic-gate typedef struct asl_end_tag_desc
261*0Sstevel@tonic-gate {
262*0Sstevel@tonic-gate     UINT8                       DescriptorType;
263*0Sstevel@tonic-gate     UINT8                       Checksum;
264*0Sstevel@tonic-gate 
265*0Sstevel@tonic-gate } ASL_END_TAG_DESC;
266*0Sstevel@tonic-gate 
267*0Sstevel@tonic-gate 
268*0Sstevel@tonic-gate /* LARGE descriptors */
269*0Sstevel@tonic-gate 
270*0Sstevel@tonic-gate typedef struct asl_memory_24_desc
271*0Sstevel@tonic-gate {
272*0Sstevel@tonic-gate     UINT8                       DescriptorType;
273*0Sstevel@tonic-gate     UINT16                      Length;
274*0Sstevel@tonic-gate     UINT8                       Information;
275*0Sstevel@tonic-gate     UINT16                      AddressMin;
276*0Sstevel@tonic-gate     UINT16                      AddressMax;
277*0Sstevel@tonic-gate     UINT16                      Alignment;
278*0Sstevel@tonic-gate     UINT16                      RangeLength;
279*0Sstevel@tonic-gate 
280*0Sstevel@tonic-gate } ASL_MEMORY_24_DESC;
281*0Sstevel@tonic-gate 
282*0Sstevel@tonic-gate 
283*0Sstevel@tonic-gate typedef struct asl_large_vendor_desc
284*0Sstevel@tonic-gate {
285*0Sstevel@tonic-gate     UINT8                       DescriptorType;
286*0Sstevel@tonic-gate     UINT16                      Length;
287*0Sstevel@tonic-gate     UINT8                       VendorDefined[1];
288*0Sstevel@tonic-gate 
289*0Sstevel@tonic-gate } ASL_LARGE_VENDOR_DESC;
290*0Sstevel@tonic-gate 
291*0Sstevel@tonic-gate 
292*0Sstevel@tonic-gate typedef struct asl_memory_32_desc
293*0Sstevel@tonic-gate {
294*0Sstevel@tonic-gate     UINT8                       DescriptorType;
295*0Sstevel@tonic-gate     UINT16                      Length;
296*0Sstevel@tonic-gate     UINT8                       Information;
297*0Sstevel@tonic-gate     UINT32                      AddressMin;
298*0Sstevel@tonic-gate     UINT32                      AddressMax;
299*0Sstevel@tonic-gate     UINT32                      Alignment;
300*0Sstevel@tonic-gate     UINT32                      RangeLength;
301*0Sstevel@tonic-gate 
302*0Sstevel@tonic-gate } ASL_MEMORY_32_DESC;
303*0Sstevel@tonic-gate 
304*0Sstevel@tonic-gate 
305*0Sstevel@tonic-gate typedef struct asl_fixed_memory_32_desc
306*0Sstevel@tonic-gate {
307*0Sstevel@tonic-gate     UINT8                       DescriptorType;
308*0Sstevel@tonic-gate     UINT16                      Length;
309*0Sstevel@tonic-gate     UINT8                       Information;
310*0Sstevel@tonic-gate     UINT32                      BaseAddress;
311*0Sstevel@tonic-gate     UINT32                      RangeLength;
312*0Sstevel@tonic-gate 
313*0Sstevel@tonic-gate } ASL_FIXED_MEMORY_32_DESC;
314*0Sstevel@tonic-gate 
315*0Sstevel@tonic-gate 
316*0Sstevel@tonic-gate typedef struct asl_extended_address_desc
317*0Sstevel@tonic-gate {
318*0Sstevel@tonic-gate     UINT8                       DescriptorType;
319*0Sstevel@tonic-gate     UINT16                      Length;
320*0Sstevel@tonic-gate     UINT8                       ResourceType;
321*0Sstevel@tonic-gate     UINT8                       Flags;
322*0Sstevel@tonic-gate     UINT8                       SpecificFlags;
323*0Sstevel@tonic-gate     UINT8                       RevisionID;
324*0Sstevel@tonic-gate     UINT8                       Reserved;
325*0Sstevel@tonic-gate     UINT64                      Granularity;
326*0Sstevel@tonic-gate     UINT64                      AddressMin;
327*0Sstevel@tonic-gate     UINT64                      AddressMax;
328*0Sstevel@tonic-gate     UINT64                      TranslationOffset;
329*0Sstevel@tonic-gate     UINT64                      AddressLength;
330*0Sstevel@tonic-gate     UINT64                      TypeSpecificAttributes;
331*0Sstevel@tonic-gate     UINT8                       OptionalFields[2];  /* Used for length calculation only */
332*0Sstevel@tonic-gate 
333*0Sstevel@tonic-gate } ASL_EXTENDED_ADDRESS_DESC;
334*0Sstevel@tonic-gate 
335*0Sstevel@tonic-gate #define ASL_EXTENDED_ADDRESS_DESC_REVISION          1       /* ACPI 3.0 */
336*0Sstevel@tonic-gate 
337*0Sstevel@tonic-gate 
338*0Sstevel@tonic-gate typedef struct asl_qword_address_desc
339*0Sstevel@tonic-gate {
340*0Sstevel@tonic-gate     UINT8                       DescriptorType;
341*0Sstevel@tonic-gate     UINT16                      Length;
342*0Sstevel@tonic-gate     UINT8                       ResourceType;
343*0Sstevel@tonic-gate     UINT8                       Flags;
344*0Sstevel@tonic-gate     UINT8                       SpecificFlags;
345*0Sstevel@tonic-gate     UINT64                      Granularity;
346*0Sstevel@tonic-gate     UINT64                      AddressMin;
347*0Sstevel@tonic-gate     UINT64                      AddressMax;
348*0Sstevel@tonic-gate     UINT64                      TranslationOffset;
349*0Sstevel@tonic-gate     UINT64                      AddressLength;
350*0Sstevel@tonic-gate     UINT8                       OptionalFields[2];
351*0Sstevel@tonic-gate 
352*0Sstevel@tonic-gate } ASL_QWORD_ADDRESS_DESC;
353*0Sstevel@tonic-gate 
354*0Sstevel@tonic-gate 
355*0Sstevel@tonic-gate typedef struct asl_dword_address_desc
356*0Sstevel@tonic-gate {
357*0Sstevel@tonic-gate     UINT8                       DescriptorType;
358*0Sstevel@tonic-gate     UINT16                      Length;
359*0Sstevel@tonic-gate     UINT8                       ResourceType;
360*0Sstevel@tonic-gate     UINT8                       Flags;
361*0Sstevel@tonic-gate     UINT8                       SpecificFlags;
362*0Sstevel@tonic-gate     UINT32                      Granularity;
363*0Sstevel@tonic-gate     UINT32                      AddressMin;
364*0Sstevel@tonic-gate     UINT32                      AddressMax;
365*0Sstevel@tonic-gate     UINT32                      TranslationOffset;
366*0Sstevel@tonic-gate     UINT32                      AddressLength;
367*0Sstevel@tonic-gate     UINT8                       OptionalFields[2];
368*0Sstevel@tonic-gate 
369*0Sstevel@tonic-gate } ASL_DWORD_ADDRESS_DESC;
370*0Sstevel@tonic-gate 
371*0Sstevel@tonic-gate 
372*0Sstevel@tonic-gate typedef struct asl_word_address_desc
373*0Sstevel@tonic-gate {
374*0Sstevel@tonic-gate     UINT8                       DescriptorType;
375*0Sstevel@tonic-gate     UINT16                      Length;
376*0Sstevel@tonic-gate     UINT8                       ResourceType;
377*0Sstevel@tonic-gate     UINT8                       Flags;
378*0Sstevel@tonic-gate     UINT8                       SpecificFlags;
379*0Sstevel@tonic-gate     UINT16                      Granularity;
380*0Sstevel@tonic-gate     UINT16                      AddressMin;
381*0Sstevel@tonic-gate     UINT16                      AddressMax;
382*0Sstevel@tonic-gate     UINT16                      TranslationOffset;
383*0Sstevel@tonic-gate     UINT16                      AddressLength;
384*0Sstevel@tonic-gate     UINT8                       OptionalFields[2];
385*0Sstevel@tonic-gate 
386*0Sstevel@tonic-gate } ASL_WORD_ADDRESS_DESC;
387*0Sstevel@tonic-gate 
388*0Sstevel@tonic-gate 
389*0Sstevel@tonic-gate typedef struct asl_extended_xrupt_desc
390*0Sstevel@tonic-gate {
391*0Sstevel@tonic-gate     UINT8                       DescriptorType;
392*0Sstevel@tonic-gate     UINT16                      Length;
393*0Sstevel@tonic-gate     UINT8                       Flags;
394*0Sstevel@tonic-gate     UINT8                       TableLength;
395*0Sstevel@tonic-gate     UINT32                      InterruptNumber[1];
396*0Sstevel@tonic-gate     /* ResSourceIndex, ResSource optional fields follow */
397*0Sstevel@tonic-gate 
398*0Sstevel@tonic-gate } ASL_EXTENDED_XRUPT_DESC;
399*0Sstevel@tonic-gate 
400*0Sstevel@tonic-gate 
401*0Sstevel@tonic-gate typedef struct asl_general_register_desc
402*0Sstevel@tonic-gate {
403*0Sstevel@tonic-gate     UINT8                       DescriptorType;
404*0Sstevel@tonic-gate     UINT16                      Length;
405*0Sstevel@tonic-gate     UINT8                       AddressSpaceId;
406*0Sstevel@tonic-gate     UINT8                       BitWidth;
407*0Sstevel@tonic-gate     UINT8                       BitOffset;
408*0Sstevel@tonic-gate     UINT8                       AccessSize; /* ACPI 3.0, was Reserved */
409*0Sstevel@tonic-gate     UINT64                      Address;
410*0Sstevel@tonic-gate 
411*0Sstevel@tonic-gate } ASL_GENERAL_REGISTER_DESC;
412*0Sstevel@tonic-gate 
413*0Sstevel@tonic-gate /* restore default alignment */
414*0Sstevel@tonic-gate 
415*0Sstevel@tonic-gate #pragma pack()
416*0Sstevel@tonic-gate 
417*0Sstevel@tonic-gate /* Union of all resource descriptors, so we can allocate the worst case */
418*0Sstevel@tonic-gate 
419*0Sstevel@tonic-gate typedef union asl_resource_desc
420*0Sstevel@tonic-gate {
421*0Sstevel@tonic-gate     ASL_IRQ_FORMAT_DESC         Irq;
422*0Sstevel@tonic-gate     ASL_DMA_FORMAT_DESC         Dma;
423*0Sstevel@tonic-gate     ASL_START_DEPENDENT_DESC    Std;
424*0Sstevel@tonic-gate     ASL_END_DEPENDENT_DESC      End;
425*0Sstevel@tonic-gate     ASL_IO_PORT_DESC            Iop;
426*0Sstevel@tonic-gate     ASL_FIXED_IO_PORT_DESC      Fio;
427*0Sstevel@tonic-gate     ASL_SMALL_VENDOR_DESC       Smv;
428*0Sstevel@tonic-gate     ASL_END_TAG_DESC            Et;
429*0Sstevel@tonic-gate 
430*0Sstevel@tonic-gate     ASL_MEMORY_24_DESC          M24;
431*0Sstevel@tonic-gate     ASL_LARGE_VENDOR_DESC       Lgv;
432*0Sstevel@tonic-gate     ASL_MEMORY_32_DESC          M32;
433*0Sstevel@tonic-gate     ASL_FIXED_MEMORY_32_DESC    F32;
434*0Sstevel@tonic-gate     ASL_QWORD_ADDRESS_DESC      Qas;
435*0Sstevel@tonic-gate     ASL_DWORD_ADDRESS_DESC      Das;
436*0Sstevel@tonic-gate     ASL_WORD_ADDRESS_DESC       Was;
437*0Sstevel@tonic-gate     ASL_EXTENDED_ADDRESS_DESC   Eas;
438*0Sstevel@tonic-gate     ASL_EXTENDED_XRUPT_DESC     Exx;
439*0Sstevel@tonic-gate     ASL_GENERAL_REGISTER_DESC   Grg;
440*0Sstevel@tonic-gate     UINT32                      U32Item;
441*0Sstevel@tonic-gate     UINT16                      U16Item;
442*0Sstevel@tonic-gate     UINT8                       U8Item;
443*0Sstevel@tonic-gate 
444*0Sstevel@tonic-gate } ASL_RESOURCE_DESC;
445*0Sstevel@tonic-gate 
446*0Sstevel@tonic-gate 
447*0Sstevel@tonic-gate #endif
448*0Sstevel@tonic-gate 
449