mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
320 lines
12 KiB
320 lines
12 KiB
/*++
|
|
|
|
Copyright (c) 1995-1999 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
debug.h
|
|
|
|
Abstract:
|
|
|
|
debug defines shared between the KD extensions and the driver
|
|
|
|
Author:
|
|
|
|
Charlie Wickham (charlwi) 11-May-1995
|
|
|
|
Revision History:
|
|
|
|
--*/
|
|
|
|
#ifndef _DEBUG_
|
|
#define _DEBUG_
|
|
|
|
//
|
|
//
|
|
// Debug Level and Mask definitions.
|
|
//
|
|
|
|
#define DBG_DEATH 1
|
|
#define DBG_CRITICAL_ERROR 2
|
|
#define DBG_FAILURE 4
|
|
#define DBG_INFO 6
|
|
#define DBG_TRACE 8
|
|
#define DBG_VERBOSE 10
|
|
|
|
#define DBG_INIT 0x00000001
|
|
#define DBG_MINIPORT 0x00000002
|
|
#define DBG_PROTOCOL 0x00000004
|
|
#define DBG_SEND 0x00000008
|
|
#define DBG_RECEIVE 0x00000010
|
|
#define DBG_IO 0x00000020
|
|
#define DBG_MEMORY 0x00000040
|
|
#define DBG_CM 0x00000080
|
|
#define DBG_REFCNTS 0x00000100
|
|
#define DBG_VC 0x00000200
|
|
#define DBG_GPC_QOS 0x00000400
|
|
#define DBG_WAN 0x00000800
|
|
#define DBG_STATE 0x00001000
|
|
#define DBG_ROUTINEOIDS 0x00002000
|
|
#define DBG_SCHED_TBC 0x00004000
|
|
#define DBG_SCHED_SHAPER 0x00008000
|
|
#define DBG_SCHED_DRR 0x00010000
|
|
#define DBG_WMI 0x00020000
|
|
#define DBG_ZAW 0x00040000
|
|
#define DBG_ALL 0xFFFFFFFF
|
|
|
|
//
|
|
// these tags are used in Lookaside lists therefore need to be
|
|
// available regardless of the type of build
|
|
//
|
|
|
|
extern ULONG NdisRequestTag;
|
|
extern ULONG GpcClientVcTag;
|
|
extern ULONG WanLinkTag;
|
|
extern ULONG PsMiscTag;
|
|
extern ULONG WMITag;
|
|
#define NDIS_PACKET_POOL_TAG_FOR_PSCHED 'pPDN'
|
|
|
|
// We mark all memory allocated via PsAllocateXXX with a signature
|
|
// immediately following allocation, and with another signature
|
|
// immediately preceeding freeing.
|
|
|
|
#define ALLOCATED_MARK (UCHAR) 0xDD
|
|
#define FREED_MARK (UCHAR) 0xBB
|
|
|
|
//
|
|
// NT Debugging routines
|
|
//
|
|
|
|
|
|
//
|
|
// signatures for data structures
|
|
//
|
|
|
|
extern ULONG AdapterTag;
|
|
extern ULONG CmParamsTag;
|
|
extern ULONG PipeContextTag;
|
|
extern ULONG FlowContextTag;
|
|
extern ULONG ClassMapContextTag;
|
|
extern ULONG ProfileTag;
|
|
extern ULONG ComponentTag;
|
|
extern ULONG WanTableTag;
|
|
|
|
#if DBG
|
|
extern CHAR VersionNumber[];
|
|
extern CHAR VersionHerald[];
|
|
extern CHAR VersionTimestamp[];
|
|
|
|
#define DEBUGCHK DbgBreakPoint()
|
|
|
|
#define STATIC
|
|
|
|
//
|
|
// these correspond to DebugLevel and DebugMask in Psched\Parameters
|
|
//
|
|
|
|
extern ULONG DbgTraceLevel;
|
|
extern ULONG DbgTraceMask;
|
|
extern ULONG LogTraceLevel;
|
|
extern ULONG LogTraceMask;
|
|
extern ULONG LogId;
|
|
extern ULONG DbgTraceControl;
|
|
|
|
#define PsDbgSched(_DebugLevel, _DebugMask, _r, _s, _t, _u, _v, _w, _x1, _x2, _y, _z){\
|
|
if ((LogTraceLevel >= _DebugLevel) && \
|
|
((_DebugMask) & LogTraceMask)){ \
|
|
DbugSched(_r, _s, _t, _u, _v, _w, (_x1), (_x2), _y, _z);\
|
|
}\
|
|
}
|
|
|
|
#define PsDbgRecv(_DebugLevel, _DebugMask, _event, _action, _a, _p1, _p2) {\
|
|
if ((LogTraceLevel >= _DebugLevel) && \
|
|
((_DebugMask) & LogTraceMask)){ \
|
|
DbugRecv(_event, _action, _a, _p1, _p2); \
|
|
} \
|
|
}
|
|
|
|
#define PsDbgSend(_DebugLevel, _DebugMask, _event, _action, _a, _v, _p1, _p2) {\
|
|
if ((LogTraceLevel >= _DebugLevel) && \
|
|
((_DebugMask) & LogTraceMask)){ \
|
|
DbugSend(_event, _action, _a, _v, _p1, _p2); \
|
|
} \
|
|
}
|
|
|
|
#define PsDbgOid(_DebugLevel, _DebugMask, Action, Local, PTState, MPState, Adapter, Oid, Status) {\
|
|
if ((LogTraceLevel >= _DebugLevel) && \
|
|
((_DebugMask) & LogTraceMask)){ \
|
|
DbugOid(Action, Local, PTState, MPState, Adapter, Oid, Status); \
|
|
} \
|
|
}
|
|
|
|
#define PsDbgOut(_DebugLevel, _DebugMask, _Out){ \
|
|
if ((DbgTraceLevel >= _DebugLevel) && \
|
|
((_DebugMask) & DbgTraceMask)){ \
|
|
DbgPrint("PSched: "); \
|
|
DbgPrint _Out; \
|
|
} \
|
|
if ((LogTraceLevel >= _DebugLevel) && \
|
|
((_DebugMask) & LogTraceMask)){ \
|
|
DbugSchedString _Out; \
|
|
} \
|
|
}
|
|
|
|
#define PsDbgOutNoID(_DebugLevel, _DebugMask, _Out) { \
|
|
if ((DbgTraceLevel >= _DebugLevel) && \
|
|
((_DebugMask) & DbgTraceMask)){ \
|
|
DbgPrint _Out; \
|
|
} \
|
|
if ((LogTraceLevel >= _DebugLevel) && \
|
|
((_DebugMask) & LogTraceMask)){ \
|
|
DbugSchedString _Out; \
|
|
} \
|
|
}
|
|
|
|
#define PS_LOCK(_s) { \
|
|
NdisAcquireSpinLock(&((_s)->Lock)); \
|
|
PsAssert((_s)->LockAcquired == FALSE); \
|
|
(_s)->LockAcquired = TRUE; \
|
|
(_s)->LastAcquiredLine = __LINE__; \
|
|
strncpy((_s)->LastAcquiredFile, strrchr(__FILE__, '\\')+1, 7); \
|
|
}
|
|
|
|
#define PS_UNLOCK(_s) \
|
|
{ \
|
|
PsAssert((_s)->LockAcquired == TRUE); \
|
|
(_s)->LockAcquired = FALSE; \
|
|
(_s)->LastReleasedLine = __LINE__; \
|
|
strncpy((_s)->LastReleasedFile, strrchr(__FILE__, '\\')+1, 7); \
|
|
NdisReleaseSpinLock(&((_s)->Lock)); \
|
|
}
|
|
|
|
#define PS_LOCK_DPC(_s) { \
|
|
PsAssert(KeGetCurrentIrql() == DISPATCH_LEVEL); \
|
|
NdisDprAcquireSpinLock(&((_s)->Lock)); \
|
|
PsAssert((_s)->LockAcquired == FALSE); \
|
|
(_s)->LockAcquired = TRUE; \
|
|
(_s)->LastAcquiredLine = __LINE__; \
|
|
strncpy((_s)->LastAcquiredFile, strrchr(__FILE__, '\\')+1, 7); \
|
|
}
|
|
|
|
#define PS_UNLOCK_DPC(_s) \
|
|
{ \
|
|
PsAssert(KeGetCurrentIrql() == DISPATCH_LEVEL); \
|
|
PsAssert((_s)->LockAcquired == TRUE); \
|
|
(_s)->LockAcquired = FALSE; \
|
|
(_s)->LastReleasedLine = __LINE__; \
|
|
strncpy((_s)->LastReleasedFile, strrchr(__FILE__, '\\')+1, 7); \
|
|
NdisDprReleaseSpinLock(&((_s)->Lock)); \
|
|
}
|
|
|
|
#define PS_INIT_SPIN_LOCK(_s) { \
|
|
(_s)->LockAcquired = FALSE; \
|
|
(_s)->LastAcquiredLine = __LINE__; \
|
|
strncpy((_s)->LastAcquiredFile, strrchr(__FILE__, '\\')+1, 7); \
|
|
NdisAllocateSpinLock(&((_s)->Lock)); \
|
|
}
|
|
|
|
#define KdPrint( x ) DbgPrint x
|
|
|
|
#define STRUCT_LLTAG ULONG LLTag
|
|
|
|
#define PsStructAssert(_tag) if ((_tag) != NULL && *(PULONG)((PUCHAR)_tag - sizeof(ULONG)) != _tag##Tag) {\
|
|
DbgPrint( "PSched: structure assertion failure for type " #_tag " in file " __FILE__ " line %d\n", __LINE__ );\
|
|
DEBUGCHK;\
|
|
}
|
|
|
|
#define PsAssert(c) if (!(c)) {\
|
|
DbgPrint( "PSched: assertion @ line %d in file " __FILE__ " \n", __LINE__ );\
|
|
DEBUGCHK;\
|
|
}
|
|
|
|
//
|
|
// allocate memory from nonpaged pool and set the tag in the checked
|
|
// version of the structure
|
|
//
|
|
|
|
#define PsAllocatePool( _addr, _size, _tag ) \
|
|
{ \
|
|
PCHAR _Temp; \
|
|
ULONG _Size = (_size) + 2 * sizeof(ULONG); \
|
|
_Temp = ExAllocatePoolWithTag( NonPagedPool, (_Size), (_tag)); \
|
|
if ( _Temp ) { \
|
|
NdisFillMemory( _Temp, _Size, ALLOCATED_MARK); \
|
|
*(PULONG)_Temp = _Size; \
|
|
*(PULONG)(_Temp + sizeof(ULONG)) = _tag; \
|
|
(PCHAR)(_addr) = _Temp + 2 * sizeof(ULONG); \
|
|
} \
|
|
else{ \
|
|
(PCHAR)(_addr) = _Temp; \
|
|
} \
|
|
}
|
|
|
|
#define PsFreePool(_addr) \
|
|
{ \
|
|
PCHAR _Temp = (PCHAR)(_addr) - 2 * sizeof(ULONG); \
|
|
ULONG _Size = *(PULONG)_Temp; \
|
|
NdisFillMemory( _Temp, _Size, FREED_MARK); \
|
|
ExFreePool(_Temp); \
|
|
}
|
|
|
|
//
|
|
// structures allocated from lookaside lists don't go through PsAllocateXXX.
|
|
// so - if we wanna tag these, we'll have to macro the LL routines.
|
|
//
|
|
|
|
#define PsAllocFromLL(_ptr, _list, _tag) \
|
|
*_ptr = NdisAllocateFromNPagedLookasideList(_list); \
|
|
if(*_ptr != 0) {\
|
|
*_ptr->LLTag = _tag##Tag; \
|
|
}
|
|
|
|
#define PsFreeToLL(_ptr, _list, _tag) \
|
|
PsAssert(_ptr->LLTag == _tag##Tag); \
|
|
_ptr->LLTag = (ULONG)0; \
|
|
NdisFreeToNPagedLookasideList(_list, _ptr); \
|
|
|
|
#define CheckLLTag(_ptr, _tag) \
|
|
PsAssert(_ptr->LLTag == _tag##Tag);
|
|
|
|
#define SetLLTag(_ptr, _tag) (_ptr)->LLTag = _tag##Tag;
|
|
|
|
#else // DBG
|
|
|
|
#define DEBUGCHK
|
|
#define PsDbgSched(_DebugLevel, _DebugMask, _r, _s, _t, _u, _v, _w, _x1, _x2, _y, _z)
|
|
#define PsDbgRecv(_DebugLevel, _DebugMask, _event, _action, _a, _p1, _p2)
|
|
#define PsDbgSend(_DebugLevel, _DebugMask, _event, _action, _a, _v, _p1, _p2)
|
|
#define PsDbgOut(s,t,u)
|
|
#define PsDbgOid(p,q,s,t,u,v,w,x,y)
|
|
#define PsDbgOutNoID(s,t,u)
|
|
#define PsDbg(r, s, t, u)
|
|
#define KdPrint( x )
|
|
#define STRUCT_LLTAG /##/
|
|
#define PsStructAssert( t )
|
|
#define PsAssert(c)
|
|
#define PS_LOCK(_s) NdisAcquireSpinLock(&((_s)->Lock))
|
|
#define PS_UNLOCK(_s) NdisReleaseSpinLock(&((_s)->Lock))
|
|
#define PS_LOCK_DPC(_s) NdisDprAcquireSpinLock(&((_s)->Lock))
|
|
#define PS_UNLOCK_DPC(_s) NdisDprReleaseSpinLock(&((_s)->Lock))
|
|
#define PS_INIT_SPIN_LOCK(_s) NdisAllocateSpinLock(&((_s)->Lock))
|
|
|
|
#define PsAllocatePool( _addr, _size, _tag ) \
|
|
_addr = ExAllocatePoolWithTag( NonPagedPool, (_size), (_tag)); \
|
|
if ( _addr ) { \
|
|
NdisZeroMemory( _addr, _size ); \
|
|
}
|
|
|
|
#define PsFreePool(_addr) ExFreePool(_addr)
|
|
|
|
//
|
|
// structures allocated from lookaside lists don't go through PsAllocateXXX.
|
|
// so - if we wanna tag these, we'll have to macro the LL routines.
|
|
//
|
|
|
|
#define PsAllocFromLL(_ptr, _list, _tag) \
|
|
*_ptr = (PVOID)NdisAllocateFromNPagedLookasideList(_list); \
|
|
|
|
#define PsFreeToLL(_ptr, _list, _tag) \
|
|
NdisFreeToNPagedLookasideList(_list, _ptr);
|
|
|
|
#define CheckLLTag(_ptr, _tag)
|
|
#define SetLLTag(_ptr, _tag)
|
|
|
|
#define STATIC static
|
|
|
|
#endif // DBG
|
|
|
|
#endif /* _DEBUG_ */
|
|
|
|
/* end debug.h */
|