xref: /dflybsd-src/sys/contrib/dev/acpica/source/include/acparser.h (revision 2ffe9f16c64a590bc6653e0284f95075c1319abb)
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 
860d02842fSSascha Wildner 
870d02842fSSascha Wildner /*
880d02842fSSascha Wildner  * psargs - Parse AML opcode arguments
890d02842fSSascha Wildner  */
900d02842fSSascha Wildner UINT8 *
910d02842fSSascha Wildner AcpiPsGetNextPackageEnd (
920d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState);
930d02842fSSascha Wildner 
940d02842fSSascha Wildner char *
950d02842fSSascha Wildner AcpiPsGetNextNamestring (
960d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState);
970d02842fSSascha Wildner 
980d02842fSSascha Wildner void
990d02842fSSascha Wildner AcpiPsGetNextSimpleArg (
1000d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
1010d02842fSSascha Wildner     UINT32                  ArgType,
1020d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Arg);
1030d02842fSSascha Wildner 
1040d02842fSSascha Wildner ACPI_STATUS
1050d02842fSSascha Wildner AcpiPsGetNextNamepath (
1060d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1070d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
1080d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Arg,
109f5f76cf2SSascha Wildner     BOOLEAN                 PossibleMethodCall);
110f5f76cf2SSascha Wildner 
111f5f76cf2SSascha Wildner /* Values for BOOLEAN above */
112f5f76cf2SSascha Wildner 
113f5f76cf2SSascha Wildner #define ACPI_NOT_METHOD_CALL            FALSE
114f5f76cf2SSascha Wildner #define ACPI_POSSIBLE_METHOD_CALL       TRUE
1150d02842fSSascha Wildner 
1160d02842fSSascha Wildner ACPI_STATUS
1170d02842fSSascha Wildner AcpiPsGetNextArg (
1180d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1190d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
1200d02842fSSascha Wildner     UINT32                  ArgType,
1210d02842fSSascha Wildner     ACPI_PARSE_OBJECT       **ReturnArg);
1220d02842fSSascha Wildner 
1230d02842fSSascha Wildner 
1240d02842fSSascha Wildner /*
1250d02842fSSascha Wildner  * psfind
1260d02842fSSascha Wildner  */
1270d02842fSSascha Wildner ACPI_PARSE_OBJECT *
1280d02842fSSascha Wildner AcpiPsFindName (
1290d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Scope,
1300d02842fSSascha Wildner     UINT32                  Name,
1310d02842fSSascha Wildner     UINT32                  Opcode);
1320d02842fSSascha Wildner 
1330d02842fSSascha Wildner ACPI_PARSE_OBJECT*
1340d02842fSSascha Wildner AcpiPsGetParent (
1350d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
1360d02842fSSascha Wildner 
1370d02842fSSascha Wildner 
1380d02842fSSascha Wildner /*
1390d02842fSSascha Wildner  * psobject - support for parse object processing
1400d02842fSSascha Wildner  */
1410d02842fSSascha Wildner ACPI_STATUS
1420d02842fSSascha Wildner AcpiPsBuildNamedOp (
1430d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1440d02842fSSascha Wildner     UINT8                   *AmlOpStart,
1450d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *UnnamedOp,
1460d02842fSSascha Wildner     ACPI_PARSE_OBJECT       **Op);
1470d02842fSSascha Wildner 
1480d02842fSSascha Wildner ACPI_STATUS
1490d02842fSSascha Wildner AcpiPsCreateOp (
1500d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1510d02842fSSascha Wildner     UINT8                   *AmlOpStart,
1520d02842fSSascha Wildner     ACPI_PARSE_OBJECT       **NewOp);
1530d02842fSSascha Wildner 
1540d02842fSSascha Wildner ACPI_STATUS
1550d02842fSSascha Wildner AcpiPsCompleteOp (
1560d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1570d02842fSSascha Wildner     ACPI_PARSE_OBJECT       **Op,
1580d02842fSSascha Wildner     ACPI_STATUS             Status);
1590d02842fSSascha Wildner 
1600d02842fSSascha Wildner ACPI_STATUS
1610d02842fSSascha Wildner AcpiPsCompleteFinalOp (
1620d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
1630d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op,
1640d02842fSSascha Wildner     ACPI_STATUS             Status);
1650d02842fSSascha Wildner 
1660d02842fSSascha Wildner 
1670d02842fSSascha Wildner /*
1680d02842fSSascha Wildner  * psopinfo - AML Opcode information
1690d02842fSSascha Wildner  */
1700d02842fSSascha Wildner const ACPI_OPCODE_INFO *
1710d02842fSSascha Wildner AcpiPsGetOpcodeInfo (
1720d02842fSSascha Wildner     UINT16                  Opcode);
1730d02842fSSascha Wildner 
174*2ffe9f16SSascha Wildner const char *
1750d02842fSSascha Wildner AcpiPsGetOpcodeName (
1760d02842fSSascha Wildner     UINT16                  Opcode);
1770d02842fSSascha Wildner 
1780d02842fSSascha Wildner UINT8
1790d02842fSSascha Wildner AcpiPsGetArgumentCount (
1800d02842fSSascha Wildner     UINT32                  OpType);
1810d02842fSSascha Wildner 
1820d02842fSSascha Wildner 
1830d02842fSSascha Wildner /*
1840d02842fSSascha Wildner  * psparse - top level parsing routines
1850d02842fSSascha Wildner  */
1860d02842fSSascha Wildner ACPI_STATUS
1870d02842fSSascha Wildner AcpiPsParseAml (
1880d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState);
1890d02842fSSascha Wildner 
1900d02842fSSascha Wildner UINT32
1910d02842fSSascha Wildner AcpiPsGetOpcodeSize (
1920d02842fSSascha Wildner     UINT32                  Opcode);
1930d02842fSSascha Wildner 
1940d02842fSSascha Wildner UINT16
1950d02842fSSascha Wildner AcpiPsPeekOpcode (
1960d02842fSSascha Wildner     ACPI_PARSE_STATE        *state);
1970d02842fSSascha Wildner 
1980d02842fSSascha Wildner ACPI_STATUS
1990d02842fSSascha Wildner AcpiPsCompleteThisOp (
2000d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
2010d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
2020d02842fSSascha Wildner 
2030d02842fSSascha Wildner ACPI_STATUS
2040d02842fSSascha Wildner AcpiPsNextParseState (
2050d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
2060d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op,
2070d02842fSSascha Wildner     ACPI_STATUS             CallbackStatus);
2080d02842fSSascha Wildner 
2090d02842fSSascha Wildner 
2100d02842fSSascha Wildner /*
2110d02842fSSascha Wildner  * psloop - main parse loop
2120d02842fSSascha Wildner  */
2130d02842fSSascha Wildner ACPI_STATUS
2140d02842fSSascha Wildner AcpiPsParseLoop (
2150d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState);
2160d02842fSSascha Wildner 
2170d02842fSSascha Wildner 
2180d02842fSSascha Wildner /*
2190d02842fSSascha Wildner  * psscope - Scope stack management routines
2200d02842fSSascha Wildner  */
2210d02842fSSascha Wildner ACPI_STATUS
2220d02842fSSascha Wildner AcpiPsInitScope (
2230d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
2240d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Root);
2250d02842fSSascha Wildner 
2260d02842fSSascha Wildner ACPI_PARSE_OBJECT *
2270d02842fSSascha Wildner AcpiPsGetParentScope (
2280d02842fSSascha Wildner     ACPI_PARSE_STATE        *state);
2290d02842fSSascha Wildner 
2300d02842fSSascha Wildner BOOLEAN
2310d02842fSSascha Wildner AcpiPsHasCompletedScope (
2320d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState);
2330d02842fSSascha Wildner 
2340d02842fSSascha Wildner void
2350d02842fSSascha Wildner AcpiPsPopScope (
2360d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
2370d02842fSSascha Wildner     ACPI_PARSE_OBJECT       **Op,
2380d02842fSSascha Wildner     UINT32                  *ArgList,
2390d02842fSSascha Wildner     UINT32                  *ArgCount);
2400d02842fSSascha Wildner 
2410d02842fSSascha Wildner ACPI_STATUS
2420d02842fSSascha Wildner AcpiPsPushScope (
2430d02842fSSascha Wildner     ACPI_PARSE_STATE        *ParserState,
2440d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op,
2450d02842fSSascha Wildner     UINT32                  RemainingArgs,
2460d02842fSSascha Wildner     UINT32                  ArgCount);
2470d02842fSSascha Wildner 
2480d02842fSSascha Wildner void
2490d02842fSSascha Wildner AcpiPsCleanupScope (
2500d02842fSSascha Wildner     ACPI_PARSE_STATE        *state);
2510d02842fSSascha Wildner 
2520d02842fSSascha Wildner 
2530d02842fSSascha Wildner /*
2540d02842fSSascha Wildner  * pstree - parse tree manipulation routines
2550d02842fSSascha Wildner  */
2560d02842fSSascha Wildner void
2570d02842fSSascha Wildner AcpiPsAppendArg(
2580d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op,
2590d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *arg);
2600d02842fSSascha Wildner 
2610d02842fSSascha Wildner ACPI_PARSE_OBJECT*
2620d02842fSSascha Wildner AcpiPsFind (
2630d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Scope,
2640d02842fSSascha Wildner     char                    *Path,
2650d02842fSSascha Wildner     UINT16                  Opcode,
2660d02842fSSascha Wildner     UINT32                  Create);
2670d02842fSSascha Wildner 
2680d02842fSSascha Wildner ACPI_PARSE_OBJECT *
2690d02842fSSascha Wildner AcpiPsGetArg(
2700d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op,
2710d02842fSSascha Wildner     UINT32                   argn);
2720d02842fSSascha Wildner 
2730d02842fSSascha Wildner ACPI_PARSE_OBJECT *
2740d02842fSSascha Wildner AcpiPsGetDepthNext (
2750d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Origin,
2760d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
2770d02842fSSascha Wildner 
2780d02842fSSascha Wildner 
2790d02842fSSascha Wildner /*
2800d02842fSSascha Wildner  * pswalk - parse tree walk routines
2810d02842fSSascha Wildner  */
2820d02842fSSascha Wildner ACPI_STATUS
2830d02842fSSascha Wildner AcpiPsWalkParsedAml (
2840d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *StartOp,
2850d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *EndOp,
2860d02842fSSascha Wildner     ACPI_OPERAND_OBJECT     *MthDesc,
2870d02842fSSascha Wildner     ACPI_NAMESPACE_NODE     *StartNode,
2880d02842fSSascha Wildner     ACPI_OPERAND_OBJECT     **Params,
2890d02842fSSascha Wildner     ACPI_OPERAND_OBJECT     **CallerReturnDesc,
2900d02842fSSascha Wildner     ACPI_OWNER_ID           OwnerId,
2910d02842fSSascha Wildner     ACPI_PARSE_DOWNWARDS    DescendingCallback,
2920d02842fSSascha Wildner     ACPI_PARSE_UPWARDS      AscendingCallback);
2930d02842fSSascha Wildner 
2940d02842fSSascha Wildner ACPI_STATUS
2950d02842fSSascha Wildner AcpiPsGetNextWalkOp (
2960d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState,
2970d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op,
2980d02842fSSascha Wildner     ACPI_PARSE_UPWARDS      AscendingCallback);
2990d02842fSSascha Wildner 
3000d02842fSSascha Wildner ACPI_STATUS
3010d02842fSSascha Wildner AcpiPsDeleteCompletedOp (
3020d02842fSSascha Wildner     ACPI_WALK_STATE         *WalkState);
3030d02842fSSascha Wildner 
3040d02842fSSascha Wildner void
3050d02842fSSascha Wildner AcpiPsDeleteParseTree (
3060d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *root);
3070d02842fSSascha Wildner 
3080d02842fSSascha Wildner 
3090d02842fSSascha Wildner /*
3100d02842fSSascha Wildner  * psutils - parser utilities
3110d02842fSSascha Wildner  */
3120d02842fSSascha Wildner ACPI_PARSE_OBJECT *
3130d02842fSSascha Wildner AcpiPsCreateScopeOp (
314267c04fdSSascha Wildner     UINT8                   *Aml);
3150d02842fSSascha Wildner 
3160d02842fSSascha Wildner void
3170d02842fSSascha Wildner AcpiPsInitOp (
3180d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op,
3190d02842fSSascha Wildner     UINT16                  opcode);
3200d02842fSSascha Wildner 
3210d02842fSSascha Wildner ACPI_PARSE_OBJECT *
3220d02842fSSascha Wildner AcpiPsAllocOp (
323267c04fdSSascha Wildner     UINT16                  Opcode,
324267c04fdSSascha Wildner     UINT8                   *Aml);
3250d02842fSSascha Wildner 
3260d02842fSSascha Wildner void
3270d02842fSSascha Wildner AcpiPsFreeOp (
3280d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
3290d02842fSSascha Wildner 
3300d02842fSSascha Wildner BOOLEAN
3310d02842fSSascha Wildner AcpiPsIsLeadingChar (
3320d02842fSSascha Wildner     UINT32                  c);
3330d02842fSSascha Wildner 
3340d02842fSSascha Wildner UINT32
3350d02842fSSascha Wildner AcpiPsGetName(
3360d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op);
3370d02842fSSascha Wildner 
3380d02842fSSascha Wildner void
3390d02842fSSascha Wildner AcpiPsSetName(
3400d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op,
3410d02842fSSascha Wildner     UINT32                  name);
3420d02842fSSascha Wildner 
3430d02842fSSascha Wildner 
3440d02842fSSascha Wildner /*
3450d02842fSSascha Wildner  * psdump - display parser tree
3460d02842fSSascha Wildner  */
3470d02842fSSascha Wildner UINT32
3480d02842fSSascha Wildner AcpiPsSprintPath (
3490d02842fSSascha Wildner     char                    *BufferStart,
3500d02842fSSascha Wildner     UINT32                  BufferSize,
3510d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
3520d02842fSSascha Wildner 
3530d02842fSSascha Wildner UINT32
3540d02842fSSascha Wildner AcpiPsSprintOp (
3550d02842fSSascha Wildner     char                    *BufferStart,
3560d02842fSSascha Wildner     UINT32                  BufferSize,
3570d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op);
3580d02842fSSascha Wildner 
3590d02842fSSascha Wildner void
3600d02842fSSascha Wildner AcpiPsShow (
3610d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *op);
3620d02842fSSascha Wildner 
3630d02842fSSascha Wildner 
3640d02842fSSascha Wildner #endif /* __ACPARSER_H__ */
365