1277350a0SSascha Wildner /****************************************************************************** 2277350a0SSascha Wildner * 3277350a0SSascha Wildner * Module Name: ahgrammar - AML grammar items 4277350a0SSascha Wildner * 5277350a0SSascha Wildner *****************************************************************************/ 6277350a0SSascha Wildner 7277350a0SSascha Wildner /* 8277350a0SSascha Wildner * Copyright (C) 2000 - 2016, Intel Corp. 9277350a0SSascha Wildner * All rights reserved. 10277350a0SSascha Wildner * 11277350a0SSascha Wildner * Redistribution and use in source and binary forms, with or without 12277350a0SSascha Wildner * modification, are permitted provided that the following conditions 13277350a0SSascha Wildner * are met: 14277350a0SSascha Wildner * 1. Redistributions of source code must retain the above copyright 15277350a0SSascha Wildner * notice, this list of conditions, and the following disclaimer, 16277350a0SSascha Wildner * without modification. 17277350a0SSascha Wildner * 2. Redistributions in binary form must reproduce at minimum a disclaimer 18277350a0SSascha Wildner * substantially similar to the "NO WARRANTY" disclaimer below 19277350a0SSascha Wildner * ("Disclaimer") and any redistribution must be conditioned upon 20277350a0SSascha Wildner * including a substantially similar Disclaimer requirement for further 21277350a0SSascha Wildner * binary redistribution. 22277350a0SSascha Wildner * 3. Neither the names of the above-listed copyright holders nor the names 23277350a0SSascha Wildner * of any contributors may be used to endorse or promote products derived 24277350a0SSascha Wildner * from this software without specific prior written permission. 25277350a0SSascha Wildner * 26277350a0SSascha Wildner * Alternatively, this software may be distributed under the terms of the 27277350a0SSascha Wildner * GNU General Public License ("GPL") version 2 as published by the Free 28277350a0SSascha Wildner * Software Foundation. 29277350a0SSascha Wildner * 30277350a0SSascha Wildner * NO WARRANTY 31277350a0SSascha Wildner * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 32277350a0SSascha Wildner * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 33277350a0SSascha Wildner * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR 34277350a0SSascha Wildner * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 35277350a0SSascha Wildner * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 36277350a0SSascha Wildner * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 37277350a0SSascha Wildner * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 38277350a0SSascha Wildner * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 39277350a0SSascha Wildner * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 40277350a0SSascha Wildner * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 41277350a0SSascha Wildner * POSSIBILITY OF SUCH DAMAGES. 42277350a0SSascha Wildner */ 43277350a0SSascha Wildner 44277350a0SSascha Wildner #include "acpihelp.h" 45277350a0SSascha Wildner 46*38b5d46cSSascha Wildner const AH_AML_TYPE Gbl_AmlTypesInfo[] = 47277350a0SSascha Wildner { 48277350a0SSascha Wildner {"ComputationalData", 49277350a0SSascha Wildner "ComputationalData :=\n" 50277350a0SSascha Wildner "ByteConst | WordConst | DWordConst | QWordConst |\n" 51277350a0SSascha Wildner "String | ConstObj | RevisionOp | DefBuffer\n\n" 52277350a0SSascha Wildner "DataObject := ComputationalData | DefPackage | DefVarPackage\n" 53277350a0SSascha Wildner "DataRefObject := DataObject | ObjectReference | DDBHandle\n\n" 54277350a0SSascha Wildner 55277350a0SSascha Wildner "ByteConst := BytePrefix ByteData\n" 56277350a0SSascha Wildner "BytePrefix := 0x0A\n" 57277350a0SSascha Wildner "ByteList := Nothing | <ByteData ByteList>\n" 58277350a0SSascha Wildner "ByteData := 0x00 - 0xFF\n\n" 59277350a0SSascha Wildner 60277350a0SSascha Wildner "WordConst := WordPrefix WordData\n" 61277350a0SSascha Wildner "WordPrefix := 0x0B\n" 62277350a0SSascha Wildner "WordData := 0x0000-0xFFFF\n\n" 63277350a0SSascha Wildner 64277350a0SSascha Wildner "DWordConst := DWordPrefix DWordData\n" 65277350a0SSascha Wildner "DWordPrefix := 0x0C\n" 66277350a0SSascha Wildner "DWordData := 0x00000000-0xFFFFFFFF\n\n" 67277350a0SSascha Wildner 68277350a0SSascha Wildner "QWordConst := QWordPrefix QWordData\n" 69277350a0SSascha Wildner "QWordPrefix := 0x0E\n" 70277350a0SSascha Wildner "QWordData := 0x0000000000000000-0xFFFFFFFFFFFFFFFF\n\n" 71277350a0SSascha Wildner 72277350a0SSascha Wildner "String := StringPrefix AsciiCharList NullChar\n" 73277350a0SSascha Wildner "StringPrefix := 0x0D\n" 74277350a0SSascha Wildner "AsciiCharList := Nothing | <AsciiChar AsciiCharList>\n" 75277350a0SSascha Wildner "AsciiChar := 0x01 - 0x7F\n" 76277350a0SSascha Wildner "NullChar := 0x00\n\n" 77277350a0SSascha Wildner 78277350a0SSascha Wildner "ConstObj := ZeroOp | OneOp | OnesOp\n\n"}, 79277350a0SSascha Wildner 80277350a0SSascha Wildner {"DefinitionBlock", 81277350a0SSascha Wildner "DefinitionBlockHeader :=\n" 82277350a0SSascha Wildner "TableSignature TableLength SpecCompliance Checksum\n" 83277350a0SSascha Wildner "OemID OemTableID OemRevision CreatorID CreatorRevision\n\n" 84277350a0SSascha Wildner 85277350a0SSascha Wildner "TableSignature := AsciiChar AsciiChar AsciiChar AsciiChar\n" 86277350a0SSascha Wildner "TableLength := DWordData\n" 87277350a0SSascha Wildner "// Length of the table in bytes including\n" 88277350a0SSascha Wildner "// the block header.\n\n" 89277350a0SSascha Wildner 90277350a0SSascha Wildner "SpecCompliance := ByteData\n" 91277350a0SSascha Wildner "// The revision of the structure\n\n" 92277350a0SSascha Wildner 93277350a0SSascha Wildner "CheckSum := ByteData\n" 94277350a0SSascha Wildner "// Byte checksum of the entire table\n\n" 95277350a0SSascha Wildner 96277350a0SSascha Wildner "OemID := ByteData(6)\n" 97277350a0SSascha Wildner "// OEM ID of up to 6 characters. If the OEM\n" 98277350a0SSascha Wildner "// ID is shorter than 6 characters, it\n" 99277350a0SSascha Wildner "// can be terminated with a NULL\n" 100277350a0SSascha Wildner "// character.\n\n" 101277350a0SSascha Wildner 102277350a0SSascha Wildner "OemTableID := ByteData(8)\n" 103277350a0SSascha Wildner "// OEM Table ID of up to 8 characters. If\n" 104277350a0SSascha Wildner "// the OEM Table ID is shorter than 8\n" 105277350a0SSascha Wildner "// characters, it can be terminated with\n" 106277350a0SSascha Wildner "// a NULL character.\n" 107277350a0SSascha Wildner "OemRevision := DWordData\n" 108277350a0SSascha Wildner "// OEM Table Revision\n\n" 109277350a0SSascha Wildner "CreatorID := DWordData\n" 110277350a0SSascha Wildner "// Vendor ID of the ASL compiler\n" 111277350a0SSascha Wildner "CreatorRevision := DWordData\n" 112277350a0SSascha Wildner "// Revision of the ASL compiler\n"}, 113277350a0SSascha Wildner 114277350a0SSascha Wildner {"FieldFlags", 115277350a0SSascha Wildner "FieldFlags := ByteData\n" 116277350a0SSascha Wildner "// bits 0-3: AccessType\n" 117277350a0SSascha Wildner "// 0 AnyAcc\n" 118277350a0SSascha Wildner "// 1 ByteAcc\n" 119277350a0SSascha Wildner "// 2 WordAcc\n" 120277350a0SSascha Wildner "// 3 DWordAcc\n" 121277350a0SSascha Wildner "// 4 QWordAcc\n" 122277350a0SSascha Wildner "// 5 BufferAcc\n" 123277350a0SSascha Wildner "// 6 Reserved\n" 124277350a0SSascha Wildner "// 7 Reserved\n" 125277350a0SSascha Wildner "// bit 4: LockRule\n" 126277350a0SSascha Wildner "// 0 NoLock\n" 127277350a0SSascha Wildner "// 1 Lock\n" 128277350a0SSascha Wildner "// bits 5-6: UpdateRule\n" 129277350a0SSascha Wildner "// 0 Preserve\n" 130277350a0SSascha Wildner "// 1 WriteAsOnes\n" 131277350a0SSascha Wildner "// 2 WriteAsZeros\n" 132277350a0SSascha Wildner "// bit 7:\n" 133277350a0SSascha Wildner "// 0 Reserved (must be 0)\n"}, 134277350a0SSascha Wildner 135277350a0SSascha Wildner {"FieldList", 136277350a0SSascha Wildner "FieldList := Nothing | <FieldElement FieldList>\n\n" 137277350a0SSascha Wildner "FieldElement := NamedField | ReservedField | AccessField |\n" 138277350a0SSascha Wildner " ExtendedAccessField | ConnectField\n\n" 139277350a0SSascha Wildner "NamedField := NameSeg PkgLength\n" 140277350a0SSascha Wildner "ReservedField := 0x00 PkgLength\n\n" 141277350a0SSascha Wildner 142277350a0SSascha Wildner "AccessField := 0x01 AccessType\n" 143277350a0SSascha Wildner "AccessField := 0x01 AccessType AccessAttrib\n\n" 144277350a0SSascha Wildner 145277350a0SSascha Wildner "AccessType := ByteData\n" 146277350a0SSascha Wildner "// Bits 0:3 - Same as AccessType bits of FieldFlags.\n" 147277350a0SSascha Wildner "// Bits 4:5 - Reserved\n" 148277350a0SSascha Wildner "// Bits 7:6 - 0 = AccessAttribute\n" 149277350a0SSascha Wildner "// Normal Access Attributes\n" 150277350a0SSascha Wildner "// 1 = AttribBytes (x)\n" 151277350a0SSascha Wildner "// 2 = AttribRawBytes (x)\n" 152277350a0SSascha Wildner "// 3 = AttribRawProcessBytes (x)\n" 153277350a0SSascha Wildner "// Note: 'x' is encoded as bits 0:7 of the AccessAttrib byte.\n\n" 154277350a0SSascha Wildner 155277350a0SSascha Wildner "AccessAttrib := ByteData\n" 156277350a0SSascha Wildner "// bits 0:7: Byte length\n" 157277350a0SSascha Wildner "//\n" 158277350a0SSascha Wildner "// If AccessType is BufferAcc for the SMB or\n" 159277350a0SSascha Wildner "// GPIO OpRegions, AccessAttrib can be one of\n" 160277350a0SSascha Wildner "// the following values:\n" 161277350a0SSascha Wildner "// 0x02 AttribQuick\n" 162277350a0SSascha Wildner "// 0x04 AttribSendReceive\n" 163277350a0SSascha Wildner "// 0x06 AttribByte\n" 164277350a0SSascha Wildner "// 0x08 AttribWord\n" 165277350a0SSascha Wildner "// 0x0A AttribBlock\n" 166277350a0SSascha Wildner "// 0x0C AttribProcessCall\n" 167277350a0SSascha Wildner "// 0x0D AttribBlockProcessCall\n\n" 168277350a0SSascha Wildner 169277350a0SSascha Wildner "ExtendedAccessField := 0x03 AccessType ExtendedAccessAttrib AccessLength\n" 170277350a0SSascha Wildner "ExtendedAccessAttrib := ByteData\n" 171277350a0SSascha Wildner "// 0x0B AttribBytes\n" 172277350a0SSascha Wildner "// 0x0E AttribRawBytes\n" 173277350a0SSascha Wildner "// 0x0F AttribRawProcess\n\n" 174277350a0SSascha Wildner 175277350a0SSascha Wildner "ConnectField := 0x02 NameString> | <0x02 BufferData\n"}, 176277350a0SSascha Wildner 177277350a0SSascha Wildner {"MatchOpcode", 178277350a0SSascha Wildner "DefMatch := MatchOp SearchPkg MatchOpcode Operand MatchOpcode Operand StartIndex\n" 179277350a0SSascha Wildner "MatchOp := 0x89\n" 180277350a0SSascha Wildner "SearchPkg := TermArg => Package\n" 181277350a0SSascha Wildner "MatchOpcode := ByteData\n" 182277350a0SSascha Wildner "// 0 MTR\n" 183277350a0SSascha Wildner "// 1 MEQ\n" 184277350a0SSascha Wildner "// 2 MLE\n" 185277350a0SSascha Wildner "// 3 MLT\n" 186277350a0SSascha Wildner "// 4 MGE\n" 187277350a0SSascha Wildner "// 5 MGT\n"}, 188277350a0SSascha Wildner 189277350a0SSascha Wildner {"MethodFlags", 190277350a0SSascha Wildner "DefMethod := MethodOp PkgLength NameString MethodFlags TermList\n" 191277350a0SSascha Wildner "MethodOp := 0x14\n" 192277350a0SSascha Wildner "MethodFlags := ByteData\n" 193277350a0SSascha Wildner "// bit 0-2: ArgCount (0-7)\n" 194277350a0SSascha Wildner "// bit 3: SerializeFlag\n" 195277350a0SSascha Wildner "// 0 NotSerialized\n" 196277350a0SSascha Wildner "// 1 Serialized\n" 197277350a0SSascha Wildner "// bit 4-7: SyncLevel (0x00-0x0f)\n"}, 198277350a0SSascha Wildner 199277350a0SSascha Wildner {"Miscellaneous", 200277350a0SSascha Wildner "ZeroOp := 0x00\n" 201277350a0SSascha Wildner "OneOp := 0x01\n" 202277350a0SSascha Wildner "OnesOp := 0xFF\n" 203277350a0SSascha Wildner "RevisionOp := ExtOpPrefix 0x30\n" 204277350a0SSascha Wildner "ExtOpPrefix := 0x5B\n"}, 205277350a0SSascha Wildner 206277350a0SSascha Wildner {"NameSeg", 207277350a0SSascha Wildner "NameSeg := <LeadNameChar NameChar NameChar NameChar>\n" 208277350a0SSascha Wildner "// Note: NameSegs shorter than 4 characters are filled with\n" 209277350a0SSascha Wildner "// trailing underscores.\n\n" 210277350a0SSascha Wildner "NameChar := DigitChar | LeadNameChar\n" 211277350a0SSascha Wildner "LeadNameChar := 'A'-'Z' | '_' (0x41 - 0x5A) | (0x5F)\n" 212277350a0SSascha Wildner "DigitChar := '0'-'9' (0x30 - 0x39)\n"}, 213277350a0SSascha Wildner 214277350a0SSascha Wildner {"NameString", 215277350a0SSascha Wildner "NameString := <RootChar NamePath> | <PrefixPath NamePath>\n" 216277350a0SSascha Wildner "PrefixPath := Nothing | <ParentPrefixChar PrefixPath>\n" 217277350a0SSascha Wildner "RootChar := '\\' (0x5C)\n" 218277350a0SSascha Wildner "ParentPrefixChar := '^' (0x5E)\n"}, 219277350a0SSascha Wildner 220277350a0SSascha Wildner {"NamePath", 221277350a0SSascha Wildner "NamePath := NameSeg | DualNamePath | MultiNamePath | NullName\n" 222277350a0SSascha Wildner "DualNamePath := DualNamePrefix NameSeg NameSeg\n" 223277350a0SSascha Wildner "DualNamePrefix := 0x2E\n" 224277350a0SSascha Wildner "MultiNamePath := MultiNamePrefix SegCount NameSeg(SegCount)\n" 225277350a0SSascha Wildner "MultiNamePrefix := 0x2F\n" 226277350a0SSascha Wildner "SegCount := ByteData\n" 227277350a0SSascha Wildner "// Note: SegCount can be from 1 to 255. For example: MultiNamePrefix(35)\n" 228277350a0SSascha Wildner "// is encoded as 0x2f 0x23 and followed by 35 NameSegs. So, the total\n" 229277350a0SSascha Wildner "// encoding length will be 1 + 1 + (35 * 4) = 142. Notice that:\n" 230277350a0SSascha Wildner "// DualNamePrefix NameSeg NameSeg has a smaller encoding than the\n" 231277350a0SSascha Wildner "// encoding of: MultiNamePrefix(2) NameSeg NameSeg\n\n" 232277350a0SSascha Wildner 233277350a0SSascha Wildner "SimpleName := NameString | ArgObj | LocalObj\n" 234277350a0SSascha Wildner "SuperName := SimpleName | DebugObj | Type6Opcode\n" 235277350a0SSascha Wildner "NullName := 0x00\n" 236277350a0SSascha Wildner "Target := SuperName | NullName\n"}, 237277350a0SSascha Wildner 238277350a0SSascha Wildner {"PkgLength", 239277350a0SSascha Wildner "PkgLength := PkgLeadByte |\n" 240277350a0SSascha Wildner "<PkgLeadByte ByteData> |\n" 241277350a0SSascha Wildner "<PkgLeadByte ByteData ByteData> |\n" 242277350a0SSascha Wildner "<PkgLeadByte ByteData ByteData ByteData>\n\n" 243277350a0SSascha Wildner 244277350a0SSascha Wildner "PkgLeadByte :=\n" 245277350a0SSascha Wildner "bit 7-6: Count of ByteData that follows (0-3)\n" 246277350a0SSascha Wildner "bit 5-4: Only used if (PkgLength < 63)\n" 247277350a0SSascha Wildner "bit 3-0: Least significant package length nybble\n" 248277350a0SSascha Wildner "// Note: The high 2 bits of the first byte reveal how many follow bytes\n" 249277350a0SSascha Wildner "// are in the PkgLength. If the PkgLength has only one byte, bit 0 through 5\n" 250277350a0SSascha Wildner "// are used to encode the package length (in other words, values 0-63). If\n" 251277350a0SSascha Wildner "// the package length value is more than 63, more than one byte must be\n" 252277350a0SSascha Wildner "// used for the encoding in which case bit 4 and 5 of the PkgLeadByte are\n" 253277350a0SSascha Wildner "// reserved and must be zero. If the multiple bytes encoding is used, bits\n" 254277350a0SSascha Wildner "// 0-3 of the PkgLeadByte become the least significant 4 bits of the\n" 255277350a0SSascha Wildner "// resulting package length value. The next ByteData will become the next\n" 256277350a0SSascha Wildner "// least significant 8 bits of the resulting value and so on, up to 3\n" 257277350a0SSascha Wildner "// ByteData bytes. Thus, the maximum package length is 2**28.\n"}, 258277350a0SSascha Wildner 259277350a0SSascha Wildner {"RegionSpace", 260277350a0SSascha Wildner "RegionSpace := ByteData\n" 261277350a0SSascha Wildner "// 0x00 SystemMemory\n" 262277350a0SSascha Wildner "// 0x01 SystemIO\n" 263277350a0SSascha Wildner "// 0x02 PCI_Config\n" 264277350a0SSascha Wildner "// 0x03 EmbeddedControl\n" 265277350a0SSascha Wildner "// 0x04 SMBus\n" 266277350a0SSascha Wildner "// 0x05 SystemCMOS\n" 267277350a0SSascha Wildner "// 0x06 PciBarTarget\n" 268277350a0SSascha Wildner "// 0x07 IPMI\n" 269277350a0SSascha Wildner "// 0x08 GeneralPurposeIO\n" 270277350a0SSascha Wildner "// 0x09 GenericSerialBus\n" 271277350a0SSascha Wildner "// 0x0A Platform Communications Channel\n" 272277350a0SSascha Wildner "// 0x0B-0x7E: Reserved\n" 273277350a0SSascha Wildner "// 0x7F: Functional Fixed Hardware\n" 274277350a0SSascha Wildner "// 0x80-0xBF: Reserved\n" 275277350a0SSascha Wildner "// 0xC0-0xFF: OEM Defined\n"}, 276277350a0SSascha Wildner 277277350a0SSascha Wildner {"TermObj", 278277350a0SSascha Wildner "TermObj := NameSpaceModifierObj | NamedObj | Type1Opcode | Type2Opcode\n" 279277350a0SSascha Wildner "TermList := Nothing | <TermObj TermList>\n\n" 280277350a0SSascha Wildner 281277350a0SSascha Wildner "MethodInvocation := NameString TermArgList\n" 282277350a0SSascha Wildner "TermArgList := Nothing | <TermArg TermArgList>\n" 283277350a0SSascha Wildner "TermArg := Type2Opcode | DataObject | ArgObj | LocalObj\n\n" 284277350a0SSascha Wildner 285277350a0SSascha Wildner "ObjectList := Nothing | <Object ObjectList>\n" 286277350a0SSascha Wildner "Object := NameSpaceModifierObj | NamedObj\n"}, 287277350a0SSascha Wildner 288277350a0SSascha Wildner {NULL, NULL} 289277350a0SSascha Wildner }; 290