Reimplemented inefficient opcode type checking with flags in opcode

info table


date	2001.08.22.16.56.00;	author rmoore1;	state Exp;
This commit is contained in:
aystarik 2005-06-29 19:44:22 +00:00
parent 1149c43c86
commit 6bb2e615fc
2 changed files with 127 additions and 123 deletions

View File

@ -1,7 +1,7 @@
/****************************************************************************** /******************************************************************************
* *
* Name: aclocal.h - Internal data types used across the ACPI subsystem * Name: aclocal.h - Internal data types used across the ACPI subsystem
* $Revision: 1.127 $ * $Revision: 1.128 $
* *
*****************************************************************************/ *****************************************************************************/
@ -630,15 +630,31 @@ ACPI_STATUS (*ACPI_PARSE_UPWARDS) (
#define ACPI_GET_OP_ARGS(a) ((a)->Flags & ACPI_OP_ARGS_MASK) #define ACPI_GET_OP_ARGS(a) ((a)->Flags & ACPI_OP_ARGS_MASK)
#define ACPI_GET_OP_TYPE(a) ((a)->Flags & ACPI_OP_TYPE_MASK) #define ACPI_GET_OP_TYPE(a) ((a)->Flags & ACPI_OP_TYPE_MASK)
/*
* Flags byte: 0-4 (5 bits) = Opcode Class (0x001F
* 5 (1 bit) = Has arguments flag
* 6-7 (2 bits) = Reserved
*/
#define AML_NO_ARGS 0
#define AML_HAS_ARGS 0x0020
#define AML_NSOBJECT 0x0100
#define AML_NSOPCODE 0x0200
#define AML_NSNODE 0x0400
#define AML_NAMED 0x0800
#define AML_DEFER 0x1000
#define AML_FIELD 0x2000
#define AML_CREATE 0x4000
/* /*
* AML opcode, name, and argument layout * AML opcode, name, and argument layout
*/ */
typedef struct acpi_opcode_info typedef struct acpi_opcode_info
{ {
UINT8 Flags; /* Opcode type, HasArgs flag */
UINT32 ParseArgs; /* Grammar/Parse time arguments */ UINT32 ParseArgs; /* Grammar/Parse time arguments */
UINT32 RuntimeArgs; /* Interpret time arguments */ UINT32 RuntimeArgs; /* Interpret time arguments */
UINT16 Flags; /* Opcode type, HasArgs flag */
#ifdef _OPCODE_NAMES #ifdef _OPCODE_NAMES
NATIVE_CHAR *Name; /* op name (debug only) */ NATIVE_CHAR *Name; /* op name (debug only) */

View File

@ -1,7 +1,7 @@
/****************************************************************************** /******************************************************************************
* *
* Name: acmacros.h - C macros for the entire subsystem. * Name: acmacros.h - C macros for the entire subsystem.
* $Revision: 1.67 $ * $Revision: 1.87 $
* *
*****************************************************************************/ *****************************************************************************/
@ -117,18 +117,11 @@
#ifndef __ACMACROS_H__ #ifndef __ACMACROS_H__
#define __ACMACROS_H__ #define __ACMACROS_H__
/* /*
* Data manipulation macros * Data manipulation macros
*/ */
#ifndef LODWORD
#define LODWORD(l) ((UINT32)(UINT64)(l))
#endif
#ifndef HIDWORD
#define HIDWORD(l) ((UINT32)((((UINT64)(l)) >> 32) & 0xFFFFFFFF))
#endif
#ifndef LOWORD #ifndef LOWORD
#define LOWORD(l) ((UINT16)(NATIVE_UINT)(l)) #define LOWORD(l) ((UINT16)(NATIVE_UINT)(l))
#endif #endif
@ -167,24 +160,65 @@
* For 16-bit addresses, we have to assume that the upper 32 bits * For 16-bit addresses, we have to assume that the upper 32 bits
* are zero. * are zero.
*/ */
#ifndef LODWORD
#define LODWORD(l) (l)
#endif
#ifndef HIDWORD
#define HIDWORD(l) (0)
#endif
#define ACPI_GET_ADDRESS(a) ((a).Lo) #define ACPI_GET_ADDRESS(a) ((a).Lo)
#define ACPI_STORE_ADDRESS(a,b) {(a).Hi=0;(a).Lo=(b);} #define ACPI_STORE_ADDRESS(a,b) {(a).Hi=0;(a).Lo=(b);}
#define ACPI_VALID_ADDRESS(a) ((a).Hi | (a).Lo) #define ACPI_VALID_ADDRESS(a) ((a).Hi | (a).Lo)
#else #else
#ifdef ACPI_NO_INTEGER64_SUPPORT
/* /*
* Full 64-bit address on 32-bit and 64-bit platforms * ACPI_INTEGER is 32-bits, no 64-bit support on this platform
*/ */
#ifndef LODWORD
#define LODWORD(l) ((UINT32)(l))
#endif
#ifndef HIDWORD
#define HIDWORD(l) (0)
#endif
#define ACPI_GET_ADDRESS(a) (a)
#define ACPI_STORE_ADDRESS(a,b) ((a)=(b))
#define ACPI_VALID_ADDRESS(a) (a)
#else
/*
* Full 64-bit address/integer on both 32-bit and 64-bit platforms
*/
#ifndef LODWORD
#define LODWORD(l) ((UINT32)(UINT64)(l))
#endif
#ifndef HIDWORD
#define HIDWORD(l) ((UINT32)(((*(UINT64_STRUCT *)(&l))).Hi))
#endif
#define ACPI_GET_ADDRESS(a) (a) #define ACPI_GET_ADDRESS(a) (a)
#define ACPI_STORE_ADDRESS(a,b) ((a)=(b)) #define ACPI_STORE_ADDRESS(a,b) ((a)=(b))
#define ACPI_VALID_ADDRESS(a) (a) #define ACPI_VALID_ADDRESS(a) (a)
#endif #endif
#endif
/* /*
* Extract a byte of data using a pointer. Any more than a byte and we * Extract a byte of data using a pointer. Any more than a byte and we
* get into potential aligment issues -- see the STORE macros below * get into potential aligment issues -- see the STORE macros below
*/ */
#define GET8(addr) (*(UINT8*)(addr)) #define GET8(addr) (*(UINT8*)(addr))
/* Pointer arithmetic */
#define POINTER_ADD(t,a,b) (t *) ((NATIVE_UINT)(a) + (NATIVE_UINT)(b))
#define POINTER_DIFF(a,b) ((UINT32) ((NATIVE_UINT)(a) - (NATIVE_UINT)(b)))
/* /*
* Macros for moving data around to/from buffers that are possibly unaligned. * Macros for moving data around to/from buffers that are possibly unaligned.
@ -263,7 +297,6 @@
/* /*
* Rounding macros (Power of two boundaries only) * Rounding macros (Power of two boundaries only)
*/ */
#define ROUND_DOWN(value,boundary) ((value) & (~((boundary)-1))) #define ROUND_DOWN(value,boundary) ((value) & (~((boundary)-1)))
#define ROUND_UP(value,boundary) (((value) + ((boundary)-1)) & (~((boundary)-1))) #define ROUND_UP(value,boundary) (((value) + ((boundary)-1)) & (~((boundary)-1)))
@ -279,30 +312,44 @@
#define ROUND_PTR_UP_TO_8(a,b) ((b *)(((NATIVE_UINT)(a) + 7) & ~7)) #define ROUND_PTR_UP_TO_8(a,b) ((b *)(((NATIVE_UINT)(a) + 7) & ~7))
#define ROUND_BITS_UP_TO_BYTES(a) DIV_8((a) + 7) #define ROUND_BITS_UP_TO_BYTES(a) DIV_8((a) + 7)
#define ROUND_BITS_DOWN_TO_BYTES(a) DIV_8((a))
#define ROUND_UP_TO_1K(a) (((a) + 1023) >> 10) #define ROUND_UP_TO_1K(a) (((a) + 1023) >> 10)
#ifdef DEBUG_ASSERT /* Generic (non-power-of-two) rounding */
#undef DEBUG_ASSERT
#endif #define ROUND_UP_TO(value,boundary) (((value) + ((boundary)-1)) / (boundary))
/*
* Bitmask creation
* Bit positions start at zero.
* MASK_BITS_ABOVE creates a mask starting AT the position and above
* MASK_BITS_BELOW creates a mask starting one bit BELOW the position
*/
#define MASK_BITS_ABOVE(position) (~(((UINT32)(-1)) << ((UINT32) (position))))
#define MASK_BITS_BELOW(position) (((UINT32)(-1)) << ((UINT32) (position)))
/* Macros for GAS addressing */ /* Macros for GAS addressing */
#ifndef _IA16
#define ACPI_PCI_DEVICE_MASK (UINT64) 0x0000FFFF00000000 #define ACPI_PCI_DEVICE_MASK (UINT64) 0x0000FFFF00000000
#define ACPI_PCI_FUNCTION_MASK (UINT64) 0x00000000FFFF0000 #define ACPI_PCI_FUNCTION_MASK (UINT64) 0x00000000FFFF0000
#define ACPI_PCI_REGISTER_MASK (UINT64) 0x000000000000FFFF #define ACPI_PCI_REGISTER_MASK (UINT64) 0x000000000000FFFF
#define ACPI_PCI_FUNCTION(a) (UINT32) ((((a) & ACPI_PCI_FUNCTION_MASK) >> 16)) #define ACPI_PCI_FUNCTION(a) (UINT16) ((((a) & ACPI_PCI_FUNCTION_MASK) >> 16))
#define ACPI_PCI_DEVICE(a) (UINT32) ((((a) & ACPI_PCI_DEVICE_MASK) >> 32)) #define ACPI_PCI_DEVICE(a) (UINT16) ((((a) & ACPI_PCI_DEVICE_MASK) >> 32))
#define ACPI_PCI_REGISTER(a) (UINT16) (((a) & ACPI_PCI_REGISTER_MASK))
#ifndef _IA16
#define ACPI_PCI_REGISTER(a) (UINT32) (((a) & ACPI_PCI_REGISTER_MASK))
#define ACPI_PCI_DEVFUN(a) (UINT32) ((ACPI_PCI_DEVICE(a) << 16) | ACPI_PCI_FUNCTION(a))
#else #else
#define ACPI_PCI_REGISTER(a) (UINT32) (((a) & 0x0000FFFF))
#define ACPI_PCI_DEVFUN(a) (UINT32) ((((a) & 0xFFFF0000) >> 16)) /* No support for GAS and PCI IDs in 16-bit mode */
#define ACPI_PCI_FUNCTION(a) (UINT16) ((a) & 0xFFFF0000)
#define ACPI_PCI_DEVICE(a) (UINT16) ((a) & 0x0000FFFF)
#define ACPI_PCI_REGISTER(a) (UINT16) ((a) & 0x0000FFFF)
#endif #endif
@ -313,7 +360,6 @@
* *
* The DataType field is the first field in both structures. * The DataType field is the first field in both structures.
*/ */
#define VALID_DESCRIPTOR_TYPE(d,t) (((ACPI_NAMESPACE_NODE *)d)->DataType == t) #define VALID_DESCRIPTOR_TYPE(d,t) (((ACPI_NAMESPACE_NODE *)d)->DataType == t)
@ -325,13 +371,16 @@
#define IS_SINGLE_TABLE(x) (((x) & 0x01) == ACPI_TABLE_SINGLE ? 1 : 0) #define IS_SINGLE_TABLE(x) (((x) & 0x01) == ACPI_TABLE_SINGLE ? 1 : 0)
/* Check if ACPI has been initialized properly */
#define ACPI_IS_INITIALIZATION_COMPLETE(s) {if (AcpiGbl_RootNode) s = AE_OK; else s=AE_NO_NAMESPACE;}
/* /*
* Macro to check if a pointer is within an ACPI table. * Macro to check if a pointer is within an ACPI table.
* Parameter (a) is the pointer to check. Parameter (b) must be defined * Parameter (a) is the pointer to check. Parameter (b) must be defined
* as a pointer to an ACPI_TABLE_HEADER. (b+1) then points past the header, * as a pointer to an ACPI_TABLE_HEADER. (b+1) then points past the header,
* and ((UINT8 *)b+b->Length) points one byte past the end of the table. * and ((UINT8 *)b+b->Length) points one byte past the end of the table.
*/ */
#ifndef _IA16 #ifndef _IA16
#define IS_IN_ACPI_TABLE(a,b) (((UINT8 *)(a) >= (UINT8 *)(b + 1)) &&\ #define IS_IN_ACPI_TABLE(a,b) (((UINT8 *)(a) >= (UINT8 *)(b + 1)) &&\
((UINT8 *)(a) < ((UINT8 *)b + b->Length))) ((UINT8 *)(a) < ((UINT8 *)b + b->Length)))
@ -345,11 +394,10 @@
/* /*
* Macros for the master AML opcode table * Macros for the master AML opcode table
*/ */
#ifdef ACPI_DEBUG #ifdef ACPI_DEBUG
#define OP_INFO_ENTRY(Flags,Name,PArgs,IArgs) {Flags,PArgs,IArgs,Name} #define ACPI_OP(Name,PArgs,IArgs,Flags) {PArgs,IArgs,Flags,Name}
#else #else
#define OP_INFO_ENTRY(Flags,Name,PArgs,IArgs) {Flags,PArgs,IArgs} #define ACPI_OP(Name,PArgs,IArgs,Flags) {PArgs,IArgs,Flags}
#endif #endif
#define ARG_TYPE_WIDTH 5 #define ARG_TYPE_WIDTH 5
@ -413,35 +461,35 @@
#ifdef ACPI_DEBUG #ifdef ACPI_DEBUG
#define REPORT_INFO(fp) {_ReportInfo(_THIS_MODULE,__LINE__,_COMPONENT); \ #define REPORT_INFO(fp) {_ReportInfo(_THIS_MODULE,__LINE__,_COMPONENT); \
DebugPrintRaw PARAM_LIST(fp);} AcpiOsPrintf PARAM_LIST(fp);}
#define REPORT_ERROR(fp) {_ReportError(_THIS_MODULE,__LINE__,_COMPONENT); \ #define REPORT_ERROR(fp) {_ReportError(_THIS_MODULE,__LINE__,_COMPONENT); \
DebugPrintRaw PARAM_LIST(fp);} AcpiOsPrintf PARAM_LIST(fp);}
#define REPORT_WARNING(fp) {_ReportWarning(_THIS_MODULE,__LINE__,_COMPONENT); \ #define REPORT_WARNING(fp) {_ReportWarning(_THIS_MODULE,__LINE__,_COMPONENT); \
DebugPrintRaw PARAM_LIST(fp);} AcpiOsPrintf PARAM_LIST(fp);}
#else #else
#define REPORT_INFO(fp) {_ReportInfo("ACPI",__LINE__,_COMPONENT); \ #define REPORT_INFO(fp) {_ReportInfo("ACPI",__LINE__,_COMPONENT); \
DebugPrintRaw PARAM_LIST(fp);} AcpiOsPrintf PARAM_LIST(fp);}
#define REPORT_ERROR(fp) {_ReportError("ACPI",__LINE__,_COMPONENT); \ #define REPORT_ERROR(fp) {_ReportError("ACPI",__LINE__,_COMPONENT); \
DebugPrintRaw PARAM_LIST(fp);} AcpiOsPrintf PARAM_LIST(fp);}
#define REPORT_WARNING(fp) {_ReportWarning("ACPI",__LINE__,_COMPONENT); \ #define REPORT_WARNING(fp) {_ReportWarning("ACPI",__LINE__,_COMPONENT); \
DebugPrintRaw PARAM_LIST(fp);} AcpiOsPrintf PARAM_LIST(fp);}
#endif #endif
/* Error reporting. These versions pass thru the module and line# */ /* Error reporting. These versions pass thru the module and line# */
#define _REPORT_INFO(a,b,c,fp) {_ReportInfo(a,b,c); \ #define _REPORT_INFO(a,b,c,fp) {_ReportInfo(a,b,c); \
DebugPrintRaw PARAM_LIST(fp);} AcpiOsPrintf PARAM_LIST(fp);}
#define _REPORT_ERROR(a,b,c,fp) {_ReportError(a,b,c); \ #define _REPORT_ERROR(a,b,c,fp) {_ReportError(a,b,c); \
DebugPrintRaw PARAM_LIST(fp);} AcpiOsPrintf PARAM_LIST(fp);}
#define _REPORT_WARNING(a,b,c,fp) {_ReportWarning(a,b,c); \ #define _REPORT_WARNING(a,b,c,fp) {_ReportWarning(a,b,c); \
DebugPrintRaw PARAM_LIST(fp);} AcpiOsPrintf PARAM_LIST(fp);}
/* Buffer dump macros */ /* Buffer dump macros */
#define DUMP_BUFFER(a,b) AcpiCmDumpBuffer((UINT8 *)a,b,DB_BYTE_DISPLAY,_COMPONENT) #define DUMP_BUFFER(a,b) AcpiUtDumpBuffer((UINT8 *)a,b,DB_BYTE_DISPLAY,_COMPONENT)
/* /*
* Debug macros that are conditionally compiled * Debug macros that are conditionally compiled
@ -457,6 +505,7 @@
* as a local string ("_ProcName) so that it can be also used by the function exit macros below. * as a local string ("_ProcName) so that it can be also used by the function exit macros below.
*/ */
#define PROC_NAME(a) char * _ProcName = a;
#define FUNCTION_TRACE(a) char * _ProcName = a;\ #define FUNCTION_TRACE(a) char * _ProcName = a;\
FunctionTrace(_THIS_MODULE,__LINE__,_COMPONENT,a) FunctionTrace(_THIS_MODULE,__LINE__,_COMPONENT,a)
#define FUNCTION_TRACE_PTR(a,b) char * _ProcName = a;\ #define FUNCTION_TRACE_PTR(a,b) char * _ProcName = a;\
@ -491,15 +540,16 @@
/* Stack and buffer dumping */ /* Stack and buffer dumping */
#define DUMP_STACK_ENTRY(a) AcpiAmlDumpOperand(a) #define DUMP_STACK_ENTRY(a) AcpiExDumpOperand(a)
#define DUMP_OPERANDS(a,b,c,d,e) AcpiAmlDumpOperands(a,b,c,d,e,_THIS_MODULE,__LINE__) #define DUMP_OPERANDS(a,b,c,d,e) AcpiExDumpOperands(a,b,c,d,e,_THIS_MODULE,__LINE__)
#define DUMP_ENTRY(a,b) AcpiNsDumpEntry (a,b) #define DUMP_ENTRY(a,b) AcpiNsDumpEntry (a,b)
#define DUMP_TABLES(a,b) AcpiNsDumpTables(a,b) #define DUMP_TABLES(a,b) AcpiNsDumpTables(a,b)
#define DUMP_PATHNAME(a,b,c,d) AcpiNsDumpPathname(a,b,c,d) #define DUMP_PATHNAME(a,b,c,d) AcpiNsDumpPathname(a,b,c,d)
#define DUMP_RESOURCE_LIST(a) AcpiRsDumpResourceList(a) #define DUMP_RESOURCE_LIST(a) AcpiRsDumpResourceList(a)
#define BREAK_MSG(a) AcpiOsBreakpoint (a) #define BREAK_MSG(a) AcpiOsSignal (ACPI_SIGNAL_BREAKPOINT,(a))
/* /*
* Generate INT3 on ACPI_ERROR (Debug only!) * Generate INT3 on ACPI_ERROR (Debug only!)
@ -507,7 +557,7 @@
#define ERROR_BREAK #define ERROR_BREAK
#ifdef ERROR_BREAK #ifdef ERROR_BREAK
#define BREAK_ON_ERROR(lvl) if ((lvl)&ACPI_ERROR) AcpiOsBreakpoint("Fatal error encountered\n") #define BREAK_ON_ERROR(lvl) if ((lvl)&ACPI_ERROR) AcpiOsSignal(ACPI_SIGNAL_BREAKPOINT,"Fatal error encountered\n")
#else #else
#define BREAK_ON_ERROR(lvl) #define BREAK_ON_ERROR(lvl)
#endif #endif
@ -517,27 +567,10 @@
* Print iff: * Print iff:
* 1) Debug print for the current component is enabled * 1) Debug print for the current component is enabled
* 2) Debug error level or trace level for the print statement is enabled * 2) Debug error level or trace level for the print statement is enabled
*
*/ */
#define TEST_DEBUG_SWITCH(lvl) if (((lvl) & AcpiDbgLevel) && (_COMPONENT & AcpiDbgLayer)) #define ACPI_DEBUG_PRINT(pl) AcpiUtDebugPrint PARAM_LIST(pl)
#define ACPI_DEBUG_PRINT_RAW(pl) AcpiUtDebugPrintRaw PARAM_LIST(pl)
#define DEBUG_PRINT(lvl,fp) TEST_DEBUG_SWITCH(lvl) {\
DebugPrintPrefix (_THIS_MODULE,__LINE__);\
DebugPrintRaw PARAM_LIST(fp);\
BREAK_ON_ERROR(lvl);}
#define DEBUG_PRINT_RAW(lvl,fp) TEST_DEBUG_SWITCH(lvl) {\
DebugPrintRaw PARAM_LIST(fp);}
/* Assert macros */
#define ACPI_ASSERT(exp) if(!(exp)) \
AcpiOsDbgAssert(#exp, __FILE__, __LINE__, "Failed Assertion")
#define DEBUG_ASSERT(msg, exp) if(!(exp)) \
AcpiOsDbgAssert(#exp, __FILE__, __LINE__, msg)
#else #else
@ -554,6 +587,7 @@
#define DEBUG_DEFINE(a) #define DEBUG_DEFINE(a)
#define DEBUG_ONLY_MEMBERS(a) #define DEBUG_ONLY_MEMBERS(a)
#define PROC_NAME(a)
#define FUNCTION_TRACE(a) #define FUNCTION_TRACE(a)
#define FUNCTION_TRACE_PTR(a,b) #define FUNCTION_TRACE_PTR(a,b)
#define FUNCTION_TRACE_U32(a,b) #define FUNCTION_TRACE_U32(a,b)
@ -567,8 +601,8 @@
#define DUMP_TABLES(a,b) #define DUMP_TABLES(a,b)
#define DUMP_PATHNAME(a,b,c,d) #define DUMP_PATHNAME(a,b,c,d)
#define DUMP_RESOURCE_LIST(a) #define DUMP_RESOURCE_LIST(a)
#define DEBUG_PRINT(l,f) #define ACPI_DEBUG_PRINT(pl)
#define DEBUG_PRINT_RAW(l,f) #define ACPI_DEBUG_PRINT_RAW(pl)
#define BREAK_MSG(a) #define BREAK_MSG(a)
#define return_VOID return #define return_VOID return
@ -576,9 +610,6 @@
#define return_VALUE(s) return(s) #define return_VALUE(s) return(s)
#define return_PTR(s) return(s) #define return_PTR(s) return(s)
#define ACPI_ASSERT(exp)
#define DEBUG_ASSERT(msg, exp)
#endif #endif
/* /*
@ -625,69 +656,26 @@
* Memory allocation tracking (DEBUG ONLY) * Memory allocation tracking (DEBUG ONLY)
*/ */
#ifndef ACPI_DEBUG_TRACK_ALLOCATIONS #ifndef ACPI_DBG_TRACK_ALLOCATIONS
#define AcpiCmAddElementToAllocList(a,b,c,d,e,f) /* Memory allocation */
#define AcpiCmDeleteElementFromAllocList(a,b,c,d)
#define AcpiCmDumpCurrentAllocations(a,b) #define ACPI_MEM_ALLOCATE(a) AcpiOsAllocate(a)
#define AcpiCmDumpAllocationInfo() #define ACPI_MEM_CALLOCATE(a) AcpiOsCallocate(a)
#define ACPI_MEM_FREE(a) AcpiOsFree(a)
#define ACPI_MEM_TRACKING(a)
#define DECREMENT_OBJECT_METRICS(a)
#define INCREMENT_OBJECT_METRICS(a)
#define INITIALIZE_ALLOCATION_METRICS()
#define DECREMENT_NAME_TABLE_METRICS(a)
#define INCREMENT_NAME_TABLE_METRICS(a)
#else #else
#define INITIALIZE_ALLOCATION_METRICS() \ /* Memory allocation */
AcpiGbl_CurrentObjectCount = 0; \
AcpiGbl_CurrentObjectSize = 0; \
AcpiGbl_RunningObjectCount = 0; \
AcpiGbl_RunningObjectSize = 0; \
AcpiGbl_MaxConcurrentObjectCount = 0; \
AcpiGbl_MaxConcurrentObjectSize = 0; \
AcpiGbl_CurrentAllocSize = 0; \
AcpiGbl_CurrentAllocCount = 0; \
AcpiGbl_RunningAllocSize = 0; \
AcpiGbl_RunningAllocCount = 0; \
AcpiGbl_MaxConcurrentAllocSize = 0; \
AcpiGbl_MaxConcurrentAllocCount = 0; \
AcpiGbl_CurrentNodeCount = 0; \
AcpiGbl_CurrentNodeSize = 0; \
AcpiGbl_MaxConcurrentNodeCount = 0
#define ACPI_MEM_ALLOCATE(a) AcpiUtAllocate(a,_COMPONENT,_THIS_MODULE,__LINE__)
#define ACPI_MEM_CALLOCATE(a) AcpiUtCallocate(a, _COMPONENT,_THIS_MODULE,__LINE__)
#define ACPI_MEM_FREE(a) AcpiUtFree(a,_COMPONENT,_THIS_MODULE,__LINE__)
#define ACPI_MEM_TRACKING(a) a
#define DECREMENT_OBJECT_METRICS(a) \ #endif /* ACPI_DBG_TRACK_ALLOCATIONS */
AcpiGbl_CurrentObjectCount--; \
AcpiGbl_CurrentObjectSize -= a
#define INCREMENT_OBJECT_METRICS(a) \
AcpiGbl_CurrentObjectCount++; \
AcpiGbl_RunningObjectCount++; \
if (AcpiGbl_MaxConcurrentObjectCount < AcpiGbl_CurrentObjectCount) \
{ \
AcpiGbl_MaxConcurrentObjectCount = AcpiGbl_CurrentObjectCount; \
} \
AcpiGbl_RunningObjectSize += a; \
AcpiGbl_CurrentObjectSize += a; \
if (AcpiGbl_MaxConcurrentObjectSize < AcpiGbl_CurrentObjectSize) \
{ \
AcpiGbl_MaxConcurrentObjectSize = AcpiGbl_CurrentObjectSize; \
}
#define DECREMENT_NAME_TABLE_METRICS(a) \
AcpiGbl_CurrentNodeCount--; \
AcpiGbl_CurrentNodeSize -= (a)
#define INCREMENT_NAME_TABLE_METRICS(a) \
AcpiGbl_CurrentNodeCount++; \
AcpiGbl_CurrentNodeSize+= (a); \
if (AcpiGbl_MaxConcurrentNodeCount < AcpiGbl_CurrentNodeCount) \
{ \
AcpiGbl_MaxConcurrentNodeCount = AcpiGbl_CurrentNodeCount; \
}
#endif /* ACPI_DEBUG_TRACK_ALLOCATIONS */
#endif /* ACMACROS_H */ #endif /* ACMACROS_H */