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