1a9f12690SJung-uk Kim /****************************************************************************** 2a9f12690SJung-uk Kim * 3a9f12690SJung-uk Kim * Module Name: acparser.h - AML Parser subcomponent prototypes and defines 4a9f12690SJung-uk Kim * 5a9f12690SJung-uk Kim *****************************************************************************/ 6a9f12690SJung-uk Kim 7d244b227SJung-uk Kim /* 8f8146b88SJung-uk Kim * Copyright (C) 2000 - 2016, Intel Corp. 9a9f12690SJung-uk Kim * All rights reserved. 10a9f12690SJung-uk Kim * 11d244b227SJung-uk Kim * Redistribution and use in source and binary forms, with or without 12d244b227SJung-uk Kim * modification, are permitted provided that the following conditions 13d244b227SJung-uk Kim * are met: 14d244b227SJung-uk Kim * 1. Redistributions of source code must retain the above copyright 15d244b227SJung-uk Kim * notice, this list of conditions, and the following disclaimer, 16d244b227SJung-uk Kim * without modification. 17d244b227SJung-uk Kim * 2. Redistributions in binary form must reproduce at minimum a disclaimer 18d244b227SJung-uk Kim * substantially similar to the "NO WARRANTY" disclaimer below 19d244b227SJung-uk Kim * ("Disclaimer") and any redistribution must be conditioned upon 20d244b227SJung-uk Kim * including a substantially similar Disclaimer requirement for further 21d244b227SJung-uk Kim * binary redistribution. 22d244b227SJung-uk Kim * 3. Neither the names of the above-listed copyright holders nor the names 23d244b227SJung-uk Kim * of any contributors may be used to endorse or promote products derived 24d244b227SJung-uk Kim * from this software without specific prior written permission. 25a9f12690SJung-uk Kim * 26d244b227SJung-uk Kim * Alternatively, this software may be distributed under the terms of the 27d244b227SJung-uk Kim * GNU General Public License ("GPL") version 2 as published by the Free 28d244b227SJung-uk Kim * Software Foundation. 29a9f12690SJung-uk Kim * 30d244b227SJung-uk Kim * NO WARRANTY 31d244b227SJung-uk Kim * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 32d244b227SJung-uk Kim * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 33d244b227SJung-uk Kim * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR 34d244b227SJung-uk Kim * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 35d244b227SJung-uk Kim * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 36d244b227SJung-uk Kim * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 37d244b227SJung-uk Kim * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 38d244b227SJung-uk Kim * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 39d244b227SJung-uk Kim * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 40d244b227SJung-uk Kim * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 41d244b227SJung-uk Kim * POSSIBILITY OF SUCH DAMAGES. 42d244b227SJung-uk Kim */ 43a9f12690SJung-uk Kim 44a9f12690SJung-uk Kim #ifndef __ACPARSER_H__ 45a9f12690SJung-uk Kim #define __ACPARSER_H__ 46a9f12690SJung-uk Kim 47a9f12690SJung-uk Kim 48a9f12690SJung-uk Kim #define OP_HAS_RETURN_VALUE 1 49a9f12690SJung-uk Kim 50a9f12690SJung-uk Kim /* Variable number of arguments. This field must be 32 bits */ 51a9f12690SJung-uk Kim 52a9f12690SJung-uk Kim #define ACPI_VAR_ARGS ACPI_UINT32_MAX 53a9f12690SJung-uk Kim 54a9f12690SJung-uk Kim 55a9f12690SJung-uk Kim #define ACPI_PARSE_DELETE_TREE 0x0001 56a9f12690SJung-uk Kim #define ACPI_PARSE_NO_TREE_DELETE 0x0000 57a9f12690SJung-uk Kim #define ACPI_PARSE_TREE_MASK 0x0001 58a9f12690SJung-uk Kim 59a9f12690SJung-uk Kim #define ACPI_PARSE_LOAD_PASS1 0x0010 60a9f12690SJung-uk Kim #define ACPI_PARSE_LOAD_PASS2 0x0020 61a9f12690SJung-uk Kim #define ACPI_PARSE_EXECUTE 0x0030 62a9f12690SJung-uk Kim #define ACPI_PARSE_MODE_MASK 0x0030 63a9f12690SJung-uk Kim 64a9f12690SJung-uk Kim #define ACPI_PARSE_DEFERRED_OP 0x0100 65a9f12690SJung-uk Kim #define ACPI_PARSE_DISASSEMBLE 0x0200 66a9f12690SJung-uk Kim 67d6dd1baeSJung-uk Kim #define ACPI_PARSE_MODULE_LEVEL 0x0400 68a9f12690SJung-uk Kim 69a9f12690SJung-uk Kim /****************************************************************************** 70a9f12690SJung-uk Kim * 71a9f12690SJung-uk Kim * Parser interfaces 72a9f12690SJung-uk Kim * 73a9f12690SJung-uk Kim *****************************************************************************/ 74a9f12690SJung-uk Kim 75a371a5fdSJung-uk Kim extern const UINT8 AcpiGbl_ShortOpIndex[]; 76a371a5fdSJung-uk Kim extern const UINT8 AcpiGbl_LongOpIndex[]; 77a371a5fdSJung-uk Kim 78a9f12690SJung-uk Kim 79a9f12690SJung-uk Kim /* 80a9f12690SJung-uk Kim * psxface - Parser external interfaces 81a9f12690SJung-uk Kim */ 82a9f12690SJung-uk Kim ACPI_STATUS 83a9f12690SJung-uk Kim AcpiPsExecuteMethod ( 84a9f12690SJung-uk Kim ACPI_EVALUATE_INFO *Info); 85a9f12690SJung-uk Kim 86*493deb39SJung-uk Kim ACPI_STATUS 87*493deb39SJung-uk Kim AcpiPsExecuteTable ( 88*493deb39SJung-uk Kim ACPI_EVALUATE_INFO *Info); 89*493deb39SJung-uk Kim 90a9f12690SJung-uk Kim 91a9f12690SJung-uk Kim /* 92a9f12690SJung-uk Kim * psargs - Parse AML opcode arguments 93a9f12690SJung-uk Kim */ 94a9f12690SJung-uk Kim UINT8 * 95a9f12690SJung-uk Kim AcpiPsGetNextPackageEnd ( 96a9f12690SJung-uk Kim ACPI_PARSE_STATE *ParserState); 97a9f12690SJung-uk Kim 98a9f12690SJung-uk Kim char * 99a9f12690SJung-uk Kim AcpiPsGetNextNamestring ( 100a9f12690SJung-uk Kim ACPI_PARSE_STATE *ParserState); 101a9f12690SJung-uk Kim 102a9f12690SJung-uk Kim void 103a9f12690SJung-uk Kim AcpiPsGetNextSimpleArg ( 104a9f12690SJung-uk Kim ACPI_PARSE_STATE *ParserState, 105a9f12690SJung-uk Kim UINT32 ArgType, 106a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Arg); 107a9f12690SJung-uk Kim 108a9f12690SJung-uk Kim ACPI_STATUS 109a9f12690SJung-uk Kim AcpiPsGetNextNamepath ( 110a9f12690SJung-uk Kim ACPI_WALK_STATE *WalkState, 111a9f12690SJung-uk Kim ACPI_PARSE_STATE *ParserState, 112a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Arg, 113f8146b88SJung-uk Kim BOOLEAN PossibleMethodCall); 114f8146b88SJung-uk Kim 115f8146b88SJung-uk Kim /* Values for BOOLEAN above */ 116f8146b88SJung-uk Kim 117f8146b88SJung-uk Kim #define ACPI_NOT_METHOD_CALL FALSE 118f8146b88SJung-uk Kim #define ACPI_POSSIBLE_METHOD_CALL TRUE 119a9f12690SJung-uk Kim 120a9f12690SJung-uk Kim ACPI_STATUS 121a9f12690SJung-uk Kim AcpiPsGetNextArg ( 122a9f12690SJung-uk Kim ACPI_WALK_STATE *WalkState, 123a9f12690SJung-uk Kim ACPI_PARSE_STATE *ParserState, 124a9f12690SJung-uk Kim UINT32 ArgType, 125a9f12690SJung-uk Kim ACPI_PARSE_OBJECT **ReturnArg); 126a9f12690SJung-uk Kim 127a9f12690SJung-uk Kim 128a9f12690SJung-uk Kim /* 129a9f12690SJung-uk Kim * psfind 130a9f12690SJung-uk Kim */ 131a9f12690SJung-uk Kim ACPI_PARSE_OBJECT * 132a9f12690SJung-uk Kim AcpiPsFindName ( 133a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Scope, 134a9f12690SJung-uk Kim UINT32 Name, 135a9f12690SJung-uk Kim UINT32 Opcode); 136a9f12690SJung-uk Kim 137a9f12690SJung-uk Kim ACPI_PARSE_OBJECT* 138a9f12690SJung-uk Kim AcpiPsGetParent ( 139a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Op); 140a9f12690SJung-uk Kim 141a9f12690SJung-uk Kim 142a9f12690SJung-uk Kim /* 143efcc2a30SJung-uk Kim * psobject - support for parse object processing 144efcc2a30SJung-uk Kim */ 145efcc2a30SJung-uk Kim ACPI_STATUS 146efcc2a30SJung-uk Kim AcpiPsBuildNamedOp ( 147efcc2a30SJung-uk Kim ACPI_WALK_STATE *WalkState, 148efcc2a30SJung-uk Kim UINT8 *AmlOpStart, 149efcc2a30SJung-uk Kim ACPI_PARSE_OBJECT *UnnamedOp, 150efcc2a30SJung-uk Kim ACPI_PARSE_OBJECT **Op); 151efcc2a30SJung-uk Kim 152efcc2a30SJung-uk Kim ACPI_STATUS 153efcc2a30SJung-uk Kim AcpiPsCreateOp ( 154efcc2a30SJung-uk Kim ACPI_WALK_STATE *WalkState, 155efcc2a30SJung-uk Kim UINT8 *AmlOpStart, 156efcc2a30SJung-uk Kim ACPI_PARSE_OBJECT **NewOp); 157efcc2a30SJung-uk Kim 158efcc2a30SJung-uk Kim ACPI_STATUS 159efcc2a30SJung-uk Kim AcpiPsCompleteOp ( 160efcc2a30SJung-uk Kim ACPI_WALK_STATE *WalkState, 161efcc2a30SJung-uk Kim ACPI_PARSE_OBJECT **Op, 162efcc2a30SJung-uk Kim ACPI_STATUS Status); 163efcc2a30SJung-uk Kim 164efcc2a30SJung-uk Kim ACPI_STATUS 165efcc2a30SJung-uk Kim AcpiPsCompleteFinalOp ( 166efcc2a30SJung-uk Kim ACPI_WALK_STATE *WalkState, 167efcc2a30SJung-uk Kim ACPI_PARSE_OBJECT *Op, 168efcc2a30SJung-uk Kim ACPI_STATUS Status); 169efcc2a30SJung-uk Kim 170efcc2a30SJung-uk Kim 171efcc2a30SJung-uk Kim /* 172efcc2a30SJung-uk Kim * psopinfo - AML Opcode information 173a9f12690SJung-uk Kim */ 174a9f12690SJung-uk Kim const ACPI_OPCODE_INFO * 175a9f12690SJung-uk Kim AcpiPsGetOpcodeInfo ( 176a9f12690SJung-uk Kim UINT16 Opcode); 177a9f12690SJung-uk Kim 178f8146b88SJung-uk Kim const char * 179a9f12690SJung-uk Kim AcpiPsGetOpcodeName ( 180a9f12690SJung-uk Kim UINT16 Opcode); 181a9f12690SJung-uk Kim 182a9f12690SJung-uk Kim UINT8 183a9f12690SJung-uk Kim AcpiPsGetArgumentCount ( 184a9f12690SJung-uk Kim UINT32 OpType); 185a9f12690SJung-uk Kim 186a9f12690SJung-uk Kim 187a9f12690SJung-uk Kim /* 188a9f12690SJung-uk Kim * psparse - top level parsing routines 189a9f12690SJung-uk Kim */ 190a9f12690SJung-uk Kim ACPI_STATUS 191a9f12690SJung-uk Kim AcpiPsParseAml ( 192a9f12690SJung-uk Kim ACPI_WALK_STATE *WalkState); 193a9f12690SJung-uk Kim 194a9f12690SJung-uk Kim UINT32 195a9f12690SJung-uk Kim AcpiPsGetOpcodeSize ( 196a9f12690SJung-uk Kim UINT32 Opcode); 197a9f12690SJung-uk Kim 198a9f12690SJung-uk Kim UINT16 199a9f12690SJung-uk Kim AcpiPsPeekOpcode ( 200a9f12690SJung-uk Kim ACPI_PARSE_STATE *state); 201a9f12690SJung-uk Kim 202a9f12690SJung-uk Kim ACPI_STATUS 203a9f12690SJung-uk Kim AcpiPsCompleteThisOp ( 204a9f12690SJung-uk Kim ACPI_WALK_STATE *WalkState, 205a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Op); 206a9f12690SJung-uk Kim 207a9f12690SJung-uk Kim ACPI_STATUS 208a9f12690SJung-uk Kim AcpiPsNextParseState ( 209a9f12690SJung-uk Kim ACPI_WALK_STATE *WalkState, 210a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Op, 211a9f12690SJung-uk Kim ACPI_STATUS CallbackStatus); 212a9f12690SJung-uk Kim 213a9f12690SJung-uk Kim 214a9f12690SJung-uk Kim /* 215a9f12690SJung-uk Kim * psloop - main parse loop 216a9f12690SJung-uk Kim */ 217a9f12690SJung-uk Kim ACPI_STATUS 218a9f12690SJung-uk Kim AcpiPsParseLoop ( 219a9f12690SJung-uk Kim ACPI_WALK_STATE *WalkState); 220a9f12690SJung-uk Kim 221a9f12690SJung-uk Kim 222a9f12690SJung-uk Kim /* 223a9f12690SJung-uk Kim * psscope - Scope stack management routines 224a9f12690SJung-uk Kim */ 225a9f12690SJung-uk Kim ACPI_STATUS 226a9f12690SJung-uk Kim AcpiPsInitScope ( 227a9f12690SJung-uk Kim ACPI_PARSE_STATE *ParserState, 228a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Root); 229a9f12690SJung-uk Kim 230a9f12690SJung-uk Kim ACPI_PARSE_OBJECT * 231a9f12690SJung-uk Kim AcpiPsGetParentScope ( 232a9f12690SJung-uk Kim ACPI_PARSE_STATE *state); 233a9f12690SJung-uk Kim 234a9f12690SJung-uk Kim BOOLEAN 235a9f12690SJung-uk Kim AcpiPsHasCompletedScope ( 236a9f12690SJung-uk Kim ACPI_PARSE_STATE *ParserState); 237a9f12690SJung-uk Kim 238a9f12690SJung-uk Kim void 239a9f12690SJung-uk Kim AcpiPsPopScope ( 240a9f12690SJung-uk Kim ACPI_PARSE_STATE *ParserState, 241a9f12690SJung-uk Kim ACPI_PARSE_OBJECT **Op, 242a9f12690SJung-uk Kim UINT32 *ArgList, 243a9f12690SJung-uk Kim UINT32 *ArgCount); 244a9f12690SJung-uk Kim 245a9f12690SJung-uk Kim ACPI_STATUS 246a9f12690SJung-uk Kim AcpiPsPushScope ( 247a9f12690SJung-uk Kim ACPI_PARSE_STATE *ParserState, 248a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Op, 249a9f12690SJung-uk Kim UINT32 RemainingArgs, 250a9f12690SJung-uk Kim UINT32 ArgCount); 251a9f12690SJung-uk Kim 252a9f12690SJung-uk Kim void 253a9f12690SJung-uk Kim AcpiPsCleanupScope ( 254a9f12690SJung-uk Kim ACPI_PARSE_STATE *state); 255a9f12690SJung-uk Kim 256a9f12690SJung-uk Kim 257a9f12690SJung-uk Kim /* 258a9f12690SJung-uk Kim * pstree - parse tree manipulation routines 259a9f12690SJung-uk Kim */ 260a9f12690SJung-uk Kim void 261a9f12690SJung-uk Kim AcpiPsAppendArg( 262a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *op, 263a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *arg); 264a9f12690SJung-uk Kim 265a9f12690SJung-uk Kim ACPI_PARSE_OBJECT* 266a9f12690SJung-uk Kim AcpiPsFind ( 267a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Scope, 268a9f12690SJung-uk Kim char *Path, 269a9f12690SJung-uk Kim UINT16 Opcode, 270a9f12690SJung-uk Kim UINT32 Create); 271a9f12690SJung-uk Kim 272a9f12690SJung-uk Kim ACPI_PARSE_OBJECT * 273a9f12690SJung-uk Kim AcpiPsGetArg( 274a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *op, 275a9f12690SJung-uk Kim UINT32 argn); 276a9f12690SJung-uk Kim 277a9f12690SJung-uk Kim ACPI_PARSE_OBJECT * 278a9f12690SJung-uk Kim AcpiPsGetDepthNext ( 279a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Origin, 280a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Op); 281a9f12690SJung-uk Kim 282a9f12690SJung-uk Kim 283a9f12690SJung-uk Kim /* 284a9f12690SJung-uk Kim * pswalk - parse tree walk routines 285a9f12690SJung-uk Kim */ 286a9f12690SJung-uk Kim ACPI_STATUS 287a9f12690SJung-uk Kim AcpiPsWalkParsedAml ( 288a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *StartOp, 289a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *EndOp, 290a9f12690SJung-uk Kim ACPI_OPERAND_OBJECT *MthDesc, 291a9f12690SJung-uk Kim ACPI_NAMESPACE_NODE *StartNode, 292a9f12690SJung-uk Kim ACPI_OPERAND_OBJECT **Params, 293a9f12690SJung-uk Kim ACPI_OPERAND_OBJECT **CallerReturnDesc, 294a9f12690SJung-uk Kim ACPI_OWNER_ID OwnerId, 295a9f12690SJung-uk Kim ACPI_PARSE_DOWNWARDS DescendingCallback, 296a9f12690SJung-uk Kim ACPI_PARSE_UPWARDS AscendingCallback); 297a9f12690SJung-uk Kim 298a9f12690SJung-uk Kim ACPI_STATUS 299a9f12690SJung-uk Kim AcpiPsGetNextWalkOp ( 300a9f12690SJung-uk Kim ACPI_WALK_STATE *WalkState, 301a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Op, 302a9f12690SJung-uk Kim ACPI_PARSE_UPWARDS AscendingCallback); 303a9f12690SJung-uk Kim 304a9f12690SJung-uk Kim ACPI_STATUS 305a9f12690SJung-uk Kim AcpiPsDeleteCompletedOp ( 306a9f12690SJung-uk Kim ACPI_WALK_STATE *WalkState); 307a9f12690SJung-uk Kim 308a9f12690SJung-uk Kim void 309a9f12690SJung-uk Kim AcpiPsDeleteParseTree ( 310a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *root); 311a9f12690SJung-uk Kim 312a9f12690SJung-uk Kim 313a9f12690SJung-uk Kim /* 314a9f12690SJung-uk Kim * psutils - parser utilities 315a9f12690SJung-uk Kim */ 316a9f12690SJung-uk Kim ACPI_PARSE_OBJECT * 317a9f12690SJung-uk Kim AcpiPsCreateScopeOp ( 318fe0f0bbbSJung-uk Kim UINT8 *Aml); 319a9f12690SJung-uk Kim 320a9f12690SJung-uk Kim void 321a9f12690SJung-uk Kim AcpiPsInitOp ( 322a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *op, 323a9f12690SJung-uk Kim UINT16 opcode); 324a9f12690SJung-uk Kim 325a9f12690SJung-uk Kim ACPI_PARSE_OBJECT * 326a9f12690SJung-uk Kim AcpiPsAllocOp ( 327fe0f0bbbSJung-uk Kim UINT16 Opcode, 328fe0f0bbbSJung-uk Kim UINT8 *Aml); 329a9f12690SJung-uk Kim 330a9f12690SJung-uk Kim void 331a9f12690SJung-uk Kim AcpiPsFreeOp ( 332a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Op); 333a9f12690SJung-uk Kim 334a9f12690SJung-uk Kim BOOLEAN 335a9f12690SJung-uk Kim AcpiPsIsLeadingChar ( 336a9f12690SJung-uk Kim UINT32 c); 337a9f12690SJung-uk Kim 338a9f12690SJung-uk Kim UINT32 339a9f12690SJung-uk Kim AcpiPsGetName( 340a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *op); 341a9f12690SJung-uk Kim 342a9f12690SJung-uk Kim void 343a9f12690SJung-uk Kim AcpiPsSetName( 344a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *op, 345a9f12690SJung-uk Kim UINT32 name); 346a9f12690SJung-uk Kim 347a9f12690SJung-uk Kim 348a9f12690SJung-uk Kim /* 349a9f12690SJung-uk Kim * psdump - display parser tree 350a9f12690SJung-uk Kim */ 351a9f12690SJung-uk Kim UINT32 352a9f12690SJung-uk Kim AcpiPsSprintPath ( 353a9f12690SJung-uk Kim char *BufferStart, 354a9f12690SJung-uk Kim UINT32 BufferSize, 355a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Op); 356a9f12690SJung-uk Kim 357a9f12690SJung-uk Kim UINT32 358a9f12690SJung-uk Kim AcpiPsSprintOp ( 359a9f12690SJung-uk Kim char *BufferStart, 360a9f12690SJung-uk Kim UINT32 BufferSize, 361a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *Op); 362a9f12690SJung-uk Kim 363a9f12690SJung-uk Kim void 364a9f12690SJung-uk Kim AcpiPsShow ( 365a9f12690SJung-uk Kim ACPI_PARSE_OBJECT *op); 366a9f12690SJung-uk Kim 367a9f12690SJung-uk Kim 368a9f12690SJung-uk Kim #endif /* __ACPARSER_H__ */ 369