xref: /dflybsd-src/sys/contrib/dev/acpica/source/include/acparser.h (revision e5e174adcc2678e90a7ffbe469dfe34d9989aa09)
10d02842fSSascha Wildner /******************************************************************************
20d02842fSSascha Wildner  *
30d02842fSSascha Wildner  * Module Name: acparser.h - AML Parser subcomponent prototypes and defines
40d02842fSSascha Wildner  *
50d02842fSSascha Wildner  *****************************************************************************/
60d02842fSSascha Wildner 
70d02842fSSascha Wildner /*
8f5f76cf2SSascha Wildner  * Copyright (C) 2000 - 2016, Intel Corp.
90d02842fSSascha Wildner  * All rights reserved.
100d02842fSSascha Wildner  *
110d02842fSSascha Wildner  * Redistribution and use in source and binary forms, with or without
120d02842fSSascha Wildner  * modification, are permitted provided that the following conditions
130d02842fSSascha Wildner  * are met:
140d02842fSSascha Wildner  * 1. Redistributions of source code must retain the above copyright
150d02842fSSascha Wildner  *    notice, this list of conditions, and the following disclaimer,
160d02842fSSascha Wildner  *    without modification.
170d02842fSSascha Wildner  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
180d02842fSSascha Wildner  *    substantially similar to the "NO WARRANTY" disclaimer below
190d02842fSSascha Wildner  *    ("Disclaimer") and any redistribution must be conditioned upon
200d02842fSSascha Wildner  *    including a substantially similar Disclaimer requirement for further
210d02842fSSascha Wildner  *    binary redistribution.
220d02842fSSascha Wildner  * 3. Neither the names of the above-listed copyright holders nor the names
230d02842fSSascha Wildner  *    of any contributors may be used to endorse or promote products derived
240d02842fSSascha Wildner  *    from this software without specific prior written permission.
250d02842fSSascha Wildner  *
260d02842fSSascha Wildner  * Alternatively, this software may be distributed under the terms of the
270d02842fSSascha Wildner  * GNU General Public License ("GPL") version 2 as published by the Free
280d02842fSSascha Wildner  * Software Foundation.
290d02842fSSascha Wildner  *
300d02842fSSascha Wildner  * NO WARRANTY
310d02842fSSascha Wildner  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
320d02842fSSascha Wildner  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
330d02842fSSascha Wildner  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
340d02842fSSascha Wildner  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
350d02842fSSascha Wildner  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
360d02842fSSascha Wildner  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
370d02842fSSascha Wildner  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
380d02842fSSascha Wildner  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
390d02842fSSascha Wildner  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
400d02842fSSascha Wildner  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
410d02842fSSascha Wildner  * POSSIBILITY OF SUCH DAMAGES.
420d02842fSSascha Wildner  */
430d02842fSSascha Wildner 
440d02842fSSascha Wildner #ifndef __ACPARSER_H__
450d02842fSSascha Wildner #define __ACPARSER_H__
460d02842fSSascha Wildner 
470d02842fSSascha Wildner 
480d02842fSSascha Wildner #define OP_HAS_RETURN_VALUE             1
490d02842fSSascha Wildner 
500d02842fSSascha Wildner /* Variable number of arguments. This field must be 32 bits */
510d02842fSSascha Wildner 
520d02842fSSascha Wildner #define ACPI_VAR_ARGS                   ACPI_UINT32_MAX
530d02842fSSascha Wildner 
540d02842fSSascha Wildner 
550d02842fSSascha Wildner #define ACPI_PARSE_DELETE_TREE          0x0001
560d02842fSSascha Wildner #define ACPI_PARSE_NO_TREE_DELETE       0x0000
570d02842fSSascha Wildner #define ACPI_PARSE_TREE_MASK            0x0001
580d02842fSSascha Wildner 
590d02842fSSascha Wildner #define ACPI_PARSE_LOAD_PASS1           0x0010
600d02842fSSascha Wildner #define ACPI_PARSE_LOAD_PASS2           0x0020
610d02842fSSascha Wildner #define ACPI_PARSE_EXECUTE              0x0030
620d02842fSSascha Wildner #define ACPI_PARSE_MODE_MASK            0x0030
630d02842fSSascha Wildner 
640d02842fSSascha Wildner #define ACPI_PARSE_DEFERRED_OP          0x0100
650d02842fSSascha Wildner #define ACPI_PARSE_DISASSEMBLE          0x0200
660d02842fSSascha Wildner 
670d02842fSSascha Wildner #define ACPI_PARSE_MODULE_LEVEL         0x0400
680d02842fSSascha Wildner 
690d02842fSSascha Wildner /******************************************************************************
700d02842fSSascha Wildner  *
710d02842fSSascha Wildner  * Parser interfaces
720d02842fSSascha Wildner  *
730d02842fSSascha Wildner  *****************************************************************************/
740d02842fSSascha Wildner 
75896f2e3aSSascha Wildner extern const UINT8      AcpiGbl_ShortOpIndex[];
76896f2e3aSSascha Wildner extern const UINT8      AcpiGbl_LongOpIndex[];
77896f2e3aSSascha Wildner 
780d02842fSSascha Wildner 
790d02842fSSascha Wildner /*
800d02842fSSascha Wildner  * psxface - Parser external interfaces
810d02842fSSascha Wildner  */
820d02842fSSascha Wildner ACPI_STATUS
830d02842fSSascha Wildner AcpiPsExecuteMethod (
840d02842fSSascha Wildner     ACPI_EVALUATE_INFO      *Info);
850d02842fSSascha Wildner 
86*e5e174adSSascha Wildner ACPI_STATUS
87*e5e174adSSascha Wildner AcpiPsExecuteTable (
88*e5e174adSSascha Wildner     ACPI_EVALUATE_INFO      *Info);
89*e5e174adSSascha Wildner 
900d02842fSSascha Wildner 
910d02842fSSascha Wildner /*
920d02842fSSascha Wildner  * psargs - Parse AML opcode arguments
930d02842fSSascha Wildner  */
940d02842fSSascha Wildner UINT8 *
950d02842fSSascha Wildner AcpiPsGetNextPackageEnd (
960d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState);
970d02842fSSascha Wildner 
980d02842fSSascha Wildner char *
990d02842fSSascha Wildner AcpiPsGetNextNamestring (
1000d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState);
1010d02842fSSascha Wildner 
1020d02842fSSascha Wildner void
1030d02842fSSascha Wildner AcpiPsGetNextSimpleArg (
1040d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
1050d02842fSSascha Wildner     UINT32                  ArgType,
1060d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Arg);
1070d02842fSSascha Wildner 
1080d02842fSSascha Wildner ACPI_STATUS
1090d02842fSSascha Wildner AcpiPsGetNextNamepath (
1100d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1110d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
1120d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Arg,
113f5f76cf2SSascha Wildner     BOOLEAN                 PossibleMethodCall);
114f5f76cf2SSascha Wildner 
115f5f76cf2SSascha Wildner /* Values for BOOLEAN above */
116f5f76cf2SSascha Wildner 
117f5f76cf2SSascha Wildner #define ACPI_NOT_METHOD_CALL            FALSE
118f5f76cf2SSascha Wildner #define ACPI_POSSIBLE_METHOD_CALL       TRUE
1190d02842fSSascha Wildner 
1200d02842fSSascha Wildner ACPI_STATUS
1210d02842fSSascha Wildner AcpiPsGetNextArg (
1220d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1230d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
1240d02842fSSascha Wildner     UINT32                  ArgType,
1250d02842fSSascha Wildner     ACPI_PARSE_OBJECT       **ReturnArg);
1260d02842fSSascha Wildner 
1270d02842fSSascha Wildner 
1280d02842fSSascha Wildner /*
1290d02842fSSascha Wildner  * psfind
1300d02842fSSascha Wildner  */
1310d02842fSSascha Wildner ACPI_PARSE_OBJECT *
1320d02842fSSascha Wildner AcpiPsFindName (
1330d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Scope,
1340d02842fSSascha Wildner     UINT32                  Name,
1350d02842fSSascha Wildner     UINT32                  Opcode);
1360d02842fSSascha Wildner 
1370d02842fSSascha Wildner ACPI_PARSE_OBJECT*
1380d02842fSSascha Wildner AcpiPsGetParent (
1390d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
1400d02842fSSascha Wildner 
1410d02842fSSascha Wildner 
1420d02842fSSascha Wildner /*
1430d02842fSSascha Wildner  * psobject - support for parse object processing
1440d02842fSSascha Wildner  */
1450d02842fSSascha Wildner ACPI_STATUS
1460d02842fSSascha Wildner AcpiPsBuildNamedOp (
1470d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1480d02842fSSascha Wildner     UINT8                   *AmlOpStart,
1490d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *UnnamedOp,
1500d02842fSSascha Wildner     ACPI_PARSE_OBJECT       **Op);
1510d02842fSSascha Wildner 
1520d02842fSSascha Wildner ACPI_STATUS
1530d02842fSSascha Wildner AcpiPsCreateOp (
1540d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1550d02842fSSascha Wildner     UINT8                   *AmlOpStart,
1560d02842fSSascha Wildner     ACPI_PARSE_OBJECT       **NewOp);
1570d02842fSSascha Wildner 
1580d02842fSSascha Wildner ACPI_STATUS
1590d02842fSSascha Wildner AcpiPsCompleteOp (
1600d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1610d02842fSSascha Wildner     ACPI_PARSE_OBJECT       **Op,
1620d02842fSSascha Wildner     ACPI_STATUS             Status);
1630d02842fSSascha Wildner 
1640d02842fSSascha Wildner ACPI_STATUS
1650d02842fSSascha Wildner AcpiPsCompleteFinalOp (
1660d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1670d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op,
1680d02842fSSascha Wildner     ACPI_STATUS             Status);
1690d02842fSSascha Wildner 
1700d02842fSSascha Wildner 
1710d02842fSSascha Wildner /*
1720d02842fSSascha Wildner  * psopinfo - AML Opcode information
1730d02842fSSascha Wildner  */
1740d02842fSSascha Wildner const ACPI_OPCODE_INFO *
1750d02842fSSascha Wildner AcpiPsGetOpcodeInfo (
1760d02842fSSascha Wildner     UINT16                  Opcode);
1770d02842fSSascha Wildner 
1782ffe9f16SSascha Wildner const char *
1790d02842fSSascha Wildner AcpiPsGetOpcodeName (
1800d02842fSSascha Wildner     UINT16                  Opcode);
1810d02842fSSascha Wildner 
1820d02842fSSascha Wildner UINT8
1830d02842fSSascha Wildner AcpiPsGetArgumentCount (
1840d02842fSSascha Wildner     UINT32                  OpType);
1850d02842fSSascha Wildner 
1860d02842fSSascha Wildner 
1870d02842fSSascha Wildner /*
1880d02842fSSascha Wildner  * psparse - top level parsing routines
1890d02842fSSascha Wildner  */
1900d02842fSSascha Wildner ACPI_STATUS
1910d02842fSSascha Wildner AcpiPsParseAml (
1920d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState);
1930d02842fSSascha Wildner 
1940d02842fSSascha Wildner UINT32
1950d02842fSSascha Wildner AcpiPsGetOpcodeSize (
1960d02842fSSascha Wildner     UINT32                  Opcode);
1970d02842fSSascha Wildner 
1980d02842fSSascha Wildner UINT16
1990d02842fSSascha Wildner AcpiPsPeekOpcode (
2000d02842fSSascha Wildner     ACPI_PARSE_STATE        *state);
2010d02842fSSascha Wildner 
2020d02842fSSascha Wildner ACPI_STATUS
2030d02842fSSascha Wildner AcpiPsCompleteThisOp (
2040d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
2050d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
2060d02842fSSascha Wildner 
2070d02842fSSascha Wildner ACPI_STATUS
2080d02842fSSascha Wildner AcpiPsNextParseState (
2090d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
2100d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op,
2110d02842fSSascha Wildner     ACPI_STATUS             CallbackStatus);
2120d02842fSSascha Wildner 
2130d02842fSSascha Wildner 
2140d02842fSSascha Wildner /*
2150d02842fSSascha Wildner  * psloop - main parse loop
2160d02842fSSascha Wildner  */
2170d02842fSSascha Wildner ACPI_STATUS
2180d02842fSSascha Wildner AcpiPsParseLoop (
2190d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState);
2200d02842fSSascha Wildner 
2210d02842fSSascha Wildner 
2220d02842fSSascha Wildner /*
2230d02842fSSascha Wildner  * psscope - Scope stack management routines
2240d02842fSSascha Wildner  */
2250d02842fSSascha Wildner ACPI_STATUS
2260d02842fSSascha Wildner AcpiPsInitScope (
2270d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
2280d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Root);
2290d02842fSSascha Wildner 
2300d02842fSSascha Wildner ACPI_PARSE_OBJECT *
2310d02842fSSascha Wildner AcpiPsGetParentScope (
2320d02842fSSascha Wildner     ACPI_PARSE_STATE        *state);
2330d02842fSSascha Wildner 
2340d02842fSSascha Wildner BOOLEAN
2350d02842fSSascha Wildner AcpiPsHasCompletedScope (
2360d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState);
2370d02842fSSascha Wildner 
2380d02842fSSascha Wildner void
2390d02842fSSascha Wildner AcpiPsPopScope (
2400d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
2410d02842fSSascha Wildner     ACPI_PARSE_OBJECT       **Op,
2420d02842fSSascha Wildner     UINT32                  *ArgList,
2430d02842fSSascha Wildner     UINT32                  *ArgCount);
2440d02842fSSascha Wildner 
2450d02842fSSascha Wildner ACPI_STATUS
2460d02842fSSascha Wildner AcpiPsPushScope (
2470d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
2480d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op,
2490d02842fSSascha Wildner     UINT32                  RemainingArgs,
2500d02842fSSascha Wildner     UINT32                  ArgCount);
2510d02842fSSascha Wildner 
2520d02842fSSascha Wildner void
2530d02842fSSascha Wildner AcpiPsCleanupScope (
2540d02842fSSascha Wildner     ACPI_PARSE_STATE        *state);
2550d02842fSSascha Wildner 
2560d02842fSSascha Wildner 
2570d02842fSSascha Wildner /*
2580d02842fSSascha Wildner  * pstree - parse tree manipulation routines
2590d02842fSSascha Wildner  */
2600d02842fSSascha Wildner void
2610d02842fSSascha Wildner AcpiPsAppendArg(
2620d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op,
2630d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *arg);
2640d02842fSSascha Wildner 
2650d02842fSSascha Wildner ACPI_PARSE_OBJECT*
2660d02842fSSascha Wildner AcpiPsFind (
2670d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Scope,
2680d02842fSSascha Wildner     char                    *Path,
2690d02842fSSascha Wildner     UINT16                  Opcode,
2700d02842fSSascha Wildner     UINT32                  Create);
2710d02842fSSascha Wildner 
2720d02842fSSascha Wildner ACPI_PARSE_OBJECT *
2730d02842fSSascha Wildner AcpiPsGetArg(
2740d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op,
2750d02842fSSascha Wildner     UINT32                   argn);
2760d02842fSSascha Wildner 
2770d02842fSSascha Wildner ACPI_PARSE_OBJECT *
2780d02842fSSascha Wildner AcpiPsGetDepthNext (
2790d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Origin,
2800d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
2810d02842fSSascha Wildner 
2820d02842fSSascha Wildner 
2830d02842fSSascha Wildner /*
2840d02842fSSascha Wildner  * pswalk - parse tree walk routines
2850d02842fSSascha Wildner  */
2860d02842fSSascha Wildner ACPI_STATUS
2870d02842fSSascha Wildner AcpiPsWalkParsedAml (
2880d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *StartOp,
2890d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *EndOp,
2900d02842fSSascha Wildner     ACPI_OPERAND_OBJECT     *MthDesc,
2910d02842fSSascha Wildner     ACPI_NAMESPACE_NODE     *StartNode,
2920d02842fSSascha Wildner     ACPI_OPERAND_OBJECT     **Params,
2930d02842fSSascha Wildner     ACPI_OPERAND_OBJECT     **CallerReturnDesc,
2940d02842fSSascha Wildner     ACPI_OWNER_ID           OwnerId,
2950d02842fSSascha Wildner     ACPI_PARSE_DOWNWARDS    DescendingCallback,
2960d02842fSSascha Wildner     ACPI_PARSE_UPWARDS      AscendingCallback);
2970d02842fSSascha Wildner 
2980d02842fSSascha Wildner ACPI_STATUS
2990d02842fSSascha Wildner AcpiPsGetNextWalkOp (
3000d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
3010d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op,
3020d02842fSSascha Wildner     ACPI_PARSE_UPWARDS      AscendingCallback);
3030d02842fSSascha Wildner 
3040d02842fSSascha Wildner ACPI_STATUS
3050d02842fSSascha Wildner AcpiPsDeleteCompletedOp (
3060d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState);
3070d02842fSSascha Wildner 
3080d02842fSSascha Wildner void
3090d02842fSSascha Wildner AcpiPsDeleteParseTree (
3100d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *root);
3110d02842fSSascha Wildner 
3120d02842fSSascha Wildner 
3130d02842fSSascha Wildner /*
3140d02842fSSascha Wildner  * psutils - parser utilities
3150d02842fSSascha Wildner  */
3160d02842fSSascha Wildner ACPI_PARSE_OBJECT *
3170d02842fSSascha Wildner AcpiPsCreateScopeOp (
318267c04fdSSascha Wildner     UINT8                   *Aml);
3190d02842fSSascha Wildner 
3200d02842fSSascha Wildner void
3210d02842fSSascha Wildner AcpiPsInitOp (
3220d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op,
3230d02842fSSascha Wildner     UINT16                  opcode);
3240d02842fSSascha Wildner 
3250d02842fSSascha Wildner ACPI_PARSE_OBJECT *
3260d02842fSSascha Wildner AcpiPsAllocOp (
327267c04fdSSascha Wildner     UINT16                  Opcode,
328267c04fdSSascha Wildner     UINT8                   *Aml);
3290d02842fSSascha Wildner 
3300d02842fSSascha Wildner void
3310d02842fSSascha Wildner AcpiPsFreeOp (
3320d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
3330d02842fSSascha Wildner 
3340d02842fSSascha Wildner BOOLEAN
3350d02842fSSascha Wildner AcpiPsIsLeadingChar (
3360d02842fSSascha Wildner     UINT32                  c);
3370d02842fSSascha Wildner 
3380d02842fSSascha Wildner UINT32
3390d02842fSSascha Wildner AcpiPsGetName(
3400d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op);
3410d02842fSSascha Wildner 
3420d02842fSSascha Wildner void
3430d02842fSSascha Wildner AcpiPsSetName(
3440d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op,
3450d02842fSSascha Wildner     UINT32                  name);
3460d02842fSSascha Wildner 
3470d02842fSSascha Wildner 
3480d02842fSSascha Wildner /*
3490d02842fSSascha Wildner  * psdump - display parser tree
3500d02842fSSascha Wildner  */
3510d02842fSSascha Wildner UINT32
3520d02842fSSascha Wildner AcpiPsSprintPath (
3530d02842fSSascha Wildner     char                    *BufferStart,
3540d02842fSSascha Wildner     UINT32                  BufferSize,
3550d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
3560d02842fSSascha Wildner 
3570d02842fSSascha Wildner UINT32
3580d02842fSSascha Wildner AcpiPsSprintOp (
3590d02842fSSascha Wildner     char                    *BufferStart,
3600d02842fSSascha Wildner     UINT32                  BufferSize,
3610d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
3620d02842fSSascha Wildner 
3630d02842fSSascha Wildner void
3640d02842fSSascha Wildner AcpiPsShow (
3650d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op);
3660d02842fSSascha Wildner 
3670d02842fSSascha Wildner 
3680d02842fSSascha Wildner #endif /* __ACPARSER_H__ */
369