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