362 lines
20 KiB
C
362 lines
20 KiB
C
/*** data.c - Global Data
|
|
*
|
|
* This module contains global data declaration.
|
|
*
|
|
* Copyright (c) 1996,1997 Microsoft Corporation
|
|
* Author: Michael Tsang (MikeTs)
|
|
* Created 08/14/96
|
|
*
|
|
* MODIFICATION HISTORY
|
|
*/
|
|
|
|
#include "pch.h"
|
|
|
|
#ifdef LOCKABLE_PRAGMA
|
|
#pragma ACPI_LOCKABLE_DATA
|
|
#pragma ACPI_LOCKABLE_CODE
|
|
#endif
|
|
|
|
#ifdef DEBUG
|
|
ULONG gdwcMemObjs = 0;
|
|
ULONG gdwcHPObjs = 0;
|
|
ULONG gdwcODObjs = 0;
|
|
ULONG gdwcNSObjs = 0;
|
|
ULONG gdwcOOObjs = 0;
|
|
ULONG gdwcBFObjs = 0;
|
|
ULONG gdwcSDObjs = 0;
|
|
ULONG gdwcBDObjs = 0;
|
|
ULONG gdwcPKObjs = 0;
|
|
ULONG gdwcFUObjs = 0;
|
|
ULONG gdwcKFObjs = 0;
|
|
ULONG gdwcFObjs = 0;
|
|
ULONG gdwcIFObjs = 0;
|
|
ULONG gdwcORObjs = 0;
|
|
ULONG gdwcMTObjs = 0;
|
|
ULONG gdwcEVObjs = 0;
|
|
ULONG gdwcMEObjs = 0;
|
|
ULONG gdwcPRObjs = 0;
|
|
ULONG gdwcPCObjs = 0;
|
|
ULONG gdwcRSObjs = 0;
|
|
ULONG gdwcSYObjs = 0;
|
|
ULONG gdwcPHObjs = 0;
|
|
ULONG gdwcCRObjs = 0;
|
|
ULONG gdwGlobalHeapSize = 0;
|
|
ULONG gdwLocalHeapMax = 0;
|
|
ULONG gdwLocalStackMax = 0;
|
|
ULONG gdwGHeapSnapshot = 0;
|
|
KSPIN_LOCK gdwGHeapSpinLock;
|
|
#endif
|
|
LONG gdwcCTObjs = 0;
|
|
ULONG gdwcCTObjsMax = 0;
|
|
KSPIN_LOCK gdwGContextSpinLock;
|
|
NPAGED_LOOKASIDE_LIST AMLIContextLookAsideList;
|
|
#ifdef TRACING
|
|
PSZ gpszTrigPts = NULL;
|
|
#endif
|
|
ULONG gdwfAMLI = 0;
|
|
ULONG gdwfAMLIInit = 0;
|
|
ULONG gdwfHacks = 0;
|
|
ULONG gdwCtxtBlkSize = DEF_CTXTBLK_SIZE;
|
|
ULONG gdwGlobalHeapBlkSize = DEF_GLOBALHEAPBLK_SIZE;
|
|
PNSOBJ gpnsNameSpaceRoot = NULL;
|
|
PHEAP gpheapGlobal = NULL;
|
|
PLIST gplistCtxtHead = NULL;
|
|
PLIST gplistObjOwners = NULL;
|
|
PLIST gplistDefuncNSObjs = NULL;
|
|
PRSACCESS gpRSAccessHead = NULL;
|
|
EVHANDLE ghNotify = {0};
|
|
EVHANDLE ghValidateTable = {0};
|
|
EVHANDLE ghFatal = {0};
|
|
EVHANDLE ghGlobalLock = {0};
|
|
EVHANDLE ghCreate = {0};
|
|
EVHANDLE ghDestroyObj = {0};
|
|
CTXTQ gReadyQueue = {0};
|
|
MUTEX gmutCtxtList = {0};
|
|
MUTEX gmutOwnerList = {0};
|
|
MUTEX gmutHeap = {0};
|
|
ULONG gdwHighestOSVerQueried = 0;
|
|
PHAL_AMLI_BAD_IO_ADDRESS_LIST gpBadIOAddressList = NULL;
|
|
PULONG gpBadIOErrorLogDoneList = NULL;
|
|
ULONG gOverrideFlags = 0;
|
|
BOOLEAN gInitTime = FALSE;
|
|
//
|
|
// Sleep specific data structures
|
|
//
|
|
MUTEX gmutSleep = {0};
|
|
KDPC SleepDpc = {0};
|
|
KTIMER SleepTimer = {0};
|
|
LIST_ENTRY SleepQueue = {0};
|
|
|
|
#define VL OF_VARIABLE_LIST
|
|
#define AO OF_ARG_OBJECT
|
|
#define LO OF_LOCAL_OBJECT
|
|
#define DO OF_DATA_OBJECT
|
|
#define SO OF_STRING_OBJECT
|
|
#define BO OF_DEBUG_OBJECT
|
|
#define NO OF_NAME_OBJECT
|
|
#define RO OF_REF_OBJECT
|
|
|
|
#define NS TC_NAMESPACE_MODIFIER
|
|
#define OB TC_NAMED_OBJECT
|
|
#define C1 TC_OPCODE_TYPE1
|
|
#define C2 TC_OPCODE_TYPE2
|
|
#define OT TC_OTHER
|
|
|
|
AMLTERM
|
|
//
|
|
// Name Space Modifiers
|
|
//
|
|
atAlias = {"Alias", OP_ALIAS, "NN", NS, 0, NULL, 0, Alias},
|
|
atName = {"Name", OP_NAME, "NO", NS, 0, NULL, 0, Name},
|
|
atScope = {"Scope", OP_SCOPE, "N", NS, VL, NULL, 0, Scope},
|
|
//
|
|
// Named Object Creators
|
|
//
|
|
atBankField = {"BankField", OP_BANKFIELD, "NNCB", OB, VL, NULL, 0, BankField},
|
|
atBitField = {"CreateBitField", OP_BITFIELD, "CCN", OB, 0, NULL, 0, CreateBitField},
|
|
atByteField = {"CreateByteField", OP_BYTEFIELD, "CCN", OB, 0, NULL, 0, CreateByteField},
|
|
atDWordField = {"CreateDWordField",OP_DWORDFIELD, "CCN", OB, 0, NULL, 0, CreateDWordField},
|
|
atCreateField = {"CreateField", OP_CREATEFIELD, "CCCN", OB, 0, NULL, 0, CreateField},
|
|
atWordField = {"CreateWordField", OP_WORDFIELD, "CCN", OB, 0, NULL, 0, CreateWordField},
|
|
atDevice = {"Device", OP_DEVICE, "N", OB, VL, NULL, 0, Device},
|
|
atEvent = {"Event", OP_EVENT, "N", OB, 0, NULL, 0, Event},
|
|
atField = {"Field", OP_FIELD, "NB", OB, VL, NULL, 0, Field},
|
|
atIndexField = {"IndexField", OP_IDXFIELD, "NNB", OB, VL, NULL, 0, IndexField},
|
|
atMethod = {"Method", OP_METHOD, "NB", OB, VL, NULL, 0, Method},
|
|
atMutex = {"Mutex", OP_MUTEX, "NB", OB, 0, NULL, 0, Mutex},
|
|
atOpRegion = {"OperationRegion", OP_OPREGION, "NBCC", OB, 0, NULL, 0, OpRegion},
|
|
atPowerRes = {"PowerResource", OP_POWERRES, "NBW", OB, VL, NULL, 0, PowerRes},
|
|
atProcessor = {"Processor", OP_PROCESSOR, "NBDB", OB, VL, NULL, 0, Processor},
|
|
atThermalZone = {"ThermalZone", OP_THERMALZONE, "N", OB, VL, NULL, 0, ThermalZone},
|
|
//
|
|
// Type 1 Opcodes
|
|
//
|
|
atBreak = {"Break", OP_BREAK, NULL, C1, 0, NULL, 0, Break},
|
|
atBreakPoint = {"BreakPoint", OP_BREAKPOINT, NULL, C1, 0, NULL, 0, BreakPoint},
|
|
atElse = {"Else", OP_ELSE, NULL, C1, VL, NULL, 0, IfElse},
|
|
atFatal = {"Fatal", OP_FATAL, "BDC", C1, 0, NULL, 0, Fatal},
|
|
atIf = {"If", OP_IF, "C", C1, VL, NULL, 0, IfElse},
|
|
atLoad = {"Load", OP_LOAD, "NS", C1, 0, NULL, 0, Load},
|
|
atNOP = {"NoOp", OP_NOP, NULL, C1, 0, NULL, 0, NULL},
|
|
atNotify = {"Notify", OP_NOTIFY, "SC", C1, 0, NULL, 0, Notify},
|
|
atRelease = {"Release", OP_RELEASE, "S", C1, 0, NULL, 0, ReleaseResetSignalUnload},
|
|
atReset = {"Reset", OP_RESET, "S", C1, 0, NULL, 0, ReleaseResetSignalUnload},
|
|
atReturn = {"Return", OP_RETURN, "C", C1, 0, NULL, 0, Return},
|
|
atSignal = {"Signal", OP_SIGNAL, "S", C1, 0, NULL, 0, ReleaseResetSignalUnload},
|
|
atSleep = {"Sleep", OP_SLEEP, "C", C1, 0, NULL, 0, SleepStall},
|
|
atStall = {"Stall", OP_STALL, "C", C1, 0, NULL, 0, SleepStall},
|
|
atUnload = {"Unload", OP_UNLOAD, "S", C1, 0, NULL, 0, ReleaseResetSignalUnload},
|
|
atWhile = {"While", OP_WHILE, "C", C1, VL, NULL, 0, While},
|
|
//
|
|
// Type 2 Opcodes
|
|
//
|
|
atAcquire = {"Acquire", OP_ACQUIRE, "SW", C2, 0, NULL, 0, Acquire},
|
|
atAdd = {"Add", OP_ADD, "CCS", C2, 0, NULL, 0, ExprOp2},
|
|
atAnd = {"And", OP_AND, "CCS", C2, 0, NULL, 0, ExprOp2},
|
|
atBuffer = {"Buffer", OP_BUFFER, "C", C2, VL, NULL, 0, Buffer},
|
|
atConcat = {"Concatenate", OP_CONCAT, "CCS", C2, 0, NULL, 0, Concat},
|
|
atCondRefOf = {"CondRefOf", OP_CONDREFOF, "sS", C1, 0, NULL, 0, CondRefOf},
|
|
atDecrement = {"Decrement", OP_DECREMENT, "S", C2, 0, NULL, 0, IncDec},
|
|
atDerefOf = {"DerefOf", OP_DEREFOF, "C", C2, 0, NULL, 0, DerefOf},
|
|
atDivide = {"Divide", OP_DIVIDE, "CCSS", C2, 0, NULL, 0, Divide},
|
|
atFindSetLBit = {"FindSetLeftBit", OP_FINDSETLBIT, "CS", C2, 0, NULL, 0, ExprOp1},
|
|
atFindSetRBit = {"FindSetRightBit", OP_FINDSETRBIT, "CS", C2, 0, NULL, 0, ExprOp1},
|
|
atFromBCD = {"FromBCD", OP_FROMBCD, "CS", C2, 0, NULL, 0, ExprOp1},
|
|
atIncrement = {"Increment", OP_INCREMENT, "S", C2, 0, NULL, 0, IncDec},
|
|
atIndex = {"Index", OP_INDEX, "CCS", C2, RO, NULL, 0, Index},
|
|
atLAnd = {"LAnd", OP_LAND, "CC", C2, 0, NULL, 0, LogOp2},
|
|
atLEq = {"LEqual", OP_LEQ, "CC", C2, 0, NULL, 0, LogOp2},
|
|
atLG = {"LGreater", OP_LG, "CC", C2, 0, NULL, 0, LogOp2},
|
|
atLL = {"LLess", OP_LL, "CC", C2, 0, NULL, 0, LogOp2},
|
|
atLNot = {"LNot", OP_LNOT, "C", C2, 0, NULL, 0, LNot},
|
|
atLOr = {"LOr", OP_LOR, "CC", C2, 0, NULL, 0, LogOp2},
|
|
atMatch = {"Match", OP_MATCH, "CBCBCC",C2, 0, NULL, 0, Match},
|
|
atMultiply = {"Multiply", OP_MULTIPLY, "CCS", C2, 0, NULL, 0, ExprOp2},
|
|
atNAnd = {"NAnd", OP_NAND, "CCS", C2, 0, NULL, 0, ExprOp2},
|
|
atNOr = {"NOr", OP_NOR, "CCS", C2, 0, NULL, 0, ExprOp2},
|
|
atNot = {"Not", OP_NOT, "CS", C2, 0, NULL, 0, ExprOp1},
|
|
atObjType = {"ObjectType", OP_OBJTYPE, "S", C2, 0, NULL, 0, ObjTypeSizeOf},
|
|
atOr = {"Or", OP_OR, "CCS", C2, 0, NULL, 0, ExprOp2},
|
|
atOSI = {"OSI", OP_OSI, "S", C2, 0, NULL, 0, OSInterface},
|
|
atPackage = {"Package", OP_PACKAGE, "B", C2, VL, NULL, 0, Package},
|
|
atRefOf = {"RefOf", OP_REFOF, "S", C2, 0, NULL, 0, RefOf},
|
|
atShiftLeft = {"ShiftLeft", OP_SHIFTL, "CCS", C2, 0, NULL, 0, ExprOp2},
|
|
atShiftRight = {"ShiftRight", OP_SHIFTR, "CCS", C2, 0, NULL, 0, ExprOp2},
|
|
atSizeOf = {"SizeOf", OP_SIZEOF, "S", C2, 0, NULL, 0, ObjTypeSizeOf},
|
|
atStore = {"Store", OP_STORE, "CS", C2, 0, NULL, 0, Store},
|
|
atSubtract = {"Subtract", OP_SUBTRACT, "CCS", C2, 0, NULL, 0, ExprOp2},
|
|
atToBCD = {"ToBCD", OP_TOBCD, "CS", C2, 0, NULL, 0, ExprOp1},
|
|
atWait = {"Wait", OP_WAIT, "SC", C2, 0, NULL, 0, Wait},
|
|
atXOr = {"XOr", OP_XOR, "CCS", C2, 0, NULL, 0, ExprOp2},
|
|
//
|
|
// Misc. Opcodes
|
|
//
|
|
atNameObj = {NULL, OP_NONE, NULL, OT, NO, NULL, 0, NULL},
|
|
atDataObj = {NULL, OP_NONE, NULL, OT, DO, NULL, 0, NULL},
|
|
atString = {NULL, OP_STRING, NULL, OT, SO, NULL, 0, NULL},
|
|
atArgObj = {NULL, OP_NONE, NULL, OT, AO, NULL, 0, NULL},
|
|
atLocalObj = {NULL, OP_NONE, NULL, OT, LO, NULL, 0, NULL},
|
|
atDebugObj = {"Debug", OP_DEBUG, NULL, OT, BO, NULL, 0, NULL};
|
|
|
|
PAMLTERM OpcodeTable[256] =
|
|
{ //0x00 0x01 0x02 0x03
|
|
&atDataObj, &atDataObj, NULL, NULL,
|
|
//0x04 0x05 0x06 0x07
|
|
NULL, NULL, &atAlias, NULL,
|
|
//0x08 0x09 0x0a 0x0b
|
|
&atName, NULL, &atDataObj, &atDataObj,
|
|
//0x0c 0x0d 0x0e 0x0f
|
|
&atDataObj, &atString, NULL, NULL,
|
|
//0x10 0x11 0x12 0x13
|
|
&atScope, &atBuffer, &atPackage, NULL,
|
|
//0x14 0x15 0x16 0x17
|
|
&atMethod, NULL, NULL, NULL,
|
|
//0x18 0x19 0x1a 0x1b
|
|
NULL, NULL, NULL, NULL,
|
|
//0x1c 0x1d 0x1e 0x1f
|
|
NULL, NULL, NULL, NULL,
|
|
//0x20 0x21 0x22 0x23
|
|
NULL, NULL, NULL, NULL,
|
|
//0x24 0x25 0x26 0x27
|
|
NULL, NULL, NULL, NULL,
|
|
//0x28 0x29 0x2a 0x2b
|
|
NULL, NULL, NULL, NULL,
|
|
//0x2c 0x2d 0x2e 0x2f
|
|
NULL, NULL, &atNameObj, &atNameObj,
|
|
//0x30 0x31 0x32 0x33
|
|
NULL, NULL, NULL, NULL,
|
|
//0x34 0x35 0x36 0x37
|
|
NULL, NULL, NULL, NULL,
|
|
//0x38 0x39 0x3a 0x3b
|
|
NULL, NULL, NULL, NULL,
|
|
//0x3c 0x3d 0x3e 0x3f
|
|
NULL, NULL, NULL, NULL,
|
|
//0x40 0x41 0x42 0x43
|
|
NULL, &atNameObj, &atNameObj, &atNameObj,
|
|
//0x44 0x45 0x46 0x47
|
|
&atNameObj, &atNameObj, &atNameObj, &atNameObj,
|
|
//0x48 0x49 0x4a 0x4b
|
|
&atNameObj, &atNameObj, &atNameObj, &atNameObj,
|
|
//0x4c 0x4d 0x4e 0x4f
|
|
&atNameObj, &atNameObj, &atNameObj, &atNameObj,
|
|
//0x50 0x51 0x52 0x53
|
|
&atNameObj, &atNameObj, &atNameObj, &atNameObj,
|
|
//0x54 0x55 0x56 0x57
|
|
&atNameObj, &atNameObj, &atNameObj, &atNameObj,
|
|
//0x58 0x59 0x5a 0x5b
|
|
&atNameObj, &atNameObj, &atNameObj, NULL,
|
|
//0x5c 0x5d 0x5e 0x5f
|
|
&atNameObj, NULL, &atNameObj, &atNameObj,
|
|
//0x60 0x61 0x62 0x63
|
|
&atLocalObj, &atLocalObj, &atLocalObj, &atLocalObj,
|
|
//0x64 0x65 0x66 0x67
|
|
&atLocalObj, &atLocalObj, &atLocalObj, &atLocalObj,
|
|
//0x68 0x69 0x6a 0x6b
|
|
&atArgObj, &atArgObj, &atArgObj, &atArgObj,
|
|
//0x6c 0x6d 0x6e 0x6f
|
|
&atArgObj, &atArgObj, &atArgObj, NULL,
|
|
//0x70 0x71 0x72 0x73
|
|
&atStore, &atRefOf, &atAdd, &atConcat,
|
|
//0x74 0x75 0x76 0x77
|
|
&atSubtract, &atIncrement, &atDecrement, &atMultiply,
|
|
//0x78 0x79 0x7a 0x7b
|
|
&atDivide, &atShiftLeft, &atShiftRight, &atAnd,
|
|
//0x7c 0x7d 0x7e 0x7f
|
|
&atNAnd, &atOr, &atNOr, &atXOr,
|
|
//0x80 0x81 0x82 0x83
|
|
&atNot, &atFindSetLBit, &atFindSetRBit, &atDerefOf,
|
|
//0x84 0x85 0x86 0x87
|
|
NULL, NULL, &atNotify, &atSizeOf,
|
|
//0x88 0x89 0x8a 0x8b
|
|
&atIndex, &atMatch, &atDWordField, &atWordField,
|
|
//0x8c 0x8d 0x8e 0x8f
|
|
&atByteField, &atBitField, &atObjType, NULL,
|
|
//0x90 0x91 0x92 0x93
|
|
&atLAnd, &atLOr, &atLNot, &atLEq,
|
|
//0x94 0x95 0x96 0x97
|
|
&atLG, &atLL, NULL, NULL,
|
|
//0x98 0x99 0x9a 0x9b
|
|
NULL, NULL, NULL, NULL,
|
|
//0x9c 0x9d 0x9e 0x9f
|
|
NULL, NULL, NULL, NULL,
|
|
//0xa0 0xa1 0xa2 0xa3
|
|
&atIf, &atElse, &atWhile, &atNOP,
|
|
//0xa4 0xa5 0xa6 0xa7
|
|
&atReturn, &atBreak, NULL, NULL,
|
|
//0xa8 0xa9 0xaa 0xab
|
|
NULL, NULL, NULL, NULL,
|
|
//0xac 0xad 0xae 0xaf
|
|
NULL, NULL, NULL, NULL,
|
|
//0xb0 0xb1 0xb2 0xb3
|
|
NULL, NULL, NULL, NULL,
|
|
//0xb4 0xb5 0xb6 0xb7
|
|
NULL, NULL, NULL, NULL,
|
|
//0xb8 0xb9 0xba 0xbb
|
|
NULL, NULL, NULL, NULL,
|
|
//0xbc 0xbd 0xbe 0xbf
|
|
NULL, NULL, NULL, NULL,
|
|
//0xc0 0xc1 0xc2 0xc3
|
|
NULL, NULL, NULL, NULL,
|
|
//0xc4 0xc5 0xc6 0xc7
|
|
NULL, NULL, NULL, NULL,
|
|
//0xc8 0xc9 0xca 0xcb
|
|
NULL, NULL, &atOSI, NULL,
|
|
//0xcc 0xcd 0xce 0xcf
|
|
&atBreakPoint, NULL, NULL, NULL,
|
|
//0xd0 0xd1 0xd2 0xd3
|
|
NULL, NULL, NULL, NULL,
|
|
//0xd4 0xd5 0xd6 0xd7
|
|
NULL, NULL, NULL, NULL,
|
|
//0xd8 0xd9 0xda 0xdb
|
|
NULL, NULL, NULL, NULL,
|
|
//0xdc 0xdd 0xde 0xdf
|
|
NULL, NULL, NULL, NULL,
|
|
//0xe0 0xe1 0xe2 0xe3
|
|
NULL, NULL, NULL, NULL,
|
|
//0xe4 0xe5 0xe6 0xe7
|
|
NULL, NULL, NULL, NULL,
|
|
//0xe8 0xe9 0xea 0xeb
|
|
NULL, NULL, NULL, NULL,
|
|
//0xec 0xed 0xee 0xef
|
|
NULL, NULL, NULL, NULL,
|
|
//0xf0 0xf1 0xf2 0xf3
|
|
NULL, NULL, NULL, NULL,
|
|
//0xf4 0xf5 0xf6 0xf7
|
|
NULL, NULL, NULL, NULL,
|
|
//0xf8 0xf9 0xfa 0xfb
|
|
NULL, NULL, NULL, NULL,
|
|
//0xfc 0xfd 0xfe 0xff
|
|
NULL, NULL, NULL, &atDataObj
|
|
};
|
|
|
|
OPCODEMAP ExOpcodeTable[] =
|
|
{
|
|
EXOP_MUTEX, &atMutex,
|
|
EXOP_EVENT, &atEvent,
|
|
EXOP_CONDREFOF, &atCondRefOf,
|
|
EXOP_CREATEFIELD, &atCreateField,
|
|
EXOP_LOAD, &atLoad,
|
|
EXOP_STALL, &atStall,
|
|
EXOP_SLEEP, &atSleep,
|
|
EXOP_ACQUIRE, &atAcquire,
|
|
EXOP_SIGNAL, &atSignal,
|
|
EXOP_WAIT, &atWait,
|
|
EXOP_RESET, &atReset,
|
|
EXOP_RELEASE, &atRelease,
|
|
EXOP_FROMBCD, &atFromBCD,
|
|
EXOP_TOBCD, &atToBCD,
|
|
EXOP_UNLOAD, &atUnload,
|
|
EXOP_REVISION, &atDataObj,
|
|
EXOP_DEBUG, &atDebugObj,
|
|
EXOP_FATAL, &atFatal,
|
|
EXOP_OPREGION, &atOpRegion,
|
|
EXOP_FIELD, &atField,
|
|
EXOP_DEVICE, &atDevice,
|
|
EXOP_PROCESSOR, &atProcessor,
|
|
EXOP_POWERRES, &atPowerRes,
|
|
EXOP_THERMALZONE, &atThermalZone,
|
|
EXOP_IDXFIELD, &atIndexField,
|
|
EXOP_BANKFIELD, &atBankField,
|
|
0, NULL
|
|
};
|