Home | History | Annotate | Line # | Download | only in include
acnamesp.h revision 1.4
      1 /******************************************************************************
      2  *
      3  * Name: acnamesp.h - Namespace subcomponent prototypes and defines
      4  *
      5  *****************************************************************************/
      6 
      7 /*
      8  * Copyright (C) 2000 - 2013, 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 __ACNAMESP_H__
     45 #define __ACNAMESP_H__
     46 
     47 
     48 /* To search the entire name space, pass this as SearchBase */
     49 
     50 #define ACPI_NS_ALL                 ((ACPI_HANDLE)0)
     51 
     52 /*
     53  * Elements of AcpiNsProperties are bit significant
     54  * and should be one-to-one with values of ACPI_OBJECT_TYPE
     55  */
     56 #define ACPI_NS_NORMAL              0
     57 #define ACPI_NS_NEWSCOPE            1   /* a definition of this type opens a name scope */
     58 #define ACPI_NS_LOCAL               2   /* suppress search of enclosing scopes */
     59 
     60 /* Flags for AcpiNsLookup, AcpiNsSearchAndEnter */
     61 
     62 #define ACPI_NS_NO_UPSEARCH         0
     63 #define ACPI_NS_SEARCH_PARENT       0x01
     64 #define ACPI_NS_DONT_OPEN_SCOPE     0x02
     65 #define ACPI_NS_NO_PEER_SEARCH      0x04
     66 #define ACPI_NS_ERROR_IF_FOUND      0x08
     67 #define ACPI_NS_PREFIX_IS_SCOPE     0x10
     68 #define ACPI_NS_EXTERNAL            0x20
     69 #define ACPI_NS_TEMPORARY           0x40
     70 
     71 /* Flags for AcpiNsWalkNamespace */
     72 
     73 #define ACPI_NS_WALK_NO_UNLOCK      0
     74 #define ACPI_NS_WALK_UNLOCK         0x01
     75 #define ACPI_NS_WALK_TEMP_NODES     0x02
     76 
     77 /* Object is not a package element */
     78 
     79 #define ACPI_NOT_PACKAGE_ELEMENT    ACPI_UINT32_MAX
     80 
     81 /* Always emit warning message, not dependent on node flags */
     82 
     83 #define ACPI_WARN_ALWAYS            0
     84 
     85 
     86 /*
     87  * nsinit - Namespace initialization
     88  */
     89 ACPI_STATUS
     90 AcpiNsInitializeObjects (
     91     void);
     92 
     93 ACPI_STATUS
     94 AcpiNsInitializeDevices (
     95     void);
     96 
     97 
     98 /*
     99  * nsload -  Namespace loading
    100  */
    101 ACPI_STATUS
    102 AcpiNsLoadNamespace (
    103     void);
    104 
    105 ACPI_STATUS
    106 AcpiNsLoadTable (
    107     UINT32                  TableIndex,
    108     ACPI_NAMESPACE_NODE     *Node);
    109 
    110 
    111 /*
    112  * nswalk - walk the namespace
    113  */
    114 ACPI_STATUS
    115 AcpiNsWalkNamespace (
    116     ACPI_OBJECT_TYPE        Type,
    117     ACPI_HANDLE             StartObject,
    118     UINT32                  MaxDepth,
    119     UINT32                  Flags,
    120     ACPI_WALK_CALLBACK      DescendingCallback,
    121     ACPI_WALK_CALLBACK      AscendingCallback,
    122     void                    *Context,
    123     void                    **ReturnValue);
    124 
    125 ACPI_NAMESPACE_NODE *
    126 AcpiNsGetNextNode (
    127     ACPI_NAMESPACE_NODE     *Parent,
    128     ACPI_NAMESPACE_NODE     *Child);
    129 
    130 ACPI_NAMESPACE_NODE *
    131 AcpiNsGetNextNodeTyped (
    132     ACPI_OBJECT_TYPE        Type,
    133     ACPI_NAMESPACE_NODE     *Parent,
    134     ACPI_NAMESPACE_NODE     *Child);
    135 
    136 /*
    137  * nsparse - table parsing
    138  */
    139 ACPI_STATUS
    140 AcpiNsParseTable (
    141     UINT32                  TableIndex,
    142     ACPI_NAMESPACE_NODE     *StartNode);
    143 
    144 ACPI_STATUS
    145 AcpiNsOneCompleteParse (
    146     UINT32                  PassNumber,
    147     UINT32                  TableIndex,
    148     ACPI_NAMESPACE_NODE     *StartNode);
    149 
    150 
    151 /*
    152  * nsaccess - Top-level namespace access
    153  */
    154 ACPI_STATUS
    155 AcpiNsRootInitialize (
    156     void);
    157 
    158 ACPI_STATUS
    159 AcpiNsLookup (
    160     ACPI_GENERIC_STATE      *ScopeInfo,
    161     char                    *Name,
    162     ACPI_OBJECT_TYPE        Type,
    163     ACPI_INTERPRETER_MODE   InterpreterMode,
    164     UINT32                  Flags,
    165     ACPI_WALK_STATE         *WalkState,
    166     ACPI_NAMESPACE_NODE     **RetNode);
    167 
    168 
    169 /*
    170  * nsalloc - Named object allocation/deallocation
    171  */
    172 ACPI_NAMESPACE_NODE *
    173 AcpiNsCreateNode (
    174     UINT32                  Name);
    175 
    176 void
    177 AcpiNsDeleteNode (
    178     ACPI_NAMESPACE_NODE     *Node);
    179 
    180 void
    181 AcpiNsRemoveNode (
    182     ACPI_NAMESPACE_NODE     *Node);
    183 
    184 void
    185 AcpiNsDeleteNamespaceSubtree (
    186     ACPI_NAMESPACE_NODE     *ParentHandle);
    187 
    188 void
    189 AcpiNsDeleteNamespaceByOwner (
    190     ACPI_OWNER_ID           OwnerId);
    191 
    192 void
    193 AcpiNsDetachObject (
    194     ACPI_NAMESPACE_NODE     *Node);
    195 
    196 void
    197 AcpiNsDeleteChildren (
    198     ACPI_NAMESPACE_NODE     *Parent);
    199 
    200 int
    201 AcpiNsCompareNames (
    202     char                    *Name1,
    203     char                    *Name2);
    204 
    205 
    206 /*
    207  * nsconvert - Dynamic object conversion routines
    208  */
    209 ACPI_STATUS
    210 AcpiNsConvertToInteger (
    211     ACPI_OPERAND_OBJECT     *OriginalObject,
    212     ACPI_OPERAND_OBJECT     **ReturnObject);
    213 
    214 ACPI_STATUS
    215 AcpiNsConvertToString (
    216     ACPI_OPERAND_OBJECT     *OriginalObject,
    217     ACPI_OPERAND_OBJECT     **ReturnObject);
    218 
    219 ACPI_STATUS
    220 AcpiNsConvertToBuffer (
    221     ACPI_OPERAND_OBJECT     *OriginalObject,
    222     ACPI_OPERAND_OBJECT     **ReturnObject);
    223 
    224 ACPI_STATUS
    225 AcpiNsConvertToUnicode (
    226     ACPI_OPERAND_OBJECT     *OriginalObject,
    227     ACPI_OPERAND_OBJECT     **ReturnObject);
    228 
    229 ACPI_STATUS
    230 AcpiNsConvertToResource (
    231     ACPI_OPERAND_OBJECT     *OriginalObject,
    232     ACPI_OPERAND_OBJECT     **ReturnObject);
    233 
    234 
    235 /*
    236  * nsdump - Namespace dump/print utilities
    237  */
    238 void
    239 AcpiNsDumpTables (
    240     ACPI_HANDLE             SearchBase,
    241     UINT32                  MaxDepth);
    242 
    243 void
    244 AcpiNsDumpEntry (
    245     ACPI_HANDLE             Handle,
    246     UINT32                  DebugLevel);
    247 
    248 void
    249 AcpiNsDumpPathname (
    250     ACPI_HANDLE             Handle,
    251     const char              *Msg,
    252     UINT32                  Level,
    253     UINT32                  Component);
    254 
    255 void
    256 AcpiNsPrintPathname (
    257     UINT32                  NumSegments,
    258     char                    *Pathname);
    259 
    260 ACPI_STATUS
    261 AcpiNsDumpOneObject (
    262     ACPI_HANDLE             ObjHandle,
    263     UINT32                  Level,
    264     void                    *Context,
    265     void                    **ReturnValue);
    266 
    267 void
    268 AcpiNsDumpObjects (
    269     ACPI_OBJECT_TYPE        Type,
    270     UINT8                   DisplayType,
    271     UINT32                  MaxDepth,
    272     ACPI_OWNER_ID           OwnerId,
    273     ACPI_HANDLE             StartHandle);
    274 
    275 void
    276 AcpiNsDumpObjectPaths (
    277     ACPI_OBJECT_TYPE        Type,
    278     UINT8                   DisplayType,
    279     UINT32                  MaxDepth,
    280     ACPI_OWNER_ID           OwnerId,
    281     ACPI_HANDLE             StartHandle);
    282 
    283 
    284 /*
    285  * nseval - Namespace evaluation functions
    286  */
    287 ACPI_STATUS
    288 AcpiNsEvaluate (
    289     ACPI_EVALUATE_INFO      *Info);
    290 
    291 void
    292 AcpiNsExecModuleCodeList (
    293     void);
    294 
    295 
    296 /*
    297  * nsarguments - Argument count/type checking for predefined/reserved names
    298  */
    299 void
    300 AcpiNsCheckArgumentCount (
    301     char                        *Pathname,
    302     ACPI_NAMESPACE_NODE         *Node,
    303     UINT32                      UserParamCount,
    304     const ACPI_PREDEFINED_INFO  *Info);
    305 
    306 void
    307 AcpiNsCheckAcpiCompliance (
    308     char                        *Pathname,
    309     ACPI_NAMESPACE_NODE         *Node,
    310     const ACPI_PREDEFINED_INFO  *Predefined);
    311 
    312 void
    313 AcpiNsCheckArgumentTypes (
    314     ACPI_EVALUATE_INFO          *Info);
    315 
    316 
    317 /*
    318  * nspredef - Return value checking for predefined/reserved names
    319  */
    320 ACPI_STATUS
    321 AcpiNsCheckReturnValue (
    322     ACPI_NAMESPACE_NODE         *Node,
    323     ACPI_EVALUATE_INFO          *Info,
    324     UINT32                      UserParamCount,
    325     ACPI_STATUS                 ReturnStatus,
    326     ACPI_OPERAND_OBJECT         **ReturnObject);
    327 
    328 ACPI_STATUS
    329 AcpiNsCheckObjectType (
    330     ACPI_EVALUATE_INFO          *Info,
    331     ACPI_OPERAND_OBJECT         **ReturnObjectPtr,
    332     UINT32                      ExpectedBtypes,
    333     UINT32                      PackageIndex);
    334 
    335 
    336 /*
    337  * nsprepkg - Validation of predefined name packages
    338  */
    339 ACPI_STATUS
    340 AcpiNsCheckPackage (
    341     ACPI_EVALUATE_INFO          *Info,
    342     ACPI_OPERAND_OBJECT         **ReturnObjectPtr);
    343 
    344 
    345 /*
    346  * nsnames - Name and Scope manipulation
    347  */
    348 UINT32
    349 AcpiNsOpensScope (
    350     ACPI_OBJECT_TYPE        Type);
    351 
    352 ACPI_STATUS
    353 AcpiNsBuildExternalPath (
    354     ACPI_NAMESPACE_NODE     *Node,
    355     ACPI_SIZE               Size,
    356     char                    *NameBuffer);
    357 
    358 char *
    359 AcpiNsGetExternalPathname (
    360     ACPI_NAMESPACE_NODE     *Node);
    361 
    362 char *
    363 AcpiNsNameOfCurrentScope (
    364     ACPI_WALK_STATE         *WalkState);
    365 
    366 ACPI_STATUS
    367 AcpiNsHandleToPathname (
    368     ACPI_HANDLE             TargetHandle,
    369     ACPI_BUFFER             *Buffer);
    370 
    371 BOOLEAN
    372 AcpiNsPatternMatch (
    373     ACPI_NAMESPACE_NODE     *ObjNode,
    374     char                    *SearchFor);
    375 
    376 ACPI_STATUS
    377 AcpiNsGetNode (
    378     ACPI_NAMESPACE_NODE     *PrefixNode,
    379     const char              *ExternalPathname,
    380     UINT32                  Flags,
    381     ACPI_NAMESPACE_NODE     **OutNode);
    382 
    383 ACPI_SIZE
    384 AcpiNsGetPathnameLength (
    385     ACPI_NAMESPACE_NODE     *Node);
    386 
    387 
    388 /*
    389  * nsobject - Object management for namespace nodes
    390  */
    391 ACPI_STATUS
    392 AcpiNsAttachObject (
    393     ACPI_NAMESPACE_NODE     *Node,
    394     ACPI_OPERAND_OBJECT     *Object,
    395     ACPI_OBJECT_TYPE        Type);
    396 
    397 ACPI_OPERAND_OBJECT *
    398 AcpiNsGetAttachedObject (
    399     ACPI_NAMESPACE_NODE     *Node);
    400 
    401 ACPI_OPERAND_OBJECT *
    402 AcpiNsGetSecondaryObject (
    403     ACPI_OPERAND_OBJECT     *ObjDesc);
    404 
    405 ACPI_STATUS
    406 AcpiNsAttachData (
    407     ACPI_NAMESPACE_NODE     *Node,
    408     ACPI_OBJECT_HANDLER     Handler,
    409     void                    *Data);
    410 
    411 ACPI_STATUS
    412 AcpiNsDetachData (
    413     ACPI_NAMESPACE_NODE     *Node,
    414     ACPI_OBJECT_HANDLER     Handler);
    415 
    416 ACPI_STATUS
    417 AcpiNsGetAttachedData (
    418     ACPI_NAMESPACE_NODE     *Node,
    419     ACPI_OBJECT_HANDLER     Handler,
    420     void                    **Data);
    421 
    422 
    423 /*
    424  * nsrepair - General return object repair for all
    425  * predefined methods/objects
    426  */
    427 ACPI_STATUS
    428 AcpiNsSimpleRepair (
    429     ACPI_EVALUATE_INFO      *Info,
    430     UINT32                  ExpectedBtypes,
    431     UINT32                  PackageIndex,
    432     ACPI_OPERAND_OBJECT     **ReturnObjectPtr);
    433 
    434 ACPI_STATUS
    435 AcpiNsWrapWithPackage (
    436     ACPI_EVALUATE_INFO      *Info,
    437     ACPI_OPERAND_OBJECT     *OriginalObject,
    438     ACPI_OPERAND_OBJECT     **ObjDescPtr);
    439 
    440 ACPI_STATUS
    441 AcpiNsRepairNullElement (
    442     ACPI_EVALUATE_INFO      *Info,
    443     UINT32                  ExpectedBtypes,
    444     UINT32                  PackageIndex,
    445     ACPI_OPERAND_OBJECT     **ReturnObjectPtr);
    446 
    447 void
    448 AcpiNsRemoveNullElements (
    449     ACPI_EVALUATE_INFO      *Info,
    450     UINT8                   PackageType,
    451     ACPI_OPERAND_OBJECT     *ObjDesc);
    452 
    453 
    454 /*
    455  * nsrepair2 - Return object repair for specific
    456  * predefined methods/objects
    457  */
    458 ACPI_STATUS
    459 AcpiNsComplexRepairs (
    460     ACPI_EVALUATE_INFO      *Info,
    461     ACPI_NAMESPACE_NODE     *Node,
    462     ACPI_STATUS             ValidateStatus,
    463     ACPI_OPERAND_OBJECT     **ReturnObjectPtr);
    464 
    465 
    466 /*
    467  * nssearch - Namespace searching and entry
    468  */
    469 ACPI_STATUS
    470 AcpiNsSearchAndEnter (
    471     UINT32                  EntryName,
    472     ACPI_WALK_STATE         *WalkState,
    473     ACPI_NAMESPACE_NODE     *Node,
    474     ACPI_INTERPRETER_MODE   InterpreterMode,
    475     ACPI_OBJECT_TYPE        Type,
    476     UINT32                  Flags,
    477     ACPI_NAMESPACE_NODE     **RetNode);
    478 
    479 ACPI_STATUS
    480 AcpiNsSearchOneScope (
    481     UINT32                  EntryName,
    482     ACPI_NAMESPACE_NODE     *Node,
    483     ACPI_OBJECT_TYPE        Type,
    484     ACPI_NAMESPACE_NODE     **RetNode);
    485 
    486 void
    487 AcpiNsInstallNode (
    488     ACPI_WALK_STATE         *WalkState,
    489     ACPI_NAMESPACE_NODE     *ParentNode,
    490     ACPI_NAMESPACE_NODE     *Node,
    491     ACPI_OBJECT_TYPE        Type);
    492 
    493 
    494 /*
    495  * nsutils - Utility functions
    496  */
    497 ACPI_OBJECT_TYPE
    498 AcpiNsGetType (
    499     ACPI_NAMESPACE_NODE     *Node);
    500 
    501 UINT32
    502 AcpiNsLocal (
    503     ACPI_OBJECT_TYPE        Type);
    504 
    505 void
    506 AcpiNsPrintNodePathname (
    507     ACPI_NAMESPACE_NODE     *Node,
    508     const char              *Msg);
    509 
    510 ACPI_STATUS
    511 AcpiNsBuildInternalName (
    512     ACPI_NAMESTRING_INFO    *Info);
    513 
    514 void
    515 AcpiNsGetInternalNameLength (
    516     ACPI_NAMESTRING_INFO    *Info);
    517 
    518 ACPI_STATUS
    519 AcpiNsInternalizeName (
    520     const char              *DottedName,
    521     char                    **ConvertedName);
    522 
    523 ACPI_STATUS
    524 AcpiNsExternalizeName (
    525     UINT32                  InternalNameLength,
    526     const char              *InternalName,
    527     UINT32                  *ConvertedNameLength,
    528     char                    **ConvertedName);
    529 
    530 ACPI_NAMESPACE_NODE *
    531 AcpiNsValidateHandle (
    532     ACPI_HANDLE             Handle);
    533 
    534 void
    535 AcpiNsTerminate (
    536     void);
    537 
    538 #endif /* __ACNAMESP_H__ */
    539