/********************************************************************/ /** Microsoft Generic Packet Scheduler **/ /** Copyright(c) Microsoft Corp., 1996-1997 **/ /********************************************************************/ #ifndef __GPCDBG #define __GPCDBG //*** gpcdbg.h - GPC definitions & prototypes for debug/memory handling // #define GPC_MEM_MARK 'KRAM' /* ///////////////////////////////////////////////////////////////// // // defines // ///////////////////////////////////////////////////////////////// */ #if DBG #undef ASSERT #define ASSERT( Value ) \ { \ if ((ULONG_PTR)(Value) == 0) { \ KdPrint(("** ASSERT Failed ** %s\n",#Value));\ KdPrint(("Assert Failed at line %d in file %s\n",__LINE__,__FILE__));\ DbgBreakPoint(); \ } \ } // // DBG=1 // #define GpcAllocMem( _pAddress,_Length,_Tag ) \ { \ PCHAR _Addr; \ ULONG _Size = (((_Length)+3)&0xfffffffc) + 3*sizeof(ULONG); \ _Addr=ExAllocatePoolWithTag(NonPagedPool,_Size,_Tag ); \ TRACE(MEMORY,_Addr+8,_Length,"GpcAllocMem"); \ if (_Addr) { \ NdisFillMemory(_Addr, _Size, 0x7f); \ *(PULONG)_Addr = _Size; \ *(PULONG)(_Addr+sizeof(ULONG)) = GPC_MEM_MARK; \ *(PULONG)(_Addr+_Size-sizeof(ULONG)) = GPC_MEM_MARK; \ (PVOID)(*_pAddress) = (PVOID)(_Addr + 2*sizeof(ULONG)); \ BytesAllocated += _Size; \ } else { \ *_pAddress = NULL; \ } \ } #define GpcAllocMemWithQuota( _pAddress,_Length,_Tag ) \ { \ PCHAR _Addr; \ ULONG _Size = (((_Length)+3)&0xfffffffc) + 3*sizeof(ULONG); \ try{ \ _Addr=ExAllocatePoolWithQuotaTag(NonPagedPool,_Size,_Tag ); \ } \ except( EXCEPTION_EXECUTE_HANDLER) { \ _Addr=NULL; \ } \ TRACE(MEMORY,_Addr+8,_Length,"GpcAllocMem"); \ if (_Addr) { \ NdisFillMemory(_Addr, _Size, 0x7f); \ *(PULONG)_Addr = _Size; \ *(PULONG)(_Addr+sizeof(ULONG)) = GPC_MEM_MARK; \ *(PULONG)(_Addr+_Size-sizeof(ULONG)) = GPC_MEM_MARK; \ (PVOID)(*_pAddress) = (PVOID)(_Addr + 2*sizeof(ULONG)); \ BytesAllocated += _Size; \ } else { \ *_pAddress = NULL; \ } \ } #define GpcFreeMem( _Address,_Tag ) \ { \ PCHAR _Addr = ((PUCHAR)_Address) - 2*sizeof(ULONG); \ ULONG _Size = *(PULONG)_Addr; \ TRACE(MEMORY,_Address,_Size-12,"GpcFreeMem"); \ ASSERT(*(PULONG)(_Addr+sizeof(ULONG)) == GPC_MEM_MARK); \ ASSERT(*(PULONG)(_Addr+_Size-sizeof(ULONG)) == GPC_MEM_MARK); \ NdisFillMemory(_Addr, _Size, 0xCC); \ ExFreePool( _Addr ); \ BytesAllocated -= _Size; \ } #define GpcAllocFromLL(_ptr, _list, _tag) \ { \ PCHAR _Addr; \ if (_Addr = (PCHAR)NdisAllocateFromNPagedLookasideList(_list)) { \ *(PULONG)(_Addr) = GPC_MEM_MARK; \ (PVOID)(*_ptr) = (PVOID)(_Addr + sizeof(ULONG_PTR)); \ TRACE(MEMORY,_tag,*_ptr,"GpcAllocFromLL"); \ } else { \ *_ptr = NULL; \ } \ } #define GpcFreeToLL(_ptr, _list, _tag) \ { \ PCHAR _Addr = ((PUCHAR)_ptr) - sizeof(ULONG_PTR); \ ASSERT(*(PULONG)_Addr == GPC_MEM_MARK); \ *(PULONG)_Addr = 0x77777777; \ NdisFreeToNPagedLookasideList(_list, _Addr); \ TRACE(MEMORY,_tag,_ptr,"GpcFreeToLL"); \ } #define GET_IRQL(_i) _i = KeGetCurrentIrql() #define VERIFY_IRQL(_i) ASSERT((_i)==KeGetCurrentIrql()) #define DEFINE_KIRQL(_i) KIRQL _i #else // DBG != 1 #define GpcAllocMem( Addr,Len,_Tag ) \ *Addr = ExAllocatePoolWithTag(NonPagedPool, Len, _Tag ) #define GpcAllocMemWithQuota( Addr,Len,_Tag ) \ try{ \ *Addr=ExAllocatePoolWithQuotaTag(NonPagedPool,Len,_Tag ); \ } \ except( EXCEPTION_EXECUTE_HANDLER) { \ *Addr=NULL; \ } #define GpcFreeMem( Address,_Tag ) \ ExFreePool( (Address) ) #define GpcAllocFromLL(_ptr, _list, _tag) \ *_ptr = NdisAllocateFromNPagedLookasideList(_list) #define GpcFreeToLL(_ptr, _list, _tag) \ NdisFreeToNPagedLookasideList(_list, _ptr) #define GET_IRQL(_i) #define VERIFY_IRQL(_i) #define DEFINE_KIRQL(_i) #endif // if DBG #if DBG #define LockedIncrement( Count,_p ) LockedInc(Count,__FILE__,__LINE__,_p) #else #define LockedIncrement( Count,_p ) NdisInterlockedIncrement((PLONG)Count) #endif #if DBG #define LockedDecrement( Count,_p ) LockedDec(Count,__FILE__,__LINE__,_p) #else #define LockedDecrement( Count,_p ) NdisInterlockedDecrement((PLONG)Count) #endif #define KD_PRINT 0x00000001 #define INIT 0x00000002 #define BLOB 0x00000004 #define PATTERN 0x00000008 #define NOTIFY 0x00000010 #define REGISTER 0x00000020 #define MEMORY 0x00000040 #define LOOKUP 0x00000080 #define LOCKS 0x00000100 #define CLASSIFY 0x00000200 #define RHIZOME 0x00000400 #define PATHASH 0x00000800 #define IOCTL 0x00001000 #define CLIENT 0x00002000 #define MAPHAND 0x00004000 #define CLASSHAND 0x00008000 #define PAT_TIMER 0x00010000 #define REFCOUNT 0x00020000 #define PARAM_EX 0x80000000 // this is reserved for the trace routine #if DBG #define DBGPRINT(Mask, String) \ { \ if(Mask & DbgPrintFlags)\ DbgPrint String;\ } #define TRACE( Mask,P1,P2,_fname ) \ { \ if (Mask & DebugFlags)\ TraceRtn((PUCHAR)__FILE__,(ULONG)__LINE__,_fname,(ULONG_PTR)(P1),(ULONG_PTR)(P2),KeGetCurrentProcessorNumber(),KeGetCurrentIrql(),Mask|PARAM_EX);\ } #else #define DBGPRINT(Mask, String) #define TRACE( Mask,P1,P2,_fname ) #endif /* ///////////////////////////////////////////////////////////////// // // externs & prototypes // ///////////////////////////////////////////////////////////////// */ extern ULONG DebugFlags; extern ULONG DbgPrintFlags; extern ULONG BytesAllocated; VOID TraceRtn( IN UCHAR *File, IN ULONG Line, IN UCHAR *FuncName, IN ULONG_PTR Param1, IN ULONG_PTR Param2, IN ULONG Param3, IN ULONG Param4, IN ULONG Mask ); _inline LONGLONG GetTime( VOID ) /*++ Routine Description: Get the current system time Arguments: Return Value: System time (in base OS time units) --*/ { LARGE_INTEGER Now; LARGE_INTEGER Frequency; #if defined(PERF_COUNTER) || defined (TRACE_PERF_COUNTER) Now = KeQueryPerformanceCounter(&Frequency); Now.QuadPart = (Now.QuadPart * OS_TIME_SCALE) / Frequency.QuadPart; #else NdisGetCurrentSystemTime( &Now ); #endif return Now.QuadPart; } #define LOGSIZE 4000 // number of entries #define LOGWIDTH 64 // number of characters (one or two bytes) per entry // // typedef struct { UCHAR Row[ LOGWIDTH ]; LONGLONG Time; ULONG Line; ULONG_PTR P1; ULONG_PTR P2; ULONG P3; ULONG P4; } ROW, *PROW; typedef struct { ULONG Index; PROW Current; PROW Buffer; ULONG Wraps; } LOG, *PLOG; _inline VOID DbgVerifyList( PLIST_ENTRY h ) { PLIST_ENTRY p = h->Flink; PLIST_ENTRY q = h; int m = 1000; if (h->Flink == h) { ASSERT(h->Blink == h); } while (p != h && m > 0) { ASSERT(p->Blink == q); q = p; p = p->Flink; m--; } ASSERT(m > 0); } #endif //__GPCDBG