1277350a0SSascha Wildner /****************************************************************************** 2277350a0SSascha Wildner * 3277350a0SSascha Wildner * Module Name: ahgrammar - AML grammar items 4277350a0SSascha Wildner * 5277350a0SSascha Wildner *****************************************************************************/ 6277350a0SSascha Wildner 7b4315fc7SSascha Wildner /****************************************************************************** 8b4315fc7SSascha Wildner * 9b4315fc7SSascha Wildner * 1. Copyright Notice 10b4315fc7SSascha Wildner * 11*383048acSSascha Wildner * Some or all of this work - Copyright (c) 1999 - 2021, Intel Corp. 12277350a0SSascha Wildner * All rights reserved. 13277350a0SSascha Wildner * 14b4315fc7SSascha Wildner * 2. License 15b4315fc7SSascha Wildner * 16b4315fc7SSascha Wildner * 2.1. This is your license from Intel Corp. under its intellectual property 17b4315fc7SSascha Wildner * rights. You may have additional license terms from the party that provided 18b4315fc7SSascha Wildner * you this software, covering your right to use that party's intellectual 19b4315fc7SSascha Wildner * property rights. 20b4315fc7SSascha Wildner * 21b4315fc7SSascha Wildner * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a 22b4315fc7SSascha Wildner * copy of the source code appearing in this file ("Covered Code") an 23b4315fc7SSascha Wildner * irrevocable, perpetual, worldwide license under Intel's copyrights in the 24b4315fc7SSascha Wildner * base code distributed originally by Intel ("Original Intel Code") to copy, 25b4315fc7SSascha Wildner * make derivatives, distribute, use and display any portion of the Covered 26b4315fc7SSascha Wildner * Code in any form, with the right to sublicense such rights; and 27b4315fc7SSascha Wildner * 28b4315fc7SSascha Wildner * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent 29b4315fc7SSascha Wildner * license (with the right to sublicense), under only those claims of Intel 30b4315fc7SSascha Wildner * patents that are infringed by the Original Intel Code, to make, use, sell, 31b4315fc7SSascha Wildner * offer to sell, and import the Covered Code and derivative works thereof 32b4315fc7SSascha Wildner * solely to the minimum extent necessary to exercise the above copyright 33b4315fc7SSascha Wildner * license, and in no event shall the patent license extend to any additions 34b4315fc7SSascha Wildner * to or modifications of the Original Intel Code. No other license or right 35b4315fc7SSascha Wildner * is granted directly or by implication, estoppel or otherwise; 36b4315fc7SSascha Wildner * 37b4315fc7SSascha Wildner * The above copyright and patent license is granted only if the following 38b4315fc7SSascha Wildner * conditions are met: 39b4315fc7SSascha Wildner * 40b4315fc7SSascha Wildner * 3. Conditions 41b4315fc7SSascha Wildner * 42b4315fc7SSascha Wildner * 3.1. Redistribution of Source with Rights to Further Distribute Source. 43b4315fc7SSascha Wildner * Redistribution of source code of any substantial portion of the Covered 44b4315fc7SSascha Wildner * Code or modification with rights to further distribute source must include 45b4315fc7SSascha Wildner * the above Copyright Notice, the above License, this list of Conditions, 46b4315fc7SSascha Wildner * and the following Disclaimer and Export Compliance provision. In addition, 47b4315fc7SSascha Wildner * Licensee must cause all Covered Code to which Licensee contributes to 48b4315fc7SSascha Wildner * contain a file documenting the changes Licensee made to create that Covered 49b4315fc7SSascha Wildner * Code and the date of any change. Licensee must include in that file the 50b4315fc7SSascha Wildner * documentation of any changes made by any predecessor Licensee. Licensee 51b4315fc7SSascha Wildner * must include a prominent statement that the modification is derived, 52b4315fc7SSascha Wildner * directly or indirectly, from Original Intel Code. 53b4315fc7SSascha Wildner * 54b4315fc7SSascha Wildner * 3.2. Redistribution of Source with no Rights to Further Distribute Source. 55b4315fc7SSascha Wildner * Redistribution of source code of any substantial portion of the Covered 56b4315fc7SSascha Wildner * Code or modification without rights to further distribute source must 57b4315fc7SSascha Wildner * include the following Disclaimer and Export Compliance provision in the 58b4315fc7SSascha Wildner * documentation and/or other materials provided with distribution. In 59b4315fc7SSascha Wildner * addition, Licensee may not authorize further sublicense of source of any 60b4315fc7SSascha Wildner * portion of the Covered Code, and must include terms to the effect that the 61b4315fc7SSascha Wildner * license from Licensee to its licensee is limited to the intellectual 62b4315fc7SSascha Wildner * property embodied in the software Licensee provides to its licensee, and 63b4315fc7SSascha Wildner * not to intellectual property embodied in modifications its licensee may 64b4315fc7SSascha Wildner * make. 65b4315fc7SSascha Wildner * 66b4315fc7SSascha Wildner * 3.3. Redistribution of Executable. Redistribution in executable form of any 67b4315fc7SSascha Wildner * substantial portion of the Covered Code or modification must reproduce the 68b4315fc7SSascha Wildner * above Copyright Notice, and the following Disclaimer and Export Compliance 69b4315fc7SSascha Wildner * provision in the documentation and/or other materials provided with the 70b4315fc7SSascha Wildner * distribution. 71b4315fc7SSascha Wildner * 72b4315fc7SSascha Wildner * 3.4. Intel retains all right, title, and interest in and to the Original 73b4315fc7SSascha Wildner * Intel Code. 74b4315fc7SSascha Wildner * 75b4315fc7SSascha Wildner * 3.5. Neither the name Intel nor any other trademark owned or controlled by 76b4315fc7SSascha Wildner * Intel shall be used in advertising or otherwise to promote the sale, use or 77b4315fc7SSascha Wildner * other dealings in products derived from or relating to the Covered Code 78b4315fc7SSascha Wildner * without prior written authorization from Intel. 79b4315fc7SSascha Wildner * 80b4315fc7SSascha Wildner * 4. Disclaimer and Export Compliance 81b4315fc7SSascha Wildner * 82b4315fc7SSascha Wildner * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED 83b4315fc7SSascha Wildner * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE 84b4315fc7SSascha Wildner * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE, 85b4315fc7SSascha Wildner * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY 86b4315fc7SSascha Wildner * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY 87b4315fc7SSascha Wildner * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A 88b4315fc7SSascha Wildner * PARTICULAR PURPOSE. 89b4315fc7SSascha Wildner * 90b4315fc7SSascha Wildner * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES 91b4315fc7SSascha Wildner * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR 92b4315fc7SSascha Wildner * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT, 93b4315fc7SSascha Wildner * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY 94b4315fc7SSascha Wildner * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL 95b4315fc7SSascha Wildner * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS 96b4315fc7SSascha Wildner * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY 97b4315fc7SSascha Wildner * LIMITED REMEDY. 98b4315fc7SSascha Wildner * 99b4315fc7SSascha Wildner * 4.3. Licensee shall not export, either directly or indirectly, any of this 100b4315fc7SSascha Wildner * software or system incorporating such software without first obtaining any 101b4315fc7SSascha Wildner * required license or other approval from the U. S. Department of Commerce or 102b4315fc7SSascha Wildner * any other agency or department of the United States Government. In the 103b4315fc7SSascha Wildner * event Licensee exports any such software from the United States or 104b4315fc7SSascha Wildner * re-exports any such software from a foreign destination, Licensee shall 105b4315fc7SSascha Wildner * ensure that the distribution and export/re-export of the software is in 106b4315fc7SSascha Wildner * compliance with all laws, regulations, orders, or other restrictions of the 107b4315fc7SSascha Wildner * U.S. Export Administration Regulations. Licensee agrees that neither it nor 108b4315fc7SSascha Wildner * any of its subsidiaries will export/re-export any technical data, process, 109b4315fc7SSascha Wildner * software, or service, directly or indirectly, to any country for which the 110b4315fc7SSascha Wildner * United States government or any agency thereof requires an export license, 111b4315fc7SSascha Wildner * other governmental approval, or letter of assurance, without first obtaining 112b4315fc7SSascha Wildner * such license, approval or letter. 113b4315fc7SSascha Wildner * 114b4315fc7SSascha Wildner ***************************************************************************** 115b4315fc7SSascha Wildner * 116b4315fc7SSascha Wildner * Alternatively, you may choose to be licensed under the terms of the 117b4315fc7SSascha Wildner * following license: 118b4315fc7SSascha Wildner * 119277350a0SSascha Wildner * Redistribution and use in source and binary forms, with or without 120277350a0SSascha Wildner * modification, are permitted provided that the following conditions 121277350a0SSascha Wildner * are met: 122277350a0SSascha Wildner * 1. Redistributions of source code must retain the above copyright 123277350a0SSascha Wildner * notice, this list of conditions, and the following disclaimer, 124277350a0SSascha Wildner * without modification. 125277350a0SSascha Wildner * 2. Redistributions in binary form must reproduce at minimum a disclaimer 126277350a0SSascha Wildner * substantially similar to the "NO WARRANTY" disclaimer below 127277350a0SSascha Wildner * ("Disclaimer") and any redistribution must be conditioned upon 128277350a0SSascha Wildner * including a substantially similar Disclaimer requirement for further 129277350a0SSascha Wildner * binary redistribution. 130277350a0SSascha Wildner * 3. Neither the names of the above-listed copyright holders nor the names 131277350a0SSascha Wildner * of any contributors may be used to endorse or promote products derived 132277350a0SSascha Wildner * from this software without specific prior written permission. 133277350a0SSascha Wildner * 134b4315fc7SSascha Wildner * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 135b4315fc7SSascha Wildner * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 136b4315fc7SSascha Wildner * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 137b4315fc7SSascha Wildner * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 138b4315fc7SSascha Wildner * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 139b4315fc7SSascha Wildner * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 140b4315fc7SSascha Wildner * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 141b4315fc7SSascha Wildner * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 142b4315fc7SSascha Wildner * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 143b4315fc7SSascha Wildner * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 144b4315fc7SSascha Wildner * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 145b4315fc7SSascha Wildner * 146b4315fc7SSascha Wildner * Alternatively, you may choose to be licensed under the terms of the 147277350a0SSascha Wildner * GNU General Public License ("GPL") version 2 as published by the Free 148277350a0SSascha Wildner * Software Foundation. 149277350a0SSascha Wildner * 150b4315fc7SSascha Wildner *****************************************************************************/ 151277350a0SSascha Wildner 152277350a0SSascha Wildner #include "acpihelp.h" 153277350a0SSascha Wildner 15438b5d46cSSascha Wildner const AH_AML_TYPE Gbl_AmlTypesInfo[] = 155277350a0SSascha Wildner { 156277350a0SSascha Wildner {"ComputationalData", 157277350a0SSascha Wildner "ComputationalData :=\n" 158277350a0SSascha Wildner "ByteConst | WordConst | DWordConst | QWordConst |\n" 159277350a0SSascha Wildner "String | ConstObj | RevisionOp | DefBuffer\n\n" 160277350a0SSascha Wildner "DataObject := ComputationalData | DefPackage | DefVarPackage\n" 161277350a0SSascha Wildner "DataRefObject := DataObject | ObjectReference | DDBHandle\n\n" 162277350a0SSascha Wildner 163277350a0SSascha Wildner "ByteConst := BytePrefix ByteData\n" 164277350a0SSascha Wildner "BytePrefix := 0x0A\n" 165277350a0SSascha Wildner "ByteList := Nothing | <ByteData ByteList>\n" 166277350a0SSascha Wildner "ByteData := 0x00 - 0xFF\n\n" 167277350a0SSascha Wildner 168277350a0SSascha Wildner "WordConst := WordPrefix WordData\n" 169277350a0SSascha Wildner "WordPrefix := 0x0B\n" 170277350a0SSascha Wildner "WordData := 0x0000-0xFFFF\n\n" 171277350a0SSascha Wildner 172277350a0SSascha Wildner "DWordConst := DWordPrefix DWordData\n" 173277350a0SSascha Wildner "DWordPrefix := 0x0C\n" 174277350a0SSascha Wildner "DWordData := 0x00000000-0xFFFFFFFF\n\n" 175277350a0SSascha Wildner 176277350a0SSascha Wildner "QWordConst := QWordPrefix QWordData\n" 177277350a0SSascha Wildner "QWordPrefix := 0x0E\n" 178277350a0SSascha Wildner "QWordData := 0x0000000000000000-0xFFFFFFFFFFFFFFFF\n\n" 179277350a0SSascha Wildner 180277350a0SSascha Wildner "String := StringPrefix AsciiCharList NullChar\n" 181277350a0SSascha Wildner "StringPrefix := 0x0D\n" 182277350a0SSascha Wildner "AsciiCharList := Nothing | <AsciiChar AsciiCharList>\n" 183277350a0SSascha Wildner "AsciiChar := 0x01 - 0x7F\n" 184277350a0SSascha Wildner "NullChar := 0x00\n\n" 185277350a0SSascha Wildner 186277350a0SSascha Wildner "ConstObj := ZeroOp | OneOp | OnesOp\n\n"}, 187277350a0SSascha Wildner 188277350a0SSascha Wildner {"DefinitionBlock", 189277350a0SSascha Wildner "DefinitionBlockHeader :=\n" 190277350a0SSascha Wildner "TableSignature TableLength SpecCompliance Checksum\n" 191277350a0SSascha Wildner "OemID OemTableID OemRevision CreatorID CreatorRevision\n\n" 192277350a0SSascha Wildner 193277350a0SSascha Wildner "TableSignature := AsciiChar AsciiChar AsciiChar AsciiChar\n" 194277350a0SSascha Wildner "TableLength := DWordData\n" 195277350a0SSascha Wildner "// Length of the table in bytes including\n" 196277350a0SSascha Wildner "// the block header.\n\n" 197277350a0SSascha Wildner 198277350a0SSascha Wildner "SpecCompliance := ByteData\n" 199277350a0SSascha Wildner "// The revision of the structure\n\n" 200277350a0SSascha Wildner 201277350a0SSascha Wildner "CheckSum := ByteData\n" 202277350a0SSascha Wildner "// Byte checksum of the entire table\n\n" 203277350a0SSascha Wildner 204277350a0SSascha Wildner "OemID := ByteData(6)\n" 205277350a0SSascha Wildner "// OEM ID of up to 6 characters. If the OEM\n" 206277350a0SSascha Wildner "// ID is shorter than 6 characters, it\n" 207277350a0SSascha Wildner "// can be terminated with a NULL\n" 208277350a0SSascha Wildner "// character.\n\n" 209277350a0SSascha Wildner 210277350a0SSascha Wildner "OemTableID := ByteData(8)\n" 211277350a0SSascha Wildner "// OEM Table ID of up to 8 characters. If\n" 212277350a0SSascha Wildner "// the OEM Table ID is shorter than 8\n" 213277350a0SSascha Wildner "// characters, it can be terminated with\n" 214277350a0SSascha Wildner "// a NULL character.\n" 215277350a0SSascha Wildner "OemRevision := DWordData\n" 216277350a0SSascha Wildner "// OEM Table Revision\n\n" 217277350a0SSascha Wildner "CreatorID := DWordData\n" 218277350a0SSascha Wildner "// Vendor ID of the ASL compiler\n" 219277350a0SSascha Wildner "CreatorRevision := DWordData\n" 220277350a0SSascha Wildner "// Revision of the ASL compiler\n"}, 221277350a0SSascha Wildner 222277350a0SSascha Wildner {"FieldFlags", 223277350a0SSascha Wildner "FieldFlags := ByteData\n" 224277350a0SSascha Wildner "// bits 0-3: AccessType\n" 225277350a0SSascha Wildner "// 0 AnyAcc\n" 226277350a0SSascha Wildner "// 1 ByteAcc\n" 227277350a0SSascha Wildner "// 2 WordAcc\n" 228277350a0SSascha Wildner "// 3 DWordAcc\n" 229277350a0SSascha Wildner "// 4 QWordAcc\n" 230277350a0SSascha Wildner "// 5 BufferAcc\n" 231277350a0SSascha Wildner "// 6 Reserved\n" 232277350a0SSascha Wildner "// 7 Reserved\n" 233277350a0SSascha Wildner "// bit 4: LockRule\n" 234277350a0SSascha Wildner "// 0 NoLock\n" 235277350a0SSascha Wildner "// 1 Lock\n" 236277350a0SSascha Wildner "// bits 5-6: UpdateRule\n" 237277350a0SSascha Wildner "// 0 Preserve\n" 238277350a0SSascha Wildner "// 1 WriteAsOnes\n" 239277350a0SSascha Wildner "// 2 WriteAsZeros\n" 240277350a0SSascha Wildner "// bit 7:\n" 241277350a0SSascha Wildner "// 0 Reserved (must be 0)\n"}, 242277350a0SSascha Wildner 243277350a0SSascha Wildner {"FieldList", 244277350a0SSascha Wildner "FieldList := Nothing | <FieldElement FieldList>\n\n" 245277350a0SSascha Wildner "FieldElement := NamedField | ReservedField | AccessField |\n" 246277350a0SSascha Wildner " ExtendedAccessField | ConnectField\n\n" 247277350a0SSascha Wildner "NamedField := NameSeg PkgLength\n" 248277350a0SSascha Wildner "ReservedField := 0x00 PkgLength\n\n" 249277350a0SSascha Wildner 250277350a0SSascha Wildner "AccessField := 0x01 AccessType\n" 251277350a0SSascha Wildner "AccessField := 0x01 AccessType AccessAttrib\n\n" 252277350a0SSascha Wildner 253277350a0SSascha Wildner "AccessType := ByteData\n" 254277350a0SSascha Wildner "// Bits 0:3 - Same as AccessType bits of FieldFlags.\n" 255277350a0SSascha Wildner "// Bits 4:5 - Reserved\n" 256277350a0SSascha Wildner "// Bits 7:6 - 0 = AccessAttribute\n" 257277350a0SSascha Wildner "// Normal Access Attributes\n" 258277350a0SSascha Wildner "// 1 = AttribBytes (x)\n" 259277350a0SSascha Wildner "// 2 = AttribRawBytes (x)\n" 260277350a0SSascha Wildner "// 3 = AttribRawProcessBytes (x)\n" 261277350a0SSascha Wildner "// Note: 'x' is encoded as bits 0:7 of the AccessAttrib byte.\n\n" 262277350a0SSascha Wildner 263277350a0SSascha Wildner "AccessAttrib := ByteData\n" 264277350a0SSascha Wildner "// bits 0:7: Byte length\n" 265277350a0SSascha Wildner "//\n" 266277350a0SSascha Wildner "// If AccessType is BufferAcc for the SMB or\n" 267277350a0SSascha Wildner "// GPIO OpRegions, AccessAttrib can be one of\n" 268277350a0SSascha Wildner "// the following values:\n" 269277350a0SSascha Wildner "// 0x02 AttribQuick\n" 270277350a0SSascha Wildner "// 0x04 AttribSendReceive\n" 271277350a0SSascha Wildner "// 0x06 AttribByte\n" 272277350a0SSascha Wildner "// 0x08 AttribWord\n" 273277350a0SSascha Wildner "// 0x0A AttribBlock\n" 274277350a0SSascha Wildner "// 0x0C AttribProcessCall\n" 275277350a0SSascha Wildner "// 0x0D AttribBlockProcessCall\n\n" 276277350a0SSascha Wildner 277277350a0SSascha Wildner "ExtendedAccessField := 0x03 AccessType ExtendedAccessAttrib AccessLength\n" 278277350a0SSascha Wildner "ExtendedAccessAttrib := ByteData\n" 279277350a0SSascha Wildner "// 0x0B AttribBytes\n" 280277350a0SSascha Wildner "// 0x0E AttribRawBytes\n" 281277350a0SSascha Wildner "// 0x0F AttribRawProcess\n\n" 282277350a0SSascha Wildner 283277350a0SSascha Wildner "ConnectField := 0x02 NameString> | <0x02 BufferData\n"}, 284277350a0SSascha Wildner 285277350a0SSascha Wildner {"MatchOpcode", 286277350a0SSascha Wildner "DefMatch := MatchOp SearchPkg MatchOpcode Operand MatchOpcode Operand StartIndex\n" 287277350a0SSascha Wildner "MatchOp := 0x89\n" 288277350a0SSascha Wildner "SearchPkg := TermArg => Package\n" 289277350a0SSascha Wildner "MatchOpcode := ByteData\n" 290277350a0SSascha Wildner "// 0 MTR\n" 291277350a0SSascha Wildner "// 1 MEQ\n" 292277350a0SSascha Wildner "// 2 MLE\n" 293277350a0SSascha Wildner "// 3 MLT\n" 294277350a0SSascha Wildner "// 4 MGE\n" 295277350a0SSascha Wildner "// 5 MGT\n"}, 296277350a0SSascha Wildner 297277350a0SSascha Wildner {"MethodFlags", 298277350a0SSascha Wildner "DefMethod := MethodOp PkgLength NameString MethodFlags TermList\n" 299277350a0SSascha Wildner "MethodOp := 0x14\n" 300277350a0SSascha Wildner "MethodFlags := ByteData\n" 301277350a0SSascha Wildner "// bit 0-2: ArgCount (0-7)\n" 302277350a0SSascha Wildner "// bit 3: SerializeFlag\n" 303277350a0SSascha Wildner "// 0 NotSerialized\n" 304277350a0SSascha Wildner "// 1 Serialized\n" 305277350a0SSascha Wildner "// bit 4-7: SyncLevel (0x00-0x0f)\n"}, 306277350a0SSascha Wildner 307277350a0SSascha Wildner {"Miscellaneous", 308277350a0SSascha Wildner "ZeroOp := 0x00\n" 309277350a0SSascha Wildner "OneOp := 0x01\n" 310277350a0SSascha Wildner "OnesOp := 0xFF\n" 311277350a0SSascha Wildner "RevisionOp := ExtOpPrefix 0x30\n" 312277350a0SSascha Wildner "ExtOpPrefix := 0x5B\n"}, 313277350a0SSascha Wildner 314277350a0SSascha Wildner {"NameSeg", 315277350a0SSascha Wildner "NameSeg := <LeadNameChar NameChar NameChar NameChar>\n" 316277350a0SSascha Wildner "// Note: NameSegs shorter than 4 characters are filled with\n" 317277350a0SSascha Wildner "// trailing underscores.\n\n" 318277350a0SSascha Wildner "NameChar := DigitChar | LeadNameChar\n" 319277350a0SSascha Wildner "LeadNameChar := 'A'-'Z' | '_' (0x41 - 0x5A) | (0x5F)\n" 320277350a0SSascha Wildner "DigitChar := '0'-'9' (0x30 - 0x39)\n"}, 321277350a0SSascha Wildner 322277350a0SSascha Wildner {"NameString", 323277350a0SSascha Wildner "NameString := <RootChar NamePath> | <PrefixPath NamePath>\n" 324277350a0SSascha Wildner "PrefixPath := Nothing | <ParentPrefixChar PrefixPath>\n" 325277350a0SSascha Wildner "RootChar := '\\' (0x5C)\n" 326277350a0SSascha Wildner "ParentPrefixChar := '^' (0x5E)\n"}, 327277350a0SSascha Wildner 328277350a0SSascha Wildner {"NamePath", 329277350a0SSascha Wildner "NamePath := NameSeg | DualNamePath | MultiNamePath | NullName\n" 330277350a0SSascha Wildner "DualNamePath := DualNamePrefix NameSeg NameSeg\n" 331277350a0SSascha Wildner "DualNamePrefix := 0x2E\n" 332277350a0SSascha Wildner "MultiNamePath := MultiNamePrefix SegCount NameSeg(SegCount)\n" 333277350a0SSascha Wildner "MultiNamePrefix := 0x2F\n" 334277350a0SSascha Wildner "SegCount := ByteData\n" 335277350a0SSascha Wildner "// Note: SegCount can be from 1 to 255. For example: MultiNamePrefix(35)\n" 336277350a0SSascha Wildner "// is encoded as 0x2f 0x23 and followed by 35 NameSegs. So, the total\n" 337277350a0SSascha Wildner "// encoding length will be 1 + 1 + (35 * 4) = 142. Notice that:\n" 338277350a0SSascha Wildner "// DualNamePrefix NameSeg NameSeg has a smaller encoding than the\n" 339277350a0SSascha Wildner "// encoding of: MultiNamePrefix(2) NameSeg NameSeg\n\n" 340277350a0SSascha Wildner 341277350a0SSascha Wildner "SimpleName := NameString | ArgObj | LocalObj\n" 342277350a0SSascha Wildner "SuperName := SimpleName | DebugObj | Type6Opcode\n" 343277350a0SSascha Wildner "NullName := 0x00\n" 344277350a0SSascha Wildner "Target := SuperName | NullName\n"}, 345277350a0SSascha Wildner 346277350a0SSascha Wildner {"PkgLength", 347277350a0SSascha Wildner "PkgLength := PkgLeadByte |\n" 348277350a0SSascha Wildner "<PkgLeadByte ByteData> |\n" 349277350a0SSascha Wildner "<PkgLeadByte ByteData ByteData> |\n" 350277350a0SSascha Wildner "<PkgLeadByte ByteData ByteData ByteData>\n\n" 351277350a0SSascha Wildner 352277350a0SSascha Wildner "PkgLeadByte :=\n" 353277350a0SSascha Wildner "bit 7-6: Count of ByteData that follows (0-3)\n" 354277350a0SSascha Wildner "bit 5-4: Only used if (PkgLength < 63)\n" 355277350a0SSascha Wildner "bit 3-0: Least significant package length nybble\n" 356277350a0SSascha Wildner "// Note: The high 2 bits of the first byte reveal how many follow bytes\n" 357277350a0SSascha Wildner "// are in the PkgLength. If the PkgLength has only one byte, bit 0 through 5\n" 358277350a0SSascha Wildner "// are used to encode the package length (in other words, values 0-63). If\n" 359277350a0SSascha Wildner "// the package length value is more than 63, more than one byte must be\n" 360277350a0SSascha Wildner "// used for the encoding in which case bit 4 and 5 of the PkgLeadByte are\n" 361277350a0SSascha Wildner "// reserved and must be zero. If the multiple bytes encoding is used, bits\n" 362277350a0SSascha Wildner "// 0-3 of the PkgLeadByte become the least significant 4 bits of the\n" 363277350a0SSascha Wildner "// resulting package length value. The next ByteData will become the next\n" 364277350a0SSascha Wildner "// least significant 8 bits of the resulting value and so on, up to 3\n" 365277350a0SSascha Wildner "// ByteData bytes. Thus, the maximum package length is 2**28.\n"}, 366277350a0SSascha Wildner 367277350a0SSascha Wildner {"RegionSpace", 368277350a0SSascha Wildner "RegionSpace := ByteData\n" 369277350a0SSascha Wildner "// 0x00 SystemMemory\n" 370277350a0SSascha Wildner "// 0x01 SystemIO\n" 371277350a0SSascha Wildner "// 0x02 PCI_Config\n" 372277350a0SSascha Wildner "// 0x03 EmbeddedControl\n" 373277350a0SSascha Wildner "// 0x04 SMBus\n" 374277350a0SSascha Wildner "// 0x05 SystemCMOS\n" 375277350a0SSascha Wildner "// 0x06 PciBarTarget\n" 376277350a0SSascha Wildner "// 0x07 IPMI\n" 377277350a0SSascha Wildner "// 0x08 GeneralPurposeIO\n" 378277350a0SSascha Wildner "// 0x09 GenericSerialBus\n" 379277350a0SSascha Wildner "// 0x0A Platform Communications Channel\n" 380277350a0SSascha Wildner "// 0x0B-0x7E: Reserved\n" 381277350a0SSascha Wildner "// 0x7F: Functional Fixed Hardware\n" 382277350a0SSascha Wildner "// 0x80-0xBF: Reserved\n" 383277350a0SSascha Wildner "// 0xC0-0xFF: OEM Defined\n"}, 384277350a0SSascha Wildner 385277350a0SSascha Wildner {"TermObj", 386277350a0SSascha Wildner "TermObj := NameSpaceModifierObj | NamedObj | Type1Opcode | Type2Opcode\n" 387277350a0SSascha Wildner "TermList := Nothing | <TermObj TermList>\n\n" 388277350a0SSascha Wildner 389277350a0SSascha Wildner "MethodInvocation := NameString TermArgList\n" 390277350a0SSascha Wildner "TermArgList := Nothing | <TermArg TermArgList>\n" 391277350a0SSascha Wildner "TermArg := Type2Opcode | DataObject | ArgObj | LocalObj\n\n" 392277350a0SSascha Wildner 393277350a0SSascha Wildner "ObjectList := Nothing | <Object ObjectList>\n" 394277350a0SSascha Wildner "Object := NameSpaceModifierObj | NamedObj\n"}, 395277350a0SSascha Wildner 396277350a0SSascha Wildner {NULL, NULL} 397277350a0SSascha Wildner }; 398