Home | History | Annotate | Line # | Download | only in include
amlresrc.h revision 1.3.6.1
      1      1.1   jruoho /******************************************************************************
      2      1.1   jruoho  *
      3      1.1   jruoho  * Module Name: amlresrc.h - AML resource descriptors
      4      1.1   jruoho  *
      5      1.1   jruoho  *****************************************************************************/
      6      1.1   jruoho 
      7      1.2    kamil /*
      8  1.3.6.1  thorpej  * Copyright (C) 2000 - 2021, Intel Corp.
      9      1.1   jruoho  * All rights reserved.
     10      1.1   jruoho  *
     11      1.2    kamil  * Redistribution and use in source and binary forms, with or without
     12      1.2    kamil  * modification, are permitted provided that the following conditions
     13      1.2    kamil  * are met:
     14      1.2    kamil  * 1. Redistributions of source code must retain the above copyright
     15      1.2    kamil  *    notice, this list of conditions, and the following disclaimer,
     16      1.2    kamil  *    without modification.
     17      1.2    kamil  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
     18      1.2    kamil  *    substantially similar to the "NO WARRANTY" disclaimer below
     19      1.2    kamil  *    ("Disclaimer") and any redistribution must be conditioned upon
     20      1.2    kamil  *    including a substantially similar Disclaimer requirement for further
     21      1.2    kamil  *    binary redistribution.
     22      1.2    kamil  * 3. Neither the names of the above-listed copyright holders nor the names
     23      1.2    kamil  *    of any contributors may be used to endorse or promote products derived
     24      1.2    kamil  *    from this software without specific prior written permission.
     25      1.2    kamil  *
     26      1.2    kamil  * Alternatively, this software may be distributed under the terms of the
     27      1.2    kamil  * GNU General Public License ("GPL") version 2 as published by the Free
     28      1.2    kamil  * Software Foundation.
     29      1.2    kamil  *
     30      1.2    kamil  * NO WARRANTY
     31      1.2    kamil  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     32      1.2    kamil  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     33  1.3.6.1  thorpej  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
     34      1.2    kamil  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
     35      1.2    kamil  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     36      1.2    kamil  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     37      1.2    kamil  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     38      1.2    kamil  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     39      1.2    kamil  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
     40      1.2    kamil  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     41      1.2    kamil  * POSSIBILITY OF SUCH DAMAGES.
     42      1.2    kamil  */
     43      1.1   jruoho 
     44      1.1   jruoho /* acpisrc:StructDefs -- for acpisrc conversion */
     45      1.1   jruoho 
     46      1.1   jruoho #ifndef __AMLRESRC_H
     47      1.1   jruoho #define __AMLRESRC_H
     48      1.1   jruoho 
     49      1.1   jruoho 
     50      1.1   jruoho /*
     51      1.1   jruoho  * Resource descriptor tags, as defined in the ACPI specification.
     52      1.1   jruoho  * Used to symbolically reference fields within a descriptor.
     53      1.1   jruoho  */
     54      1.1   jruoho #define ACPI_RESTAG_ADDRESS                     "_ADR"
     55      1.1   jruoho #define ACPI_RESTAG_ALIGNMENT                   "_ALN"
     56      1.1   jruoho #define ACPI_RESTAG_ADDRESSSPACE                "_ASI"
     57      1.1   jruoho #define ACPI_RESTAG_ACCESSSIZE                  "_ASZ"
     58      1.1   jruoho #define ACPI_RESTAG_TYPESPECIFICATTRIBUTES      "_ATT"
     59      1.1   jruoho #define ACPI_RESTAG_BASEADDRESS                 "_BAS"
     60      1.1   jruoho #define ACPI_RESTAG_BUSMASTER                   "_BM_"  /* Master(1), Slave(0) */
     61      1.2    kamil #define ACPI_RESTAG_DEBOUNCETIME                "_DBT"
     62      1.1   jruoho #define ACPI_RESTAG_DECODE                      "_DEC"
     63      1.2    kamil #define ACPI_RESTAG_DEVICEPOLARITY              "_DPL"
     64      1.1   jruoho #define ACPI_RESTAG_DMA                         "_DMA"
     65      1.1   jruoho #define ACPI_RESTAG_DMATYPE                     "_TYP"  /* Compatible(0), A(1), B(2), F(3) */
     66      1.2    kamil #define ACPI_RESTAG_DRIVESTRENGTH               "_DRS"
     67      1.2    kamil #define ACPI_RESTAG_ENDIANNESS                  "_END"
     68      1.2    kamil #define ACPI_RESTAG_FLOWCONTROL                 "_FLC"
     69      1.2    kamil #define ACPI_RESTAG_FUNCTION                    "_FUN"
     70      1.1   jruoho #define ACPI_RESTAG_GRANULARITY                 "_GRA"
     71      1.1   jruoho #define ACPI_RESTAG_INTERRUPT                   "_INT"
     72      1.1   jruoho #define ACPI_RESTAG_INTERRUPTLEVEL              "_LL_"  /* ActiveLo(1), ActiveHi(0) */
     73      1.1   jruoho #define ACPI_RESTAG_INTERRUPTSHARE              "_SHR"  /* Shareable(1), NoShare(0) */
     74      1.1   jruoho #define ACPI_RESTAG_INTERRUPTTYPE               "_HE_"  /* Edge(1), Level(0) */
     75      1.2    kamil #define ACPI_RESTAG_IORESTRICTION               "_IOR"
     76      1.1   jruoho #define ACPI_RESTAG_LENGTH                      "_LEN"
     77      1.2    kamil #define ACPI_RESTAG_LINE                        "_LIN"
     78  1.3.6.1  thorpej #define ACPI_RESTAG_LOCALPORT                   "_PRT"
     79      1.1   jruoho #define ACPI_RESTAG_MEMATTRIBUTES               "_MTP"  /* Memory(0), Reserved(1), ACPI(2), NVS(3) */
     80      1.1   jruoho #define ACPI_RESTAG_MEMTYPE                     "_MEM"  /* NonCache(0), Cacheable(1) Cache+combine(2), Cache+prefetch(3) */
     81      1.1   jruoho #define ACPI_RESTAG_MAXADDR                     "_MAX"
     82      1.1   jruoho #define ACPI_RESTAG_MINADDR                     "_MIN"
     83      1.1   jruoho #define ACPI_RESTAG_MAXTYPE                     "_MAF"
     84      1.1   jruoho #define ACPI_RESTAG_MINTYPE                     "_MIF"
     85      1.2    kamil #define ACPI_RESTAG_MODE                        "_MOD"
     86      1.2    kamil #define ACPI_RESTAG_PARITY                      "_PAR"
     87      1.2    kamil #define ACPI_RESTAG_PHASE                       "_PHA"
     88  1.3.6.1  thorpej #define ACPI_RESTAG_PHYTYPE                     "_PHY"
     89      1.2    kamil #define ACPI_RESTAG_PIN                         "_PIN"
     90      1.2    kamil #define ACPI_RESTAG_PINCONFIG                   "_PPI"
     91      1.2    kamil #define ACPI_RESTAG_PINCONFIG_TYPE              "_TYP"
     92      1.2    kamil #define ACPI_RESTAG_PINCONFIG_VALUE             "_VAL"
     93      1.2    kamil #define ACPI_RESTAG_POLARITY                    "_POL"
     94      1.1   jruoho #define ACPI_RESTAG_REGISTERBITOFFSET           "_RBO"
     95      1.1   jruoho #define ACPI_RESTAG_REGISTERBITWIDTH            "_RBW"
     96      1.1   jruoho #define ACPI_RESTAG_RANGETYPE                   "_RNG"
     97      1.1   jruoho #define ACPI_RESTAG_READWRITETYPE               "_RW_"  /* ReadOnly(0), Writeable (1) */
     98      1.2    kamil #define ACPI_RESTAG_LENGTH_RX                   "_RXL"
     99      1.2    kamil #define ACPI_RESTAG_LENGTH_TX                   "_TXL"
    100      1.2    kamil #define ACPI_RESTAG_SLAVEMODE                   "_SLV"
    101      1.2    kamil #define ACPI_RESTAG_SPEED                       "_SPE"
    102      1.2    kamil #define ACPI_RESTAG_STOPBITS                    "_STB"
    103      1.1   jruoho #define ACPI_RESTAG_TRANSLATION                 "_TRA"
    104      1.1   jruoho #define ACPI_RESTAG_TRANSTYPE                   "_TRS"  /* Sparse(1), Dense(0) */
    105      1.1   jruoho #define ACPI_RESTAG_TYPE                        "_TTP"  /* Translation(1), Static (0) */
    106      1.1   jruoho #define ACPI_RESTAG_XFERTYPE                    "_SIZ"  /* 8(0), 8And16(1), 16(2) */
    107      1.2    kamil #define ACPI_RESTAG_VENDORDATA                  "_VEN"
    108      1.1   jruoho 
    109      1.1   jruoho 
    110      1.1   jruoho /* Default sizes for "small" resource descriptors */
    111      1.1   jruoho 
    112      1.1   jruoho #define ASL_RDESC_IRQ_SIZE                      0x02
    113      1.1   jruoho #define ASL_RDESC_DMA_SIZE                      0x02
    114      1.1   jruoho #define ASL_RDESC_ST_DEPEND_SIZE                0x00
    115      1.1   jruoho #define ASL_RDESC_END_DEPEND_SIZE               0x00
    116      1.1   jruoho #define ASL_RDESC_IO_SIZE                       0x07
    117      1.1   jruoho #define ASL_RDESC_FIXED_IO_SIZE                 0x03
    118      1.2    kamil #define ASL_RDESC_FIXED_DMA_SIZE                0x05
    119      1.1   jruoho #define ASL_RDESC_END_TAG_SIZE                  0x01
    120      1.1   jruoho 
    121      1.1   jruoho 
    122      1.1   jruoho typedef struct asl_resource_node
    123      1.1   jruoho {
    124      1.1   jruoho     UINT32                          BufferLength;
    125      1.1   jruoho     void                            *Buffer;
    126      1.1   jruoho     struct asl_resource_node        *Next;
    127      1.1   jruoho 
    128      1.1   jruoho } ASL_RESOURCE_NODE;
    129      1.1   jruoho 
    130      1.2    kamil typedef struct asl_resource_info
    131      1.2    kamil {
    132      1.2    kamil     ACPI_PARSE_OBJECT               *DescriptorTypeOp;  /* Resource descriptor parse node */
    133      1.2    kamil     ACPI_PARSE_OBJECT               *MappingOp;         /* Used for mapfile support */
    134      1.2    kamil     UINT32                          CurrentByteOffset;  /* Offset in resource template */
    135      1.2    kamil 
    136      1.2    kamil } ASL_RESOURCE_INFO;
    137      1.2    kamil 
    138      1.1   jruoho 
    139      1.1   jruoho /* Macros used to generate AML resource length fields */
    140      1.1   jruoho 
    141      1.1   jruoho #define ACPI_AML_SIZE_LARGE(r)      (sizeof (r) - sizeof (AML_RESOURCE_LARGE_HEADER))
    142      1.1   jruoho #define ACPI_AML_SIZE_SMALL(r)      (sizeof (r) - sizeof (AML_RESOURCE_SMALL_HEADER))
    143      1.1   jruoho 
    144      1.1   jruoho /*
    145      1.1   jruoho  * Resource descriptors defined in the ACPI specification.
    146      1.1   jruoho  *
    147      1.1   jruoho  * Packing/alignment must be BYTE because these descriptors
    148      1.1   jruoho  * are used to overlay the raw AML byte stream.
    149      1.1   jruoho  */
    150      1.1   jruoho #pragma pack(1)
    151      1.1   jruoho 
    152      1.1   jruoho /*
    153      1.1   jruoho  * SMALL descriptors
    154      1.1   jruoho  */
    155      1.1   jruoho #define AML_RESOURCE_SMALL_HEADER_COMMON \
    156      1.1   jruoho     UINT8                           DescriptorType;
    157      1.1   jruoho 
    158      1.1   jruoho typedef struct aml_resource_small_header
    159      1.1   jruoho {
    160      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    161      1.1   jruoho 
    162      1.1   jruoho } AML_RESOURCE_SMALL_HEADER;
    163      1.1   jruoho 
    164      1.1   jruoho 
    165      1.1   jruoho typedef struct aml_resource_irq
    166      1.1   jruoho {
    167      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    168      1.1   jruoho     UINT16                          IrqMask;
    169      1.1   jruoho     UINT8                           Flags;
    170      1.1   jruoho 
    171      1.1   jruoho } AML_RESOURCE_IRQ;
    172      1.1   jruoho 
    173      1.1   jruoho 
    174      1.1   jruoho typedef struct aml_resource_irq_noflags
    175      1.1   jruoho {
    176      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    177      1.1   jruoho     UINT16                          IrqMask;
    178      1.1   jruoho 
    179      1.1   jruoho } AML_RESOURCE_IRQ_NOFLAGS;
    180      1.1   jruoho 
    181      1.1   jruoho 
    182      1.1   jruoho typedef struct aml_resource_dma
    183      1.1   jruoho {
    184      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    185      1.1   jruoho     UINT8                           DmaChannelMask;
    186      1.1   jruoho     UINT8                           Flags;
    187      1.1   jruoho 
    188      1.1   jruoho } AML_RESOURCE_DMA;
    189      1.1   jruoho 
    190      1.1   jruoho 
    191      1.1   jruoho typedef struct aml_resource_start_dependent
    192      1.1   jruoho {
    193      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    194      1.1   jruoho     UINT8                           Flags;
    195      1.1   jruoho 
    196      1.1   jruoho } AML_RESOURCE_START_DEPENDENT;
    197      1.1   jruoho 
    198      1.1   jruoho 
    199      1.1   jruoho typedef struct aml_resource_start_dependent_noprio
    200      1.1   jruoho {
    201      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    202      1.1   jruoho 
    203      1.1   jruoho } AML_RESOURCE_START_DEPENDENT_NOPRIO;
    204      1.1   jruoho 
    205      1.1   jruoho 
    206      1.1   jruoho typedef struct aml_resource_end_dependent
    207      1.1   jruoho {
    208      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    209      1.1   jruoho 
    210      1.1   jruoho } AML_RESOURCE_END_DEPENDENT;
    211      1.1   jruoho 
    212      1.1   jruoho 
    213      1.1   jruoho typedef struct aml_resource_io
    214      1.1   jruoho {
    215      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    216      1.1   jruoho     UINT8                           Flags;
    217      1.1   jruoho     UINT16                          Minimum;
    218      1.1   jruoho     UINT16                          Maximum;
    219      1.1   jruoho     UINT8                           Alignment;
    220      1.1   jruoho     UINT8                           AddressLength;
    221      1.1   jruoho 
    222      1.1   jruoho } AML_RESOURCE_IO;
    223      1.1   jruoho 
    224      1.1   jruoho 
    225      1.1   jruoho typedef struct aml_resource_fixed_io
    226      1.1   jruoho {
    227      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    228      1.1   jruoho     UINT16                          Address;
    229      1.1   jruoho     UINT8                           AddressLength;
    230      1.1   jruoho 
    231      1.1   jruoho } AML_RESOURCE_FIXED_IO;
    232      1.1   jruoho 
    233      1.1   jruoho 
    234      1.1   jruoho typedef struct aml_resource_vendor_small
    235      1.1   jruoho {
    236      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    237      1.1   jruoho 
    238      1.1   jruoho } AML_RESOURCE_VENDOR_SMALL;
    239      1.1   jruoho 
    240      1.1   jruoho 
    241      1.1   jruoho typedef struct aml_resource_end_tag
    242      1.1   jruoho {
    243      1.1   jruoho     AML_RESOURCE_SMALL_HEADER_COMMON
    244      1.1   jruoho     UINT8                           Checksum;
    245      1.1   jruoho 
    246      1.1   jruoho } AML_RESOURCE_END_TAG;
    247      1.1   jruoho 
    248      1.1   jruoho 
    249      1.2    kamil typedef struct aml_resource_fixed_dma
    250      1.2    kamil {
    251      1.2    kamil     AML_RESOURCE_SMALL_HEADER_COMMON
    252      1.2    kamil     UINT16                          RequestLines;
    253      1.2    kamil     UINT16                          Channels;
    254      1.2    kamil     UINT8                           Width;
    255      1.2    kamil 
    256      1.2    kamil } AML_RESOURCE_FIXED_DMA;
    257      1.2    kamil 
    258      1.2    kamil 
    259      1.1   jruoho /*
    260      1.1   jruoho  * LARGE descriptors
    261      1.1   jruoho  */
    262      1.1   jruoho #define AML_RESOURCE_LARGE_HEADER_COMMON \
    263      1.1   jruoho     UINT8                           DescriptorType;\
    264      1.1   jruoho     UINT16                          ResourceLength;
    265      1.1   jruoho 
    266      1.1   jruoho typedef struct aml_resource_large_header
    267      1.1   jruoho {
    268      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    269      1.1   jruoho 
    270      1.1   jruoho } AML_RESOURCE_LARGE_HEADER;
    271      1.1   jruoho 
    272      1.1   jruoho 
    273      1.1   jruoho /* General Flags for address space resource descriptors */
    274      1.1   jruoho 
    275      1.1   jruoho #define ACPI_RESOURCE_FLAG_DEC      2
    276      1.1   jruoho #define ACPI_RESOURCE_FLAG_MIF      4
    277      1.1   jruoho #define ACPI_RESOURCE_FLAG_MAF      8
    278      1.1   jruoho 
    279      1.1   jruoho typedef struct aml_resource_memory24
    280      1.1   jruoho {
    281      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    282      1.1   jruoho     UINT8                           Flags;
    283      1.1   jruoho     UINT16                          Minimum;
    284      1.1   jruoho     UINT16                          Maximum;
    285      1.1   jruoho     UINT16                          Alignment;
    286      1.1   jruoho     UINT16                          AddressLength;
    287      1.1   jruoho 
    288      1.1   jruoho } AML_RESOURCE_MEMORY24;
    289      1.1   jruoho 
    290      1.1   jruoho 
    291      1.1   jruoho typedef struct aml_resource_vendor_large
    292      1.1   jruoho {
    293      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    294      1.1   jruoho 
    295      1.1   jruoho } AML_RESOURCE_VENDOR_LARGE;
    296      1.1   jruoho 
    297      1.1   jruoho 
    298      1.1   jruoho typedef struct aml_resource_memory32
    299      1.1   jruoho {
    300      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    301      1.1   jruoho     UINT8                           Flags;
    302      1.1   jruoho     UINT32                          Minimum;
    303      1.1   jruoho     UINT32                          Maximum;
    304      1.1   jruoho     UINT32                          Alignment;
    305      1.1   jruoho     UINT32                          AddressLength;
    306      1.1   jruoho 
    307      1.1   jruoho } AML_RESOURCE_MEMORY32;
    308      1.1   jruoho 
    309      1.1   jruoho 
    310      1.1   jruoho typedef struct aml_resource_fixed_memory32
    311      1.1   jruoho {
    312      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    313      1.1   jruoho     UINT8                           Flags;
    314      1.1   jruoho     UINT32                          Address;
    315      1.1   jruoho     UINT32                          AddressLength;
    316      1.1   jruoho 
    317      1.1   jruoho } AML_RESOURCE_FIXED_MEMORY32;
    318      1.1   jruoho 
    319      1.1   jruoho 
    320      1.1   jruoho #define AML_RESOURCE_ADDRESS_COMMON \
    321      1.1   jruoho     UINT8                           ResourceType; \
    322      1.1   jruoho     UINT8                           Flags; \
    323      1.1   jruoho     UINT8                           SpecificFlags;
    324      1.1   jruoho 
    325      1.1   jruoho 
    326      1.1   jruoho typedef struct aml_resource_address
    327      1.1   jruoho {
    328      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    329      1.1   jruoho     AML_RESOURCE_ADDRESS_COMMON
    330      1.1   jruoho 
    331      1.1   jruoho } AML_RESOURCE_ADDRESS;
    332      1.1   jruoho 
    333      1.1   jruoho 
    334      1.1   jruoho typedef struct aml_resource_extended_address64
    335      1.1   jruoho {
    336      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    337      1.1   jruoho     AML_RESOURCE_ADDRESS_COMMON
    338      1.1   jruoho     UINT8                           RevisionID;
    339      1.1   jruoho     UINT8                           Reserved;
    340      1.1   jruoho     UINT64                          Granularity;
    341      1.1   jruoho     UINT64                          Minimum;
    342      1.1   jruoho     UINT64                          Maximum;
    343      1.1   jruoho     UINT64                          TranslationOffset;
    344      1.1   jruoho     UINT64                          AddressLength;
    345      1.1   jruoho     UINT64                          TypeSpecific;
    346      1.1   jruoho 
    347      1.1   jruoho } AML_RESOURCE_EXTENDED_ADDRESS64;
    348      1.1   jruoho 
    349      1.1   jruoho #define AML_RESOURCE_EXTENDED_ADDRESS_REVISION          1       /* ACPI 3.0 */
    350      1.1   jruoho 
    351      1.1   jruoho 
    352      1.1   jruoho typedef struct aml_resource_address64
    353      1.1   jruoho {
    354      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    355      1.1   jruoho     AML_RESOURCE_ADDRESS_COMMON
    356      1.1   jruoho     UINT64                          Granularity;
    357      1.1   jruoho     UINT64                          Minimum;
    358      1.1   jruoho     UINT64                          Maximum;
    359      1.1   jruoho     UINT64                          TranslationOffset;
    360      1.1   jruoho     UINT64                          AddressLength;
    361      1.1   jruoho 
    362      1.1   jruoho } AML_RESOURCE_ADDRESS64;
    363      1.1   jruoho 
    364      1.1   jruoho 
    365      1.1   jruoho typedef struct aml_resource_address32
    366      1.1   jruoho {
    367      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    368      1.1   jruoho     AML_RESOURCE_ADDRESS_COMMON
    369      1.1   jruoho     UINT32                          Granularity;
    370      1.1   jruoho     UINT32                          Minimum;
    371      1.1   jruoho     UINT32                          Maximum;
    372      1.1   jruoho     UINT32                          TranslationOffset;
    373      1.1   jruoho     UINT32                          AddressLength;
    374      1.1   jruoho 
    375      1.1   jruoho } AML_RESOURCE_ADDRESS32;
    376      1.1   jruoho 
    377      1.1   jruoho 
    378      1.1   jruoho typedef struct aml_resource_address16
    379      1.1   jruoho {
    380      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    381      1.1   jruoho     AML_RESOURCE_ADDRESS_COMMON
    382      1.1   jruoho     UINT16                          Granularity;
    383      1.1   jruoho     UINT16                          Minimum;
    384      1.1   jruoho     UINT16                          Maximum;
    385      1.1   jruoho     UINT16                          TranslationOffset;
    386      1.1   jruoho     UINT16                          AddressLength;
    387      1.1   jruoho 
    388      1.1   jruoho } AML_RESOURCE_ADDRESS16;
    389      1.1   jruoho 
    390      1.1   jruoho 
    391      1.1   jruoho typedef struct aml_resource_extended_irq
    392      1.1   jruoho {
    393      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    394      1.1   jruoho     UINT8                           Flags;
    395      1.1   jruoho     UINT8                           InterruptCount;
    396      1.1   jruoho     UINT32                          Interrupts[1];
    397      1.1   jruoho     /* ResSourceIndex, ResSource optional fields follow */
    398      1.1   jruoho 
    399      1.1   jruoho } AML_RESOURCE_EXTENDED_IRQ;
    400      1.1   jruoho 
    401      1.1   jruoho 
    402      1.1   jruoho typedef struct aml_resource_generic_register
    403      1.1   jruoho {
    404      1.1   jruoho     AML_RESOURCE_LARGE_HEADER_COMMON
    405      1.1   jruoho     UINT8                           AddressSpaceId;
    406      1.1   jruoho     UINT8                           BitWidth;
    407      1.1   jruoho     UINT8                           BitOffset;
    408      1.1   jruoho     UINT8                           AccessSize; /* ACPI 3.0, was previously Reserved */
    409      1.1   jruoho     UINT64                          Address;
    410      1.1   jruoho 
    411      1.1   jruoho } AML_RESOURCE_GENERIC_REGISTER;
    412      1.1   jruoho 
    413      1.1   jruoho 
    414      1.2    kamil /* Common descriptor for GpioInt and GpioIo (ACPI 5.0) */
    415      1.2    kamil 
    416      1.2    kamil typedef struct aml_resource_gpio
    417      1.2    kamil {
    418      1.2    kamil     AML_RESOURCE_LARGE_HEADER_COMMON
    419      1.2    kamil     UINT8                           RevisionId;
    420      1.2    kamil     UINT8                           ConnectionType;
    421      1.2    kamil     UINT16                          Flags;
    422      1.2    kamil     UINT16                          IntFlags;
    423      1.2    kamil     UINT8                           PinConfig;
    424      1.2    kamil     UINT16                          DriveStrength;
    425      1.2    kamil     UINT16                          DebounceTimeout;
    426      1.2    kamil     UINT16                          PinTableOffset;
    427      1.2    kamil     UINT8                           ResSourceIndex;
    428      1.2    kamil     UINT16                          ResSourceOffset;
    429      1.2    kamil     UINT16                          VendorOffset;
    430      1.2    kamil     UINT16                          VendorLength;
    431      1.2    kamil     /*
    432      1.2    kamil      * Optional fields follow immediately:
    433      1.2    kamil      * 1) PIN list (Words)
    434      1.2    kamil      * 2) Resource Source String
    435      1.2    kamil      * 3) Vendor Data bytes
    436      1.2    kamil      */
    437      1.2    kamil 
    438      1.2    kamil } AML_RESOURCE_GPIO;
    439      1.2    kamil 
    440      1.2    kamil #define AML_RESOURCE_GPIO_REVISION              1       /* ACPI 5.0 */
    441      1.2    kamil 
    442      1.2    kamil /* Values for ConnectionType above */
    443      1.2    kamil 
    444      1.2    kamil #define AML_RESOURCE_GPIO_TYPE_INT              0
    445      1.2    kamil #define AML_RESOURCE_GPIO_TYPE_IO               1
    446      1.2    kamil #define AML_RESOURCE_MAX_GPIOTYPE               1
    447      1.2    kamil 
    448      1.2    kamil 
    449      1.2    kamil /* Common preamble for all serial descriptors (ACPI 5.0) */
    450      1.2    kamil 
    451      1.2    kamil #define AML_RESOURCE_SERIAL_COMMON \
    452      1.2    kamil     UINT8                           RevisionId; \
    453      1.2    kamil     UINT8                           ResSourceIndex; \
    454      1.2    kamil     UINT8                           Type; \
    455      1.2    kamil     UINT8                           Flags; \
    456      1.2    kamil     UINT16                          TypeSpecificFlags; \
    457      1.2    kamil     UINT8                           TypeRevisionId; \
    458      1.2    kamil     UINT16                          TypeDataLength; \
    459      1.2    kamil 
    460      1.2    kamil /* Values for the type field above */
    461      1.2    kamil 
    462      1.2    kamil #define AML_RESOURCE_I2C_SERIALBUSTYPE          1
    463      1.2    kamil #define AML_RESOURCE_SPI_SERIALBUSTYPE          2
    464      1.2    kamil #define AML_RESOURCE_UART_SERIALBUSTYPE         3
    465  1.3.6.1  thorpej #define AML_RESOURCE_CSI2_SERIALBUSTYPE         4
    466  1.3.6.1  thorpej #define AML_RESOURCE_MAX_SERIALBUSTYPE          4
    467      1.2    kamil #define AML_RESOURCE_VENDOR_SERIALBUSTYPE       192 /* Vendor defined is 0xC0-0xFF (NOT SUPPORTED) */
    468      1.2    kamil 
    469      1.2    kamil typedef struct aml_resource_common_serialbus
    470      1.2    kamil {
    471      1.2    kamil     AML_RESOURCE_LARGE_HEADER_COMMON
    472      1.2    kamil     AML_RESOURCE_SERIAL_COMMON
    473      1.2    kamil 
    474      1.2    kamil } AML_RESOURCE_COMMON_SERIALBUS;
    475      1.2    kamil 
    476  1.3.6.1  thorpej 
    477  1.3.6.1  thorpej typedef struct aml_resource_csi2_serialbus
    478  1.3.6.1  thorpej {
    479  1.3.6.1  thorpej     AML_RESOURCE_LARGE_HEADER_COMMON
    480  1.3.6.1  thorpej     AML_RESOURCE_SERIAL_COMMON
    481  1.3.6.1  thorpej 
    482  1.3.6.1  thorpej     /*
    483  1.3.6.1  thorpej      * Optional fields follow immediately:
    484  1.3.6.1  thorpej      * 1) Vendor Data bytes
    485  1.3.6.1  thorpej      * 2) Resource Source String
    486  1.3.6.1  thorpej      */
    487  1.3.6.1  thorpej 
    488  1.3.6.1  thorpej } AML_RESOURCE_CSI2_SERIALBUS;
    489  1.3.6.1  thorpej 
    490  1.3.6.1  thorpej #define AML_RESOURCE_CSI2_REVISION              1       /* ACPI 6.4 */
    491  1.3.6.1  thorpej #define AML_RESOURCE_CSI2_TYPE_REVISION         1       /* ACPI 6.4 */
    492  1.3.6.1  thorpej #define AML_RESOURCE_CSI2_MIN_DATA_LEN          0       /* ACPI 6.4 */
    493  1.3.6.1  thorpej 
    494      1.2    kamil typedef struct aml_resource_i2c_serialbus
    495      1.2    kamil {
    496      1.2    kamil     AML_RESOURCE_LARGE_HEADER_COMMON
    497      1.2    kamil     AML_RESOURCE_SERIAL_COMMON
    498      1.2    kamil     UINT32                          ConnectionSpeed;
    499      1.2    kamil     UINT16                          SlaveAddress;
    500      1.2    kamil     /*
    501      1.2    kamil      * Optional fields follow immediately:
    502      1.2    kamil      * 1) Vendor Data bytes
    503      1.2    kamil      * 2) Resource Source String
    504      1.2    kamil      */
    505      1.2    kamil 
    506      1.2    kamil } AML_RESOURCE_I2C_SERIALBUS;
    507      1.2    kamil 
    508      1.2    kamil #define AML_RESOURCE_I2C_REVISION               1       /* ACPI 5.0 */
    509      1.2    kamil #define AML_RESOURCE_I2C_TYPE_REVISION          1       /* ACPI 5.0 */
    510      1.2    kamil #define AML_RESOURCE_I2C_MIN_DATA_LEN           6
    511      1.2    kamil 
    512      1.2    kamil typedef struct aml_resource_spi_serialbus
    513      1.2    kamil {
    514      1.2    kamil     AML_RESOURCE_LARGE_HEADER_COMMON
    515      1.2    kamil     AML_RESOURCE_SERIAL_COMMON
    516      1.2    kamil     UINT32                          ConnectionSpeed;
    517      1.2    kamil     UINT8                           DataBitLength;
    518      1.2    kamil     UINT8                           ClockPhase;
    519      1.2    kamil     UINT8                           ClockPolarity;
    520      1.2    kamil     UINT16                          DeviceSelection;
    521      1.2    kamil     /*
    522      1.2    kamil      * Optional fields follow immediately:
    523      1.2    kamil      * 1) Vendor Data bytes
    524      1.2    kamil      * 2) Resource Source String
    525      1.2    kamil      */
    526      1.2    kamil 
    527      1.2    kamil } AML_RESOURCE_SPI_SERIALBUS;
    528      1.2    kamil 
    529      1.2    kamil #define AML_RESOURCE_SPI_REVISION               1       /* ACPI 5.0 */
    530      1.2    kamil #define AML_RESOURCE_SPI_TYPE_REVISION          1       /* ACPI 5.0 */
    531      1.2    kamil #define AML_RESOURCE_SPI_MIN_DATA_LEN           9
    532      1.2    kamil 
    533      1.2    kamil typedef struct aml_resource_uart_serialbus
    534      1.2    kamil {
    535      1.2    kamil     AML_RESOURCE_LARGE_HEADER_COMMON
    536      1.2    kamil     AML_RESOURCE_SERIAL_COMMON
    537      1.2    kamil     UINT32                          DefaultBaudRate;
    538      1.2    kamil     UINT16                          RxFifoSize;
    539      1.2    kamil     UINT16                          TxFifoSize;
    540      1.2    kamil     UINT8                           Parity;
    541      1.2    kamil     UINT8                           LinesEnabled;
    542      1.2    kamil     /*
    543      1.2    kamil      * Optional fields follow immediately:
    544      1.2    kamil      * 1) Vendor Data bytes
    545      1.2    kamil      * 2) Resource Source String
    546      1.2    kamil      */
    547      1.2    kamil 
    548      1.2    kamil } AML_RESOURCE_UART_SERIALBUS;
    549      1.2    kamil 
    550      1.2    kamil #define AML_RESOURCE_UART_REVISION              1       /* ACPI 5.0 */
    551      1.2    kamil #define AML_RESOURCE_UART_TYPE_REVISION         1       /* ACPI 5.0 */
    552      1.2    kamil #define AML_RESOURCE_UART_MIN_DATA_LEN          10
    553      1.2    kamil 
    554      1.2    kamil typedef struct aml_resource_pin_function
    555      1.2    kamil {
    556      1.2    kamil     AML_RESOURCE_LARGE_HEADER_COMMON
    557      1.2    kamil     UINT8                           RevisionId;
    558      1.2    kamil     UINT16                          Flags;
    559      1.2    kamil     UINT8                           PinConfig;
    560      1.2    kamil     UINT16                          FunctionNumber;
    561      1.2    kamil     UINT16                          PinTableOffset;
    562      1.2    kamil     UINT8                           ResSourceIndex;
    563      1.2    kamil     UINT16                          ResSourceOffset;
    564      1.2    kamil     UINT16                          VendorOffset;
    565      1.2    kamil     UINT16                          VendorLength;
    566      1.2    kamil     /*
    567      1.2    kamil      * Optional fields follow immediately:
    568      1.2    kamil      * 1) PIN list (Words)
    569      1.2    kamil      * 2) Resource Source String
    570      1.2    kamil      * 3) Vendor Data bytes
    571      1.2    kamil      */
    572      1.2    kamil 
    573      1.2    kamil } AML_RESOURCE_PIN_FUNCTION;
    574      1.2    kamil 
    575      1.2    kamil #define AML_RESOURCE_PIN_FUNCTION_REVISION      1       /* ACPI 6.2 */
    576      1.2    kamil 
    577      1.2    kamil typedef struct aml_resource_pin_config
    578      1.2    kamil {
    579      1.2    kamil     AML_RESOURCE_LARGE_HEADER_COMMON
    580      1.2    kamil     UINT8                           RevisionId;
    581      1.2    kamil     UINT16                          Flags;
    582      1.2    kamil     UINT8                           PinConfigType;
    583      1.2    kamil     UINT32                          PinConfigValue;
    584      1.2    kamil     UINT16                          PinTableOffset;
    585      1.2    kamil     UINT8                           ResSourceIndex;
    586      1.2    kamil     UINT16                          ResSourceOffset;
    587      1.2    kamil     UINT16                          VendorOffset;
    588      1.2    kamil     UINT16                          VendorLength;
    589      1.2    kamil     /*
    590      1.2    kamil      * Optional fields follow immediately:
    591      1.2    kamil      * 1) PIN list (Words)
    592      1.2    kamil      * 2) Resource Source String
    593      1.2    kamil      * 3) Vendor Data bytes
    594      1.2    kamil      */
    595      1.2    kamil 
    596      1.2    kamil } AML_RESOURCE_PIN_CONFIG;
    597      1.2    kamil 
    598      1.2    kamil #define AML_RESOURCE_PIN_CONFIG_REVISION      1       /* ACPI 6.2 */
    599      1.2    kamil 
    600      1.2    kamil typedef struct aml_resource_pin_group
    601      1.2    kamil {
    602      1.2    kamil     AML_RESOURCE_LARGE_HEADER_COMMON
    603      1.2    kamil     UINT8                           RevisionId;
    604      1.2    kamil     UINT16                          Flags;
    605      1.2    kamil     UINT16                          PinTableOffset;
    606      1.2    kamil     UINT16                          LabelOffset;
    607      1.2    kamil     UINT16                          VendorOffset;
    608      1.2    kamil     UINT16                          VendorLength;
    609      1.2    kamil     /*
    610      1.2    kamil      * Optional fields follow immediately:
    611      1.2    kamil      * 1) PIN list (Words)
    612      1.2    kamil      * 2) Resource Label String
    613      1.2    kamil      * 3) Vendor Data bytes
    614      1.2    kamil      */
    615      1.2    kamil 
    616      1.2    kamil } AML_RESOURCE_PIN_GROUP;
    617      1.2    kamil 
    618      1.2    kamil #define AML_RESOURCE_PIN_GROUP_REVISION      1       /* ACPI 6.2 */
    619      1.2    kamil 
    620      1.2    kamil typedef struct aml_resource_pin_group_function
    621      1.2    kamil {
    622      1.2    kamil     AML_RESOURCE_LARGE_HEADER_COMMON
    623      1.2    kamil     UINT8                           RevisionId;
    624      1.2    kamil     UINT16                          Flags;
    625      1.2    kamil     UINT16                          FunctionNumber;
    626      1.2    kamil     UINT8                           ResSourceIndex;
    627      1.2    kamil     UINT16                          ResSourceOffset;
    628      1.2    kamil     UINT16                          ResSourceLabelOffset;
    629      1.2    kamil     UINT16                          VendorOffset;
    630      1.2    kamil     UINT16                          VendorLength;
    631      1.2    kamil     /*
    632      1.2    kamil      * Optional fields follow immediately:
    633      1.2    kamil      * 1) Resource Source String
    634      1.2    kamil      * 2) Resource Source Label String
    635      1.2    kamil      * 3) Vendor Data bytes
    636      1.2    kamil      */
    637      1.2    kamil 
    638      1.2    kamil } AML_RESOURCE_PIN_GROUP_FUNCTION;
    639      1.2    kamil 
    640      1.2    kamil #define AML_RESOURCE_PIN_GROUP_FUNCTION_REVISION    1       /* ACPI 6.2 */
    641      1.2    kamil 
    642      1.2    kamil typedef struct aml_resource_pin_group_config
    643      1.2    kamil {
    644      1.2    kamil     AML_RESOURCE_LARGE_HEADER_COMMON
    645      1.2    kamil     UINT8                           RevisionId;
    646      1.2    kamil     UINT16                          Flags;
    647      1.2    kamil     UINT8                           PinConfigType;
    648      1.2    kamil     UINT32                          PinConfigValue;
    649      1.2    kamil     UINT8                           ResSourceIndex;
    650      1.2    kamil     UINT16                          ResSourceOffset;
    651      1.2    kamil     UINT16                          ResSourceLabelOffset;
    652      1.2    kamil     UINT16                          VendorOffset;
    653      1.2    kamil     UINT16                          VendorLength;
    654      1.2    kamil     /*
    655      1.2    kamil      * Optional fields follow immediately:
    656      1.2    kamil      * 1) Resource Source String
    657      1.2    kamil      * 2) Resource Source Label String
    658      1.2    kamil      * 3) Vendor Data bytes
    659      1.2    kamil      */
    660      1.2    kamil 
    661      1.2    kamil } AML_RESOURCE_PIN_GROUP_CONFIG;
    662      1.2    kamil 
    663      1.2    kamil #define AML_RESOURCE_PIN_GROUP_CONFIG_REVISION    1       /* ACPI 6.2 */
    664      1.1   jruoho 
    665      1.1   jruoho /* Union of all resource descriptors, so we can allocate the worst case */
    666      1.1   jruoho 
    667      1.1   jruoho typedef union aml_resource
    668      1.1   jruoho {
    669      1.1   jruoho     /* Descriptor headers */
    670      1.1   jruoho 
    671      1.1   jruoho     UINT8                                   DescriptorType;
    672      1.1   jruoho     AML_RESOURCE_SMALL_HEADER               SmallHeader;
    673      1.1   jruoho     AML_RESOURCE_LARGE_HEADER               LargeHeader;
    674      1.1   jruoho 
    675      1.1   jruoho     /* Small resource descriptors */
    676      1.1   jruoho 
    677      1.1   jruoho     AML_RESOURCE_IRQ                        Irq;
    678      1.1   jruoho     AML_RESOURCE_DMA                        Dma;
    679      1.1   jruoho     AML_RESOURCE_START_DEPENDENT            StartDpf;
    680      1.1   jruoho     AML_RESOURCE_END_DEPENDENT              EndDpf;
    681      1.1   jruoho     AML_RESOURCE_IO                         Io;
    682      1.1   jruoho     AML_RESOURCE_FIXED_IO                   FixedIo;
    683      1.2    kamil     AML_RESOURCE_FIXED_DMA                  FixedDma;
    684      1.1   jruoho     AML_RESOURCE_VENDOR_SMALL               VendorSmall;
    685      1.1   jruoho     AML_RESOURCE_END_TAG                    EndTag;
    686      1.1   jruoho 
    687      1.1   jruoho     /* Large resource descriptors */
    688      1.1   jruoho 
    689      1.1   jruoho     AML_RESOURCE_MEMORY24                   Memory24;
    690      1.1   jruoho     AML_RESOURCE_GENERIC_REGISTER           GenericReg;
    691      1.1   jruoho     AML_RESOURCE_VENDOR_LARGE               VendorLarge;
    692      1.1   jruoho     AML_RESOURCE_MEMORY32                   Memory32;
    693      1.1   jruoho     AML_RESOURCE_FIXED_MEMORY32             FixedMemory32;
    694      1.1   jruoho     AML_RESOURCE_ADDRESS16                  Address16;
    695      1.1   jruoho     AML_RESOURCE_ADDRESS32                  Address32;
    696      1.1   jruoho     AML_RESOURCE_ADDRESS64                  Address64;
    697      1.1   jruoho     AML_RESOURCE_EXTENDED_ADDRESS64         ExtAddress64;
    698      1.1   jruoho     AML_RESOURCE_EXTENDED_IRQ               ExtendedIrq;
    699      1.2    kamil     AML_RESOURCE_GPIO                       Gpio;
    700      1.2    kamil     AML_RESOURCE_I2C_SERIALBUS              I2cSerialBus;
    701      1.2    kamil     AML_RESOURCE_SPI_SERIALBUS              SpiSerialBus;
    702      1.2    kamil     AML_RESOURCE_UART_SERIALBUS             UartSerialBus;
    703  1.3.6.1  thorpej     AML_RESOURCE_CSI2_SERIALBUS             Csi2SerialBus;
    704      1.2    kamil     AML_RESOURCE_COMMON_SERIALBUS           CommonSerialBus;
    705      1.2    kamil     AML_RESOURCE_PIN_FUNCTION               PinFunction;
    706      1.2    kamil     AML_RESOURCE_PIN_CONFIG                 PinConfig;
    707      1.2    kamil     AML_RESOURCE_PIN_GROUP                  PinGroup;
    708      1.2    kamil     AML_RESOURCE_PIN_GROUP_FUNCTION         PinGroupFunction;
    709      1.2    kamil     AML_RESOURCE_PIN_GROUP_CONFIG           PinGroupConfig;
    710      1.1   jruoho 
    711      1.1   jruoho     /* Utility overlays */
    712      1.1   jruoho 
    713      1.1   jruoho     AML_RESOURCE_ADDRESS                    Address;
    714      1.1   jruoho     UINT32                                  DwordItem;
    715      1.1   jruoho     UINT16                                  WordItem;
    716      1.1   jruoho     UINT8                                   ByteItem;
    717      1.1   jruoho 
    718      1.1   jruoho } AML_RESOURCE;
    719      1.1   jruoho 
    720      1.2    kamil /* restore default alignment */
    721      1.2    kamil 
    722      1.2    kamil #pragma pack()
    723      1.2    kamil 
    724      1.2    kamil /* Interfaces used by both the disassembler and compiler */
    725      1.2    kamil 
    726      1.2    kamil void
    727      1.2    kamil MpSaveGpioInfo (
    728      1.2    kamil     ACPI_PARSE_OBJECT       *Op,
    729      1.2    kamil     AML_RESOURCE            *Resource,
    730      1.2    kamil     UINT32                  PinCount,
    731      1.2    kamil     UINT16                  *PinList,
    732      1.2    kamil     char                    *DeviceName);
    733      1.2    kamil 
    734      1.2    kamil void
    735      1.2    kamil MpSaveSerialInfo (
    736      1.2    kamil     ACPI_PARSE_OBJECT       *Op,
    737      1.2    kamil     AML_RESOURCE            *Resource,
    738      1.2    kamil     char                    *DeviceName);
    739      1.2    kamil 
    740      1.2    kamil char *
    741      1.2    kamil MpGetHidFromParseTree (
    742      1.2    kamil     ACPI_NAMESPACE_NODE     *HidNode);
    743      1.2    kamil 
    744      1.2    kamil char *
    745      1.2    kamil MpGetHidViaNamestring (
    746      1.2    kamil     char                    *DeviceName);
    747      1.2    kamil 
    748      1.2    kamil char *
    749      1.2    kamil MpGetConnectionInfo (
    750      1.2    kamil     ACPI_PARSE_OBJECT       *Op,
    751      1.2    kamil     UINT32                  PinIndex,
    752      1.2    kamil     ACPI_NAMESPACE_NODE     **TargetNode,
    753      1.2    kamil     char                    **TargetName);
    754      1.2    kamil 
    755      1.2    kamil char *
    756      1.2    kamil MpGetParentDeviceHid (
    757      1.2    kamil     ACPI_PARSE_OBJECT       *Op,
    758      1.2    kamil     ACPI_NAMESPACE_NODE     **TargetNode,
    759      1.2    kamil     char                    **ParentDeviceName);
    760      1.2    kamil 
    761      1.2    kamil char *
    762      1.2    kamil MpGetDdnValue (
    763      1.2    kamil     char                    *DeviceName);
    764      1.2    kamil 
    765      1.2    kamil char *
    766      1.2    kamil MpGetHidValue (
    767      1.2    kamil     ACPI_NAMESPACE_NODE     *DeviceNode);
    768      1.2    kamil 
    769      1.1   jruoho #endif
    770