1 /****************************************************************************** 2 * 3 * Module Name: psscope - Parser scope stack management routines 4 * 5 *****************************************************************************/ 6 7 /* 8 * Copyright (C) 2000 - 2020, Intel Corp. 9 * All rights reserved. 10 * 11 * Redistribution and use in source and binary forms, with or without 12 * modification, are permitted provided that the following conditions 13 * are met: 14 * 1. Redistributions of source code must retain the above copyright 15 * notice, this list of conditions, and the following disclaimer, 16 * without modification. 17 * 2. Redistributions in binary form must reproduce at minimum a disclaimer 18 * substantially similar to the "NO WARRANTY" disclaimer below 19 * ("Disclaimer") and any redistribution must be conditioned upon 20 * including a substantially similar Disclaimer requirement for further 21 * binary redistribution. 22 * 3. Neither the names of the above-listed copyright holders nor the names 23 * of any contributors may be used to endorse or promote products derived 24 * from this software without specific prior written permission. 25 * 26 * Alternatively, this software may be distributed under the terms of the 27 * GNU General Public License ("GPL") version 2 as published by the Free 28 * Software Foundation. 29 * 30 * NO WARRANTY 31 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 32 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 33 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR 34 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 35 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 36 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 37 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 38 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 40 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 41 * POSSIBILITY OF SUCH DAMAGES. 42 */ 43 44 #include "acpi.h" 45 #include "accommon.h" 46 #include "acparser.h" 47 48 #define _COMPONENT ACPI_PARSER 49 ACPI_MODULE_NAME ("psscope") 50 51 52 /******************************************************************************* 53 * 54 * FUNCTION: AcpiPsGetParentScope 55 * 56 * PARAMETERS: ParserState - Current parser state object 57 * 58 * RETURN: Pointer to an Op object 59 * 60 * DESCRIPTION: Get parent of current op being parsed 61 * 62 ******************************************************************************/ 63 64 ACPI_PARSE_OBJECT * 65 AcpiPsGetParentScope ( 66 ACPI_PARSE_STATE *ParserState) 67 { 68 69 return (ParserState->Scope->ParseScope.Op); 70 } 71 72 73 /******************************************************************************* 74 * 75 * FUNCTION: AcpiPsHasCompletedScope 76 * 77 * PARAMETERS: ParserState - Current parser state object 78 * 79 * RETURN: Boolean, TRUE = scope completed. 80 * 81 * DESCRIPTION: Is parsing of current argument complete? Determined by 82 * 1) AML pointer is at or beyond the end of the scope 83 * 2) The scope argument count has reached zero. 84 * 85 ******************************************************************************/ 86 87 BOOLEAN 88 AcpiPsHasCompletedScope ( 89 ACPI_PARSE_STATE *ParserState) 90 { 91 92 return ((BOOLEAN) 93 ((ParserState->Aml >= ParserState->Scope->ParseScope.ArgEnd || 94 !ParserState->Scope->ParseScope.ArgCount))); 95 } 96 97 98 /******************************************************************************* 99 * 100 * FUNCTION: AcpiPsInitScope 101 * 102 * PARAMETERS: ParserState - Current parser state object 103 * Root - the Root Node of this new scope 104 * 105 * RETURN: Status 106 * 107 * DESCRIPTION: Allocate and init a new scope object 108 * 109 ******************************************************************************/ 110 111 ACPI_STATUS 112 AcpiPsInitScope ( 113 ACPI_PARSE_STATE *ParserState, 114 ACPI_PARSE_OBJECT *RootOp) 115 { 116 ACPI_GENERIC_STATE *Scope; 117 118 119 ACPI_FUNCTION_TRACE_PTR (PsInitScope, RootOp); 120 121 122 Scope = AcpiUtCreateGenericState (); 123 if (!Scope) 124 { 125 return_ACPI_STATUS (AE_NO_MEMORY); 126 } 127 128 Scope->Common.DescriptorType = ACPI_DESC_TYPE_STATE_RPSCOPE; 129 Scope->ParseScope.Op = RootOp; 130 Scope->ParseScope.ArgCount = ACPI_VAR_ARGS; 131 Scope->ParseScope.ArgEnd = ParserState->AmlEnd; 132 Scope->ParseScope.PkgEnd = ParserState->AmlEnd; 133 134 ParserState->Scope = Scope; 135 ParserState->StartOp = RootOp; 136 137 return_ACPI_STATUS (AE_OK); 138 } 139 140 141 /******************************************************************************* 142 * 143 * FUNCTION: AcpiPsPushScope 144 * 145 * PARAMETERS: ParserState - Current parser state object 146 * Op - Current op to be pushed 147 * RemainingArgs - List of args remaining 148 * ArgCount - Fixed or variable number of args 149 * 150 * RETURN: Status 151 * 152 * DESCRIPTION: Push current op to begin parsing its argument 153 * 154 ******************************************************************************/ 155 156 ACPI_STATUS 157 AcpiPsPushScope ( 158 ACPI_PARSE_STATE *ParserState, 159 ACPI_PARSE_OBJECT *Op, 160 UINT32 RemainingArgs, 161 UINT32 ArgCount) 162 { 163 ACPI_GENERIC_STATE *Scope; 164 165 166 ACPI_FUNCTION_TRACE_PTR (PsPushScope, Op); 167 168 169 Scope = AcpiUtCreateGenericState (); 170 if (!Scope) 171 { 172 return_ACPI_STATUS (AE_NO_MEMORY); 173 } 174 175 Scope->Common.DescriptorType = ACPI_DESC_TYPE_STATE_PSCOPE; 176 Scope->ParseScope.Op = Op; 177 Scope->ParseScope.ArgList = RemainingArgs; 178 Scope->ParseScope.ArgCount = ArgCount; 179 Scope->ParseScope.PkgEnd = ParserState->PkgEnd; 180 181 /* Push onto scope stack */ 182 183 AcpiUtPushGenericState (&ParserState->Scope, Scope); 184 185 if (ArgCount == ACPI_VAR_ARGS) 186 { 187 /* Multiple arguments */ 188 189 Scope->ParseScope.ArgEnd = ParserState->PkgEnd; 190 } 191 else 192 { 193 /* Single argument */ 194 195 Scope->ParseScope.ArgEnd = ACPI_TO_POINTER (ACPI_MAX_PTR); 196 } 197 198 return_ACPI_STATUS (AE_OK); 199 } 200 201 202 /******************************************************************************* 203 * 204 * FUNCTION: AcpiPsPopScope 205 * 206 * PARAMETERS: ParserState - Current parser state object 207 * Op - Where the popped op is returned 208 * ArgList - Where the popped "next argument" is 209 * returned 210 * ArgCount - Count of objects in ArgList 211 * 212 * RETURN: Status 213 * 214 * DESCRIPTION: Return to parsing a previous op 215 * 216 ******************************************************************************/ 217 218 void 219 AcpiPsPopScope ( 220 ACPI_PARSE_STATE *ParserState, 221 ACPI_PARSE_OBJECT **Op, 222 UINT32 *ArgList, 223 UINT32 *ArgCount) 224 { 225 ACPI_GENERIC_STATE *Scope = ParserState->Scope; 226 227 228 ACPI_FUNCTION_TRACE (PsPopScope); 229 230 231 /* Only pop the scope if there is in fact a next scope */ 232 233 if (Scope->Common.Next) 234 { 235 Scope = AcpiUtPopGenericState (&ParserState->Scope); 236 237 /* Return to parsing previous op */ 238 239 *Op = Scope->ParseScope.Op; 240 *ArgList = Scope->ParseScope.ArgList; 241 *ArgCount = Scope->ParseScope.ArgCount; 242 ParserState->PkgEnd = Scope->ParseScope.PkgEnd; 243 244 /* All done with this scope state structure */ 245 246 AcpiUtDeleteGenericState (Scope); 247 } 248 else 249 { 250 /* Empty parse stack, prepare to fetch next opcode */ 251 252 *Op = NULL; 253 *ArgList = 0; 254 *ArgCount = 0; 255 } 256 257 ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, 258 "Popped Op %p Args %X\n", *Op, *ArgCount)); 259 return_VOID; 260 } 261 262 263 /******************************************************************************* 264 * 265 * FUNCTION: AcpiPsCleanupScope 266 * 267 * PARAMETERS: ParserState - Current parser state object 268 * 269 * RETURN: None 270 * 271 * DESCRIPTION: Destroy available list, remaining stack levels, and return 272 * root scope 273 * 274 ******************************************************************************/ 275 276 void 277 AcpiPsCleanupScope ( 278 ACPI_PARSE_STATE *ParserState) 279 { 280 ACPI_GENERIC_STATE *Scope; 281 282 283 ACPI_FUNCTION_TRACE_PTR (PsCleanupScope, ParserState); 284 285 286 if (!ParserState) 287 { 288 return_VOID; 289 } 290 291 /* Delete anything on the scope stack */ 292 293 while (ParserState->Scope) 294 { 295 Scope = AcpiUtPopGenericState (&ParserState->Scope); 296 AcpiUtDeleteGenericState (Scope); 297 } 298 299 return_VOID; 300 } 301