1 NoEcho(' 2 /****************************************************************************** 3 * 4 * Module Name: aslresources.y - Bison/Yacc production rules for resources 5 * - Keep this file synched with the 6 * CvParseOpBlockType function in cvcompiler.c 7 * 8 *****************************************************************************/ 9 10 /****************************************************************************** 11 * 12 * 1. Copyright Notice 13 * 14 * Some or all of this work - Copyright (c) 1999 - 2022, Intel Corp. 15 * All rights reserved. 16 * 17 * 2. License 18 * 19 * 2.1. This is your license from Intel Corp. under its intellectual property 20 * rights. You may have additional license terms from the party that provided 21 * you this software, covering your right to use that party's intellectual 22 * property rights. 23 * 24 * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a 25 * copy of the source code appearing in this file ("Covered Code") an 26 * irrevocable, perpetual, worldwide license under Intel's copyrights in the 27 * base code distributed originally by Intel ("Original Intel Code") to copy, 28 * make derivatives, distribute, use and display any portion of the Covered 29 * Code in any form, with the right to sublicense such rights; and 30 * 31 * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent 32 * license (with the right to sublicense), under only those claims of Intel 33 * patents that are infringed by the Original Intel Code, to make, use, sell, 34 * offer to sell, and import the Covered Code and derivative works thereof 35 * solely to the minimum extent necessary to exercise the above copyright 36 * license, and in no event shall the patent license extend to any additions 37 * to or modifications of the Original Intel Code. No other license or right 38 * is granted directly or by implication, estoppel or otherwise; 39 * 40 * The above copyright and patent license is granted only if the following 41 * conditions are met: 42 * 43 * 3. Conditions 44 * 45 * 3.1. Redistribution of Source with Rights to Further Distribute Source. 46 * Redistribution of source code of any substantial portion of the Covered 47 * Code or modification with rights to further distribute source must include 48 * the above Copyright Notice, the above License, this list of Conditions, 49 * and the following Disclaimer and Export Compliance provision. In addition, 50 * Licensee must cause all Covered Code to which Licensee contributes to 51 * contain a file documenting the changes Licensee made to create that Covered 52 * Code and the date of any change. Licensee must include in that file the 53 * documentation of any changes made by any predecessor Licensee. Licensee 54 * must include a prominent statement that the modification is derived, 55 * directly or indirectly, from Original Intel Code. 56 * 57 * 3.2. Redistribution of Source with no Rights to Further Distribute Source. 58 * Redistribution of source code of any substantial portion of the Covered 59 * Code or modification without rights to further distribute source must 60 * include the following Disclaimer and Export Compliance provision in the 61 * documentation and/or other materials provided with distribution. In 62 * addition, Licensee may not authorize further sublicense of source of any 63 * portion of the Covered Code, and must include terms to the effect that the 64 * license from Licensee to its licensee is limited to the intellectual 65 * property embodied in the software Licensee provides to its licensee, and 66 * not to intellectual property embodied in modifications its licensee may 67 * make. 68 * 69 * 3.3. Redistribution of Executable. Redistribution in executable form of any 70 * substantial portion of the Covered Code or modification must reproduce the 71 * above Copyright Notice, and the following Disclaimer and Export Compliance 72 * provision in the documentation and/or other materials provided with the 73 * distribution. 74 * 75 * 3.4. Intel retains all right, title, and interest in and to the Original 76 * Intel Code. 77 * 78 * 3.5. Neither the name Intel nor any other trademark owned or controlled by 79 * Intel shall be used in advertising or otherwise to promote the sale, use or 80 * other dealings in products derived from or relating to the Covered Code 81 * without prior written authorization from Intel. 82 * 83 * 4. Disclaimer and Export Compliance 84 * 85 * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED 86 * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE 87 * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE, 88 * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY 89 * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY 90 * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A 91 * PARTICULAR PURPOSE. 92 * 93 * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES 94 * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR 95 * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT, 96 * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY 97 * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL 98 * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS 99 * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY 100 * LIMITED REMEDY. 101 * 102 * 4.3. Licensee shall not export, either directly or indirectly, any of this 103 * software or system incorporating such software without first obtaining any 104 * required license or other approval from the U. S. Department of Commerce or 105 * any other agency or department of the United States Government. In the 106 * event Licensee exports any such software from the United States or 107 * re-exports any such software from a foreign destination, Licensee shall 108 * ensure that the distribution and export/re-export of the software is in 109 * compliance with all laws, regulations, orders, or other restrictions of the 110 * U.S. Export Administration Regulations. Licensee agrees that neither it nor 111 * any of its subsidiaries will export/re-export any technical data, process, 112 * software, or service, directly or indirectly, to any country for which the 113 * United States government or any agency thereof requires an export license, 114 * other governmental approval, or letter of assurance, without first obtaining 115 * such license, approval or letter. 116 * 117 ***************************************************************************** 118 * 119 * Alternatively, you may choose to be licensed under the terms of the 120 * following license: 121 * 122 * Redistribution and use in source and binary forms, with or without 123 * modification, are permitted provided that the following conditions 124 * are met: 125 * 1. Redistributions of source code must retain the above copyright 126 * notice, this list of conditions, and the following disclaimer, 127 * without modification. 128 * 2. Redistributions in binary form must reproduce at minimum a disclaimer 129 * substantially similar to the "NO WARRANTY" disclaimer below 130 * ("Disclaimer") and any redistribution must be conditioned upon 131 * including a substantially similar Disclaimer requirement for further 132 * binary redistribution. 133 * 3. Neither the names of the above-listed copyright holders nor the names 134 * of any contributors may be used to endorse or promote products derived 135 * from this software without specific prior written permission. 136 * 137 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 138 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 139 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 140 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 141 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 142 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 143 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 144 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 145 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 146 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 147 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 148 * 149 * Alternatively, you may choose to be licensed under the terms of the 150 * GNU General Public License ("GPL") version 2 as published by the Free 151 * Software Foundation. 152 * 153 *****************************************************************************/ 154 155 ') 156 157 158 /******************************************************************************* 159 * 160 * ASL Resource Template Terms 161 * 162 ******************************************************************************/ 163 164 /* 165 * Note: Create two default nodes to allow conversion to a Buffer AML opcode 166 * Also, insert the EndTag at the end of the template. 167 */ 168 ResourceTemplateTerm 169 : PARSEOP_RESOURCETEMPLATE {COMMENT_CAPTURE_OFF;} 170 OptionalParentheses 171 '{' 172 ResourceMacroList '}' {$$ = TrCreateOp (PARSEOP_RESOURCETEMPLATE,4, 173 TrCreateLeafOp (PARSEOP_DEFAULT_ARG), 174 TrCreateLeafOp (PARSEOP_DEFAULT_ARG), 175 $5, 176 TrCreateLeafOp (PARSEOP_ENDTAG)); 177 COMMENT_CAPTURE_ON;} 178 ; 179 180 OptionalParentheses 181 : {$$ = NULL;} 182 | PARSEOP_OPEN_PAREN 183 PARSEOP_CLOSE_PAREN {$$ = NULL;} 184 ; 185 186 ResourceMacroList 187 : {$$ = NULL;} 188 | ResourceMacroList 189 ResourceMacroTerm {$$ = TrLinkPeerOp ($1,$2);} 190 ; 191 192 ResourceMacroTerm 193 : Csi2SerialBusTerm {} 194 | DMATerm {} 195 | DWordIOTerm {} 196 | DWordMemoryTerm {} 197 | DWordSpaceTerm {} 198 | EndDependentFnTerm {} 199 | ExtendedIOTerm {} 200 | ExtendedMemoryTerm {} 201 | ExtendedSpaceTerm {} 202 | FixedDmaTerm {} 203 | FixedIOTerm {} 204 | GpioIntTerm {} 205 | GpioIoTerm {} 206 | I2cSerialBusTerm {} 207 | I2cSerialBusTermV2 {} 208 | InterruptTerm {} 209 | IOTerm {} 210 | IRQNoFlagsTerm {} 211 | IRQTerm {} 212 | Memory24Term {} 213 | Memory32FixedTerm {} 214 | Memory32Term {} 215 | PinConfigTerm {} 216 | PinFunctionTerm {} 217 | PinGroupTerm {} 218 | PinGroupConfigTerm {} 219 | PinGroupFunctionTerm {} 220 | QWordIOTerm {} 221 | QWordMemoryTerm {} 222 | QWordSpaceTerm {} 223 | RegisterTerm {} 224 | SpiSerialBusTerm {} 225 | SpiSerialBusTermV2 {} 226 | StartDependentFnNoPriTerm {} 227 | StartDependentFnTerm {} 228 | UartSerialBusTerm {} 229 | UartSerialBusTermV2 {} 230 | VendorLongTerm {} 231 | VendorShortTerm {} 232 | WordBusNumberTerm {} 233 | WordIOTerm {} 234 | WordSpaceTerm {} 235 ; 236 237 Csi2SerialBusTerm 238 : PARSEOP_CSI2_SERIALBUS 239 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_CSI2_SERIALBUS);} 240 OptionalSlaveMode_First {UtCheckIntegerRange ($4, 0x00, 0x01);} /* 04: SlaveMode */ 241 ',' ByteConstExpr {UtCheckIntegerRange ($7, 0x00, 0x03);} /* 07: PhyType */ 242 OptionalByteConstExpr {UtCheckIntegerRange ($9, 0x00, 0xFC);} /* 09: LocalPortInstance */ 243 ',' StringData /* 12: ResourceSource */ 244 ',' ByteConstExpr /* 14: ResourceSourceIndex */ 245 OptionalResourceType /* 15; ResourceType (ResourceUsage) */ 246 OptionalNameString /* 16: DescriptorName */ 247 OptionalBuffer_Last /* 17: VendorData */ 248 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,8, 249 $4,$7,$9,$12,$14,$15,$16,$17);} 250 | PARSEOP_CSI2_SERIALBUS 251 PARSEOP_OPEN_PAREN 252 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 253 254 DMATerm 255 : PARSEOP_DMA 256 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_DMA);} 257 DMATypeKeyword 258 OptionalBusMasterKeyword 259 ',' XferTypeKeyword 260 OptionalNameString_Last 261 PARSEOP_CLOSE_PAREN '{' 262 ByteList '}' {$$ = TrLinkOpChildren ($<n>3,5,$4,$5,$7,$8,$11);} 263 | PARSEOP_DMA 264 PARSEOP_OPEN_PAREN 265 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 266 ; 267 268 DWordIOTerm 269 : PARSEOP_DWORDIO 270 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_DWORDIO);} 271 OptionalResourceType_First 272 OptionalMinType 273 OptionalMaxType 274 OptionalDecodeType 275 OptionalRangeType 276 ',' DWordConstExpr 277 ',' DWordConstExpr 278 ',' DWordConstExpr 279 ',' DWordConstExpr 280 ',' DWordConstExpr 281 OptionalByteConstExpr 282 OptionalStringData 283 OptionalNameString 284 OptionalType 285 OptionalTranslationType_Last 286 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,15, 287 $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$19,$20,$21,$22,$23);} 288 | PARSEOP_DWORDIO 289 PARSEOP_OPEN_PAREN 290 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 291 ; 292 293 DWordMemoryTerm 294 : PARSEOP_DWORDMEMORY 295 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_DWORDMEMORY);} 296 OptionalResourceType_First 297 OptionalDecodeType 298 OptionalMinType 299 OptionalMaxType 300 OptionalMemType 301 ',' OptionalReadWriteKeyword 302 ',' DWordConstExpr 303 ',' DWordConstExpr 304 ',' DWordConstExpr 305 ',' DWordConstExpr 306 ',' DWordConstExpr 307 OptionalByteConstExpr 308 OptionalStringData 309 OptionalNameString 310 OptionalAddressRange 311 OptionalType_Last 312 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,16, 313 $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$20,$21,$22,$23,$24,$25);} 314 | PARSEOP_DWORDMEMORY 315 PARSEOP_OPEN_PAREN 316 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 317 ; 318 319 DWordSpaceTerm 320 : PARSEOP_DWORDSPACE 321 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_DWORDSPACE);} 322 ByteConstExpr {UtCheckIntegerRange ($4, 0xC0, 0xFF);} 323 OptionalResourceType 324 OptionalDecodeType 325 OptionalMinType 326 OptionalMaxType 327 ',' ByteConstExpr 328 ',' DWordConstExpr 329 ',' DWordConstExpr 330 ',' DWordConstExpr 331 ',' DWordConstExpr 332 ',' DWordConstExpr 333 OptionalByteConstExpr 334 OptionalStringData 335 OptionalNameString_Last 336 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,14, 337 $4,$6,$7,$8,$9,$11,$13,$15,$17,$19,$21,$22,$23,$24);} 338 | PARSEOP_DWORDSPACE 339 PARSEOP_OPEN_PAREN 340 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 341 ; 342 343 EndDependentFnTerm 344 : PARSEOP_ENDDEPENDENTFN 345 PARSEOP_OPEN_PAREN 346 PARSEOP_CLOSE_PAREN {$$ = TrCreateLeafOp (PARSEOP_ENDDEPENDENTFN);} 347 | PARSEOP_ENDDEPENDENTFN 348 PARSEOP_OPEN_PAREN 349 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 350 ; 351 352 ExtendedIOTerm 353 : PARSEOP_EXTENDEDIO 354 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_EXTENDEDIO);} 355 OptionalResourceType_First 356 OptionalMinType 357 OptionalMaxType 358 OptionalDecodeType 359 OptionalRangeType 360 ',' QWordConstExpr 361 ',' QWordConstExpr 362 ',' QWordConstExpr 363 ',' QWordConstExpr 364 ',' QWordConstExpr 365 OptionalQWordConstExpr 366 OptionalNameString 367 OptionalType 368 OptionalTranslationType_Last 369 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,14, 370 $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$19,$20,$21,$22);} 371 | PARSEOP_EXTENDEDIO 372 PARSEOP_OPEN_PAREN 373 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 374 ; 375 376 ExtendedMemoryTerm 377 : PARSEOP_EXTENDEDMEMORY 378 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_EXTENDEDMEMORY);} 379 OptionalResourceType_First 380 OptionalDecodeType 381 OptionalMinType 382 OptionalMaxType 383 OptionalMemType 384 ',' OptionalReadWriteKeyword 385 ',' QWordConstExpr 386 ',' QWordConstExpr 387 ',' QWordConstExpr 388 ',' QWordConstExpr 389 ',' QWordConstExpr 390 OptionalQWordConstExpr 391 OptionalNameString 392 OptionalAddressRange 393 OptionalType_Last 394 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,15, 395 $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$20,$21,$22,$23,$24);} 396 | PARSEOP_EXTENDEDMEMORY 397 PARSEOP_OPEN_PAREN 398 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 399 ; 400 401 ExtendedSpaceTerm 402 : PARSEOP_EXTENDEDSPACE PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_EXTENDEDSPACE);} 403 ByteConstExpr {UtCheckIntegerRange ($4, 0xC0, 0xFF);} 404 OptionalResourceType 405 OptionalDecodeType 406 OptionalMinType 407 OptionalMaxType 408 ',' ByteConstExpr 409 ',' QWordConstExpr 410 ',' QWordConstExpr 411 ',' QWordConstExpr 412 ',' QWordConstExpr 413 ',' QWordConstExpr 414 OptionalQWordConstExpr 415 OptionalNameString_Last 416 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,13, 417 $4,$6,$7,$8,$9,$11,$13,$15,$17,$19,$21,$22,$23);} 418 | PARSEOP_EXTENDEDSPACE 419 PARSEOP_OPEN_PAREN 420 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 421 ; 422 423 FixedDmaTerm 424 : PARSEOP_FIXEDDMA 425 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_FIXEDDMA);} 426 WordConstExpr /* 04: DMA RequestLines */ 427 ',' WordConstExpr /* 06: DMA Channels */ 428 OptionalXferSize /* 07: DMA TransferSize */ 429 OptionalNameString /* 08: DescriptorName */ 430 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,4,$4,$6,$7,$8);} 431 | PARSEOP_FIXEDDMA 432 PARSEOP_OPEN_PAREN 433 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 434 ; 435 436 FixedIOTerm 437 : PARSEOP_FIXEDIO 438 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_FIXEDIO);} 439 WordConstExpr 440 ',' ByteConstExpr 441 OptionalNameString_Last 442 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,3,$4,$6,$7);} 443 | PARSEOP_FIXEDIO 444 PARSEOP_OPEN_PAREN 445 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 446 ; 447 448 GpioIntTerm 449 : PARSEOP_GPIO_INT 450 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_GPIO_INT);} 451 InterruptTypeKeyword /* 04: InterruptType */ 452 ',' InterruptLevel /* 06: InterruptLevel */ 453 OptionalShareType /* 07: SharedType */ 454 ',' PinConfigByte /* 09: PinConfig */ 455 OptionalWordConstExpr /* 10: DebounceTimeout */ 456 ',' StringData /* 12: ResourceSource */ 457 OptionalByteConstExpr /* 13: ResourceSourceIndex */ 458 OptionalResourceType /* 14: ResourceType */ 459 OptionalNameString /* 15: DescriptorName */ 460 OptionalBuffer_Last /* 16: VendorData */ 461 PARSEOP_CLOSE_PAREN '{' 462 DWordConstExpr '}' {$$ = TrLinkOpChildren ($<n>3,11, 463 $4,$6,$7,$9,$10,$12,$13,$14,$15,$16,$19);} 464 | PARSEOP_GPIO_INT 465 PARSEOP_OPEN_PAREN 466 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 467 ; 468 469 GpioIoTerm 470 : PARSEOP_GPIO_IO 471 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_GPIO_IO);} 472 OptionalShareType_First /* 04: SharedType */ 473 ',' PinConfigByte /* 06: PinConfig */ 474 OptionalWordConstExpr /* 07: DebounceTimeout */ 475 OptionalWordConstExpr /* 08: DriveStrength */ 476 OptionalIoRestriction /* 09: IoRestriction */ 477 ',' StringData /* 11: ResourceSource */ 478 OptionalByteConstExpr /* 12: ResourceSourceIndex */ 479 OptionalResourceType /* 13: ResourceType */ 480 OptionalNameString /* 14: DescriptorName */ 481 OptionalBuffer_Last /* 15: VendorData */ 482 PARSEOP_CLOSE_PAREN '{' 483 DWordList '}' {$$ = TrLinkOpChildren ($<n>3,11, 484 $4,$6,$7,$8,$9,$11,$12,$13,$14,$15,$18);} 485 | PARSEOP_GPIO_IO 486 PARSEOP_OPEN_PAREN 487 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 488 ; 489 490 I2cSerialBusTerm 491 : PARSEOP_I2C_SERIALBUS 492 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_I2C_SERIALBUS);} 493 WordConstExpr /* 04: SlaveAddress */ 494 OptionalSlaveMode /* 05: SlaveMode */ 495 ',' DWordConstExpr /* 07: ConnectionSpeed */ 496 OptionalAddressingMode /* 08: AddressingMode */ 497 ',' StringData /* 10: ResourceSource */ 498 OptionalByteConstExpr /* 11: ResourceSourceIndex */ 499 OptionalResourceType /* 12: ResourceType */ 500 OptionalNameString /* 13: DescriptorName */ 501 OptionalBuffer_Last /* 14: VendorData */ 502 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,10, 503 $4,$5,$7,$8,$10,$11,$12,$13, 504 TrCreateLeafOp (PARSEOP_DEFAULT_ARG),$14);} 505 | PARSEOP_I2C_SERIALBUS 506 PARSEOP_OPEN_PAREN 507 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 508 ; 509 510 I2cSerialBusTermV2 511 : PARSEOP_I2C_SERIALBUS_V2 512 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_I2C_SERIALBUS_V2);} 513 WordConstExpr /* 04: SlaveAddress */ 514 OptionalSlaveMode /* 05: SlaveMode */ 515 ',' DWordConstExpr /* 07: ConnectionSpeed */ 516 OptionalAddressingMode /* 08: AddressingMode */ 517 ',' StringData /* 10: ResourceSource */ 518 OptionalByteConstExpr /* 11: ResourceSourceIndex */ 519 OptionalResourceType /* 12: ResourceType */ 520 OptionalNameString /* 13: DescriptorName */ 521 OptionalShareType /* 14: Share */ 522 OptionalBuffer_Last /* 15: VendorData */ 523 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,10, 524 $4,$5,$7,$8,$10,$11,$12,$13,$14,$15);} 525 | PARSEOP_I2C_SERIALBUS_V2 526 PARSEOP_OPEN_PAREN 527 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 528 ; 529 530 InterruptTerm 531 : PARSEOP_INTERRUPT 532 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_INTERRUPT);} 533 OptionalResourceType_First 534 ',' InterruptTypeKeyword 535 ',' InterruptLevel 536 OptionalShareType 537 OptionalByteConstExpr 538 OptionalStringData 539 OptionalNameString_Last 540 PARSEOP_CLOSE_PAREN '{' 541 DWordList '}' {$$ = TrLinkOpChildren ($<n>3,8, 542 $4,$6,$8,$9,$10,$11,$12,$15);} 543 | PARSEOP_INTERRUPT 544 PARSEOP_OPEN_PAREN 545 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 546 ; 547 548 IOTerm 549 : PARSEOP_IO 550 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_IO);} 551 IODecodeKeyword 552 ',' WordConstExpr 553 ',' WordConstExpr 554 ',' ByteConstExpr 555 ',' ByteConstExpr 556 OptionalNameString_Last 557 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,6,$4,$6,$8,$10,$12,$13);} 558 | PARSEOP_IO 559 PARSEOP_OPEN_PAREN 560 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 561 ; 562 563 IRQNoFlagsTerm 564 : PARSEOP_IRQNOFLAGS 565 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_IRQNOFLAGS);} 566 OptionalNameString_First 567 PARSEOP_CLOSE_PAREN '{' 568 ByteList '}' {$$ = TrLinkOpChildren ($<n>3,2,$4,$7);} 569 | PARSEOP_IRQNOFLAGS 570 PARSEOP_OPEN_PAREN 571 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 572 ; 573 574 IRQTerm 575 : PARSEOP_IRQ 576 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_IRQ);} 577 InterruptTypeKeyword 578 ',' InterruptLevel 579 OptionalShareType 580 OptionalNameString_Last 581 PARSEOP_CLOSE_PAREN '{' 582 ByteList '}' {$$ = TrLinkOpChildren ($<n>3,5,$4,$6,$7,$8,$11);} 583 | PARSEOP_IRQ 584 PARSEOP_OPEN_PAREN 585 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 586 ; 587 588 Memory24Term 589 : PARSEOP_MEMORY24 590 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_MEMORY24);} 591 OptionalReadWriteKeyword 592 ',' WordConstExpr 593 ',' WordConstExpr 594 ',' WordConstExpr 595 ',' WordConstExpr 596 OptionalNameString_Last 597 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,6,$4,$6,$8,$10,$12,$13);} 598 | PARSEOP_MEMORY24 599 PARSEOP_OPEN_PAREN 600 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 601 ; 602 603 Memory32FixedTerm 604 : PARSEOP_MEMORY32FIXED 605 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_MEMORY32FIXED);} 606 OptionalReadWriteKeyword 607 ',' DWordConstExpr 608 ',' DWordConstExpr 609 OptionalNameString_Last 610 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,4,$4,$6,$8,$9);} 611 | PARSEOP_MEMORY32FIXED 612 PARSEOP_OPEN_PAREN 613 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 614 ; 615 616 Memory32Term 617 : PARSEOP_MEMORY32 618 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_MEMORY32);} 619 OptionalReadWriteKeyword 620 ',' DWordConstExpr 621 ',' DWordConstExpr 622 ',' DWordConstExpr 623 ',' DWordConstExpr 624 OptionalNameString_Last 625 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,6,$4,$6,$8,$10,$12,$13);} 626 | PARSEOP_MEMORY32 627 PARSEOP_OPEN_PAREN 628 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 629 ; 630 631 PinConfigTerm 632 : PARSEOP_PINCONFIG 633 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_PINCONFIG);} 634 OptionalShareType_First /* 04: SharedType */ 635 ',' ByteConstExpr /* 06: PinConfigType */ 636 ',' DWordConstExpr /* 08: PinConfigValue */ 637 ',' StringData /* 10: ResourceSource */ 638 OptionalByteConstExpr /* 11: ResourceSourceIndex */ 639 OptionalResourceType /* 12: ResourceType */ 640 OptionalNameString /* 13: DescriptorName */ 641 OptionalBuffer_Last /* 14: VendorData */ 642 PARSEOP_CLOSE_PAREN '{' 643 DWordList '}' {$$ = TrLinkOpChildren ($<n>3,9, 644 $4,$6,$8,$10,$11,$12,$13,$14,$17);} 645 | PARSEOP_PINCONFIG 646 PARSEOP_OPEN_PAREN 647 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 648 ; 649 650 PinFunctionTerm 651 : PARSEOP_PINFUNCTION 652 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_PINFUNCTION);} 653 OptionalShareType_First /* 04: SharedType */ 654 ',' PinConfigByte /* 06: PinConfig */ 655 ',' WordConstExpr /* 08: FunctionNumber */ 656 ',' StringData /* 10: ResourceSource */ 657 OptionalByteConstExpr /* 11: ResourceSourceIndex */ 658 OptionalResourceType /* 12: ResourceType */ 659 OptionalNameString /* 13: DescriptorName */ 660 OptionalBuffer_Last /* 14: VendorData */ 661 PARSEOP_CLOSE_PAREN '{' 662 DWordList '}' {$$ = TrLinkOpChildren ($<n>3,9, 663 $4,$6,$8,$10,$11,$12,$13,$14,$17);} 664 | PARSEOP_PINFUNCTION 665 PARSEOP_OPEN_PAREN 666 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 667 ; 668 669 PinGroupTerm 670 : PARSEOP_PINGROUP 671 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_PINGROUP);} 672 StringData /* 04: ResourceLabel */ 673 OptionalProducerResourceType /* 05: ResourceType */ 674 OptionalNameString /* 06: DescriptorName */ 675 OptionalBuffer_Last /* 07: VendorData */ 676 PARSEOP_CLOSE_PAREN '{' 677 DWordList '}' {$$ = TrLinkOpChildren ($<n>3,5,$4,$5,$6,$7,$10);} 678 | PARSEOP_PINGROUP 679 PARSEOP_OPEN_PAREN 680 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 681 ; 682 683 PinGroupConfigTerm 684 : PARSEOP_PINGROUPCONFIG 685 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_PINGROUPCONFIG);} 686 OptionalShareType_First /* 04: SharedType */ 687 ',' ByteConstExpr /* 06: PinConfigType */ 688 ',' DWordConstExpr /* 08: PinConfigValue */ 689 ',' StringData /* 10: ResourceSource */ 690 OptionalByteConstExpr /* 11: ResourceSourceIndex */ 691 ',' StringData /* 13: ResourceSourceLabel */ 692 OptionalResourceType /* 14: ResourceType */ 693 OptionalNameString /* 15: DescriptorName */ 694 OptionalBuffer_Last /* 16: VendorData */ 695 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,9, 696 $4,$6,$8,$10,$11,$13,$14,$15,$16);} 697 | PARSEOP_PINGROUPCONFIG 698 PARSEOP_OPEN_PAREN 699 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 700 ; 701 702 PinGroupFunctionTerm 703 : PARSEOP_PINGROUPFUNCTION 704 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_PINGROUPFUNCTION);} 705 OptionalShareType_First /* 04: SharedType */ 706 ',' WordConstExpr /* 06: FunctionNumber */ 707 ',' StringData /* 08: ResourceSource */ 708 OptionalByteConstExpr /* 09: ResourceSourceIndex */ 709 ',' StringData /* 11: ResourceSourceLabel */ 710 OptionalResourceType /* 12: ResourceType */ 711 OptionalNameString /* 13: DescriptorName */ 712 OptionalBuffer_Last /* 14: VendorData */ 713 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,8, 714 $4,$6,$8,$9,$11,$12,$13,$14);} 715 | PARSEOP_PINGROUPFUNCTION 716 PARSEOP_OPEN_PAREN 717 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 718 ; 719 720 QWordIOTerm 721 : PARSEOP_QWORDIO 722 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_QWORDIO);} 723 OptionalResourceType_First 724 OptionalMinType 725 OptionalMaxType 726 OptionalDecodeType 727 OptionalRangeType 728 ',' QWordConstExpr 729 ',' QWordConstExpr 730 ',' QWordConstExpr 731 ',' QWordConstExpr 732 ',' QWordConstExpr 733 OptionalByteConstExpr 734 OptionalStringData 735 OptionalNameString 736 OptionalType 737 OptionalTranslationType_Last 738 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,15, 739 $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$19,$20,$21,$22,$23);} 740 | PARSEOP_QWORDIO 741 PARSEOP_OPEN_PAREN 742 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 743 ; 744 745 QWordMemoryTerm 746 : PARSEOP_QWORDMEMORY 747 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_QWORDMEMORY);} 748 OptionalResourceType_First 749 OptionalDecodeType 750 OptionalMinType 751 OptionalMaxType 752 OptionalMemType 753 ',' OptionalReadWriteKeyword 754 ',' QWordConstExpr 755 ',' QWordConstExpr 756 ',' QWordConstExpr 757 ',' QWordConstExpr 758 ',' QWordConstExpr 759 OptionalByteConstExpr 760 OptionalStringData 761 OptionalNameString 762 OptionalAddressRange 763 OptionalType_Last 764 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,16, 765 $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$20,$21,$22,$23,$24,$25);} 766 | PARSEOP_QWORDMEMORY 767 PARSEOP_OPEN_PAREN 768 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 769 ; 770 771 QWordSpaceTerm 772 : PARSEOP_QWORDSPACE 773 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_QWORDSPACE);} 774 ByteConstExpr {UtCheckIntegerRange ($4, 0xC0, 0xFF);} 775 OptionalResourceType 776 OptionalDecodeType 777 OptionalMinType 778 OptionalMaxType 779 ',' ByteConstExpr 780 ',' QWordConstExpr 781 ',' QWordConstExpr 782 ',' QWordConstExpr 783 ',' QWordConstExpr 784 ',' QWordConstExpr 785 OptionalByteConstExpr 786 OptionalStringData 787 OptionalNameString_Last 788 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,14, 789 $4,$6,$7,$8,$9,$11,$13,$15,$17,$19,$21,$22,$23,$24);} 790 | PARSEOP_QWORDSPACE 791 PARSEOP_OPEN_PAREN 792 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 793 ; 794 795 RegisterTerm 796 : PARSEOP_REGISTER 797 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_REGISTER);} 798 AddressSpaceKeyword 799 ',' ByteConstExpr 800 ',' ByteConstExpr 801 ',' QWordConstExpr 802 OptionalAccessSize 803 OptionalNameString_Last 804 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,6,$4,$6,$8,$10,$11,$12);} 805 | PARSEOP_REGISTER 806 PARSEOP_OPEN_PAREN 807 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 808 ; 809 810 SpiSerialBusTerm 811 : PARSEOP_SPI_SERIALBUS 812 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_SPI_SERIALBUS);} 813 WordConstExpr /* 04: DeviceSelection */ 814 OptionalDevicePolarity /* 05: DevicePolarity */ 815 OptionalWireMode /* 06: WireMode */ 816 ',' ByteConstExpr /* 08: DataBitLength */ 817 OptionalSlaveMode /* 09: SlaveMode */ 818 ',' DWordConstExpr /* 11: ConnectionSpeed */ 819 ',' ClockPolarityKeyword /* 13: ClockPolarity */ 820 ',' ClockPhaseKeyword /* 15: ClockPhase */ 821 ',' StringData /* 17: ResourceSource */ 822 OptionalByteConstExpr /* 18: ResourceSourceIndex */ 823 OptionalResourceType /* 19: ResourceType */ 824 OptionalNameString /* 20: DescriptorName */ 825 OptionalBuffer_Last /* 21: VendorData */ 826 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,14, 827 $4,$5,$6,$8,$9,$11,$13,$15,$17,$18,$19,$20, 828 TrCreateLeafOp (PARSEOP_DEFAULT_ARG),$21);} 829 | PARSEOP_SPI_SERIALBUS 830 PARSEOP_OPEN_PAREN 831 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 832 ; 833 834 SpiSerialBusTermV2 835 : PARSEOP_SPI_SERIALBUS_V2 836 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_SPI_SERIALBUS_V2);} 837 WordConstExpr /* 04: DeviceSelection */ 838 OptionalDevicePolarity /* 05: DevicePolarity */ 839 OptionalWireMode /* 06: WireMode */ 840 ',' ByteConstExpr /* 08: DataBitLength */ 841 OptionalSlaveMode /* 09: SlaveMode */ 842 ',' DWordConstExpr /* 11: ConnectionSpeed */ 843 ',' ClockPolarityKeyword /* 13: ClockPolarity */ 844 ',' ClockPhaseKeyword /* 15: ClockPhase */ 845 ',' StringData /* 17: ResourceSource */ 846 OptionalByteConstExpr /* 18: ResourceSourceIndex */ 847 OptionalResourceType /* 19: ResourceType */ 848 OptionalNameString /* 20: DescriptorName */ 849 OptionalShareType /* 21: Share */ 850 OptionalBuffer_Last /* 22: VendorData */ 851 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,14, 852 $4,$5,$6,$8,$9,$11,$13,$15,$17,$18,$19,$20,$21,$22);} 853 | PARSEOP_SPI_SERIALBUS_V2 854 PARSEOP_OPEN_PAREN 855 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 856 ; 857 858 StartDependentFnNoPriTerm 859 : PARSEOP_STARTDEPENDENTFN_NOPRI 860 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_STARTDEPENDENTFN_NOPRI);} 861 PARSEOP_CLOSE_PAREN '{' 862 ResourceMacroList '}' {$$ = TrLinkOpChildren ($<n>3,1,$6);} 863 | PARSEOP_STARTDEPENDENTFN_NOPRI 864 PARSEOP_OPEN_PAREN 865 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 866 ; 867 868 StartDependentFnTerm 869 : PARSEOP_STARTDEPENDENTFN 870 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_STARTDEPENDENTFN);} 871 ByteConstExpr 872 ',' ByteConstExpr 873 PARSEOP_CLOSE_PAREN '{' 874 ResourceMacroList '}' {$$ = TrLinkOpChildren ($<n>3,3,$4,$6,$9);} 875 | PARSEOP_STARTDEPENDENTFN 876 PARSEOP_OPEN_PAREN 877 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 878 ; 879 880 UartSerialBusTerm 881 : PARSEOP_UART_SERIALBUS 882 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_UART_SERIALBUS);} 883 DWordConstExpr /* 04: ConnectionSpeed */ 884 OptionalBitsPerByte /* 05: BitsPerByte */ 885 OptionalStopBits /* 06: StopBits */ 886 ',' ByteConstExpr /* 08: LinesInUse */ 887 OptionalEndian /* 09: Endianness */ 888 OptionalParityType /* 10: Parity */ 889 OptionalFlowControl /* 11: FlowControl */ 890 ',' WordConstExpr /* 13: Rx BufferSize */ 891 ',' WordConstExpr /* 15: Tx BufferSize */ 892 ',' StringData /* 17: ResourceSource */ 893 OptionalByteConstExpr /* 18: ResourceSourceIndex */ 894 OptionalResourceType /* 19: ResourceType */ 895 OptionalNameString /* 20: DescriptorName */ 896 OptionalBuffer_Last /* 21: VendorData */ 897 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,15, 898 $4,$5,$6,$8,$9,$10,$11,$13,$15,$17,$18,$19,$20, 899 TrCreateLeafOp (PARSEOP_DEFAULT_ARG),$21);} 900 | PARSEOP_UART_SERIALBUS 901 PARSEOP_OPEN_PAREN 902 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 903 ; 904 905 UartSerialBusTermV2 906 : PARSEOP_UART_SERIALBUS_V2 907 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_UART_SERIALBUS_V2);} 908 DWordConstExpr /* 04: ConnectionSpeed */ 909 OptionalBitsPerByte /* 05: BitsPerByte */ 910 OptionalStopBits /* 06: StopBits */ 911 ',' ByteConstExpr /* 08: LinesInUse */ 912 OptionalEndian /* 09: Endianness */ 913 OptionalParityType /* 10: Parity */ 914 OptionalFlowControl /* 11: FlowControl */ 915 ',' WordConstExpr /* 13: Rx BufferSize */ 916 ',' WordConstExpr /* 15: Tx BufferSize */ 917 ',' StringData /* 17: ResourceSource */ 918 OptionalByteConstExpr /* 18: ResourceSourceIndex */ 919 OptionalResourceType /* 19: ResourceType */ 920 OptionalNameString /* 20: DescriptorName */ 921 OptionalShareType /* 21: Share */ 922 OptionalBuffer_Last /* 22: VendorData */ 923 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,15, 924 $4,$5,$6,$8,$9,$10,$11,$13,$15,$17,$18,$19,$20,$21,$22);} 925 | PARSEOP_UART_SERIALBUS_V2 926 PARSEOP_OPEN_PAREN 927 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 928 ; 929 930 VendorLongTerm 931 : PARSEOP_VENDORLONG 932 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_VENDORLONG);} 933 OptionalNameString_First 934 PARSEOP_CLOSE_PAREN '{' 935 ByteList '}' {$$ = TrLinkOpChildren ($<n>3,2,$4,$7);} 936 | PARSEOP_VENDORLONG 937 PARSEOP_OPEN_PAREN 938 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 939 ; 940 941 VendorShortTerm 942 : PARSEOP_VENDORSHORT 943 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_VENDORSHORT);} 944 OptionalNameString_First 945 PARSEOP_CLOSE_PAREN '{' 946 ByteList '}' {$$ = TrLinkOpChildren ($<n>3,2,$4,$7);} 947 | PARSEOP_VENDORSHORT 948 PARSEOP_OPEN_PAREN 949 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 950 ; 951 952 WordBusNumberTerm 953 : PARSEOP_WORDBUSNUMBER 954 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_WORDBUSNUMBER);} 955 OptionalResourceType_First 956 OptionalMinType 957 OptionalMaxType 958 OptionalDecodeType 959 ',' WordConstExpr 960 ',' WordConstExpr 961 ',' WordConstExpr 962 ',' WordConstExpr 963 ',' WordConstExpr 964 OptionalByteConstExpr 965 OptionalStringData 966 OptionalNameString_Last 967 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,12, 968 $4,$5,$6,$7,$9,$11,$13,$15,$17,$18,$19,$20);} 969 | PARSEOP_WORDBUSNUMBER 970 PARSEOP_OPEN_PAREN 971 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 972 ; 973 974 WordIOTerm 975 : PARSEOP_WORDIO 976 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_WORDIO);} 977 OptionalResourceType_First 978 OptionalMinType 979 OptionalMaxType 980 OptionalDecodeType 981 OptionalRangeType 982 ',' WordConstExpr 983 ',' WordConstExpr 984 ',' WordConstExpr 985 ',' WordConstExpr 986 ',' WordConstExpr 987 OptionalByteConstExpr 988 OptionalStringData 989 OptionalNameString 990 OptionalType 991 OptionalTranslationType_Last 992 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,15, 993 $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$19,$20,$21,$22,$23);} 994 | PARSEOP_WORDIO 995 PARSEOP_OPEN_PAREN 996 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 997 ; 998 999 WordSpaceTerm 1000 : PARSEOP_WORDSPACE 1001 PARSEOP_OPEN_PAREN {$<n>$ = TrCreateLeafOp (PARSEOP_WORDSPACE);} 1002 ByteConstExpr {UtCheckIntegerRange ($4, 0xC0, 0xFF);} 1003 OptionalResourceType 1004 OptionalDecodeType 1005 OptionalMinType 1006 OptionalMaxType 1007 ',' ByteConstExpr 1008 ',' WordConstExpr 1009 ',' WordConstExpr 1010 ',' WordConstExpr 1011 ',' WordConstExpr 1012 ',' WordConstExpr 1013 OptionalByteConstExpr 1014 OptionalStringData 1015 OptionalNameString_Last 1016 PARSEOP_CLOSE_PAREN {$$ = TrLinkOpChildren ($<n>3,14, 1017 $4,$6,$7,$8,$9,$11,$13,$15,$17,$19,$21,$22,$23,$24);} 1018 | PARSEOP_WORDSPACE 1019 PARSEOP_OPEN_PAREN 1020 error PARSEOP_CLOSE_PAREN {$$ = AslDoError(); yyclearin;} 1021 ; 1022