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.
301 lines
7.8 KiB
301 lines
7.8 KiB
/*****************************************************************************
|
|
*
|
|
* Copyright (c) 1998-1999 Microsoft Corporation
|
|
*
|
|
* DEBUG.C - debugging functions, etc.
|
|
*
|
|
* Author: Stan Adermann (stana)
|
|
*
|
|
* Created: 9/2/1998
|
|
*
|
|
*****************************************************************************/
|
|
|
|
#include "raspptp.h"
|
|
|
|
#include "debug.tmh"
|
|
|
|
#if MEM_CHECKING
|
|
typedef struct MEM_HDR {
|
|
LIST_ENTRY ListEntry;
|
|
ULONG Size;
|
|
CHAR File[16];
|
|
ULONG Line;
|
|
} MEM_HDR;
|
|
|
|
LIST_ENTRY leAlloc;
|
|
NDIS_SPIN_LOCK slAlloc;
|
|
|
|
VOID InitMemory()
|
|
{
|
|
NdisAllocateSpinLock(&slAlloc);
|
|
NdisInitializeListHead(&leAlloc);
|
|
}
|
|
|
|
VOID DeinitMemory()
|
|
{
|
|
PLIST_ENTRY ListEntry;
|
|
|
|
NdisAcquireSpinLock(&slAlloc);
|
|
for (ListEntry=leAlloc.Flink;
|
|
ListEntry!=&leAlloc;
|
|
ListEntry = ListEntry->Flink)
|
|
{
|
|
MEM_HDR *Hdr = (MEM_HDR*)ListEntry;
|
|
DEBUGMSG(DBG_ERROR, (DTEXT("PPTP Unfreed Memory:%p size:%X <%s:%d>\n"),
|
|
&Hdr[1], Hdr->Size, Hdr->File, Hdr->Line));
|
|
WPLOG(LL_A, LM_Res, ("PPTP Unfreed Memory:%p size:%X <%s:%d>",
|
|
&Hdr[1], Hdr->Size, Hdr->File, Hdr->Line));
|
|
|
|
|
|
}
|
|
NdisReleaseSpinLock(&slAlloc);
|
|
NdisFreeSpinLock(&slAlloc);
|
|
}
|
|
#endif
|
|
|
|
#if MEM_CHECKING
|
|
PVOID
|
|
_MyMemAlloc(UINT size, ULONG tag, PUCHAR file, UINT line)
|
|
#else
|
|
PVOID
|
|
MyMemAlloc(UINT size, ULONG tag)
|
|
#endif
|
|
{
|
|
PVOID memptr;
|
|
NDIS_STATUS status;
|
|
|
|
#if MEM_CHECKING
|
|
status = NdisAllocateMemoryWithTag(&memptr, size+sizeof(MEM_HDR), tag);
|
|
#else
|
|
status = NdisAllocateMemoryWithTag(&memptr, size, tag);
|
|
#endif
|
|
|
|
if (status != NDIS_STATUS_SUCCESS)
|
|
{
|
|
DEBUGMSG(DBG_ERROR, (DTEXT("Memory allocation failed <%s:%d>.\n"),
|
|
file, line));
|
|
WPLOG(LL_A, LM_Res, ("Memory allocation failed size %d tag %x", size, tag));
|
|
|
|
memptr = NULL;
|
|
|
|
gCounters.ulMemAllocFail++;
|
|
}
|
|
#if MEM_CHECKING
|
|
else
|
|
{
|
|
MEM_HDR *Hdr = memptr;
|
|
UINT FileNameLen = strlen(file);
|
|
|
|
Hdr->Size = size;
|
|
Hdr->Line = line;
|
|
if (FileNameLen>sizeof(Hdr->File)-1)
|
|
strcpy(Hdr->File, &file[FileNameLen-sizeof(Hdr->File)+1]);
|
|
else
|
|
strcpy(Hdr->File, file);
|
|
MyInterlockedInsertHeadList(&leAlloc, &Hdr->ListEntry, &slAlloc);
|
|
memptr = &Hdr[1];
|
|
}
|
|
#endif
|
|
|
|
return memptr;
|
|
}
|
|
|
|
|
|
VOID
|
|
MyMemFree(
|
|
PVOID memptr,
|
|
UINT size
|
|
)
|
|
{
|
|
#if MEM_CHECKING
|
|
PLIST_ENTRY ListEntry;
|
|
MEM_HDR *Hdr = (MEM_HDR*)((PUCHAR)memptr-sizeof(MEM_HDR));
|
|
|
|
NdisAcquireSpinLock(&slAlloc);
|
|
for (ListEntry = leAlloc.Flink;
|
|
ListEntry != &leAlloc;
|
|
ListEntry = ListEntry->Flink)
|
|
{
|
|
if (ListEntry==&Hdr->ListEntry)
|
|
{
|
|
RemoveEntryList(&Hdr->ListEntry);
|
|
break;
|
|
}
|
|
}
|
|
if (ListEntry==&leAlloc)
|
|
{
|
|
DEBUGMSG(DBG_ERROR, (DTEXT("PPTP: Freeing memory not owned %p\n"), memptr));
|
|
WPLOG(LL_A, LM_Res, ("PPTP: Freeing memory not owned %p", memptr));
|
|
}
|
|
NdisReleaseSpinLock(&slAlloc);
|
|
|
|
NdisFreeMemory(Hdr, size+sizeof(MEM_HDR), 0);
|
|
#else
|
|
NdisFreeMemory(memptr, size, 0);
|
|
#endif
|
|
}
|
|
|
|
#if LIST_CHECKING
|
|
VOID FASTCALL CheckList(PLIST_ENTRY ListHead)
|
|
{
|
|
PLIST_ENTRY ListEntry, PrevListEntry;
|
|
|
|
if (ListHead->Flink==ListHead)
|
|
{
|
|
if (ListHead->Blink!=ListHead)
|
|
{
|
|
DEBUGMSG(DBG_ERROR|DBG_BREAK,(DTEXT("PPTP: Corrupt list head:%p Flink:%p Blink:%p\n"), ListHead, ListHead->Flink, ListHead->Blink));
|
|
WPLOG(LL_A, LM_Res, ("PPTP: Corrupt list head:%p Flink:%p Blink:%p", ListHead, ListHead->Flink, ListHead->Blink));
|
|
}
|
|
}
|
|
else
|
|
{
|
|
ListEntry = ListHead;
|
|
|
|
do
|
|
{
|
|
PrevListEntry = ListEntry;
|
|
ListEntry = ListEntry->Flink;
|
|
|
|
if (ListEntry->Blink!=PrevListEntry)
|
|
{
|
|
DEBUGMSG(DBG_ERROR|DBG_BREAK, (DTEXT("PPTP: Corrupt LIST_ENTRY Head:%p %p->Flink==%p %p->Blink==%p\n"),
|
|
ListHead, PrevListEntry, PrevListEntry->Flink, ListEntry, ListEntry->Blink));
|
|
WPLOG(LL_A, LM_Res, ("PPTP: Corrupt LIST_ENTRY Head:%p %p->Flink==%p %p->Blink==%p",
|
|
ListHead, PrevListEntry, PrevListEntry->Flink, ListEntry, ListEntry->Blink));
|
|
}
|
|
} while (ListEntry!=ListHead);
|
|
}
|
|
}
|
|
|
|
// Check if the entry exists in the list
|
|
BOOLEAN FASTCALL CheckListEntry(PLIST_ENTRY ListHead, PLIST_ENTRY Entry)
|
|
{
|
|
PLIST_ENTRY ListEntry;
|
|
|
|
ListEntry = ListHead->Flink;
|
|
|
|
while(ListEntry != ListHead)
|
|
{
|
|
if(ListEntry == Entry)
|
|
{
|
|
return TRUE;
|
|
}
|
|
|
|
ListEntry = ListEntry->Flink;
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
PLIST_ENTRY FASTCALL MyInterlockedInsertHeadList(PLIST_ENTRY Head, PLIST_ENTRY Entry, PNDIS_SPIN_LOCK SpinLock)
|
|
{
|
|
PLIST_ENTRY RetVal;
|
|
|
|
NdisAcquireSpinLock(SpinLock);
|
|
if (IsListEmpty(Head))
|
|
RetVal = NULL;
|
|
else
|
|
RetVal = Head->Flink;
|
|
InsertHeadList(Head, Entry);
|
|
NdisReleaseSpinLock(SpinLock);
|
|
|
|
return RetVal;
|
|
}
|
|
|
|
PLIST_ENTRY FASTCALL MyInterlockedInsertTailList(PLIST_ENTRY Head, PLIST_ENTRY Entry, PNDIS_SPIN_LOCK SpinLock)
|
|
{
|
|
PLIST_ENTRY RetVal;
|
|
|
|
NdisAcquireSpinLock(SpinLock);
|
|
if (IsListEmpty(Head))
|
|
RetVal = NULL;
|
|
else
|
|
RetVal = Head->Blink;
|
|
InsertTailList(Head, Entry);
|
|
NdisReleaseSpinLock(SpinLock);
|
|
|
|
return RetVal;
|
|
}
|
|
|
|
PLIST_ENTRY FASTCALL MyInterlockedRemoveHeadList(PLIST_ENTRY Head, PNDIS_SPIN_LOCK SpinLock)
|
|
{
|
|
PLIST_ENTRY RetVal;
|
|
NdisAcquireSpinLock(SpinLock);
|
|
//RemoveHeadList uses RemoveEntryList, which is redefined to call CheckList in DEBUG.H
|
|
RetVal = RemoveHeadList(Head);
|
|
|
|
if (RetVal==Head)
|
|
RetVal = NULL;
|
|
else
|
|
RetVal->Flink = RetVal->Blink = NULL;
|
|
NdisReleaseSpinLock(SpinLock);
|
|
|
|
return RetVal;
|
|
}
|
|
|
|
|
|
#define CASE_RETURN_NAME(x) case x: return DTEXT(#x)
|
|
|
|
#ifdef DBG
|
|
|
|
char *ControlStateToString(ULONG State)
|
|
{
|
|
switch( State ){
|
|
CASE_RETURN_NAME(STATE_CTL_INVALID);
|
|
CASE_RETURN_NAME(STATE_CTL_LISTEN);
|
|
CASE_RETURN_NAME(STATE_CTL_DIALING);
|
|
CASE_RETURN_NAME(STATE_CTL_WAIT_REQUEST);
|
|
CASE_RETURN_NAME(STATE_CTL_WAIT_REPLY);
|
|
CASE_RETURN_NAME(STATE_CTL_ESTABLISHED);
|
|
CASE_RETURN_NAME(STATE_CTL_WAIT_STOP);
|
|
CASE_RETURN_NAME(STATE_CTL_CLEANUP);
|
|
default:
|
|
return DTEXT("UNKNOWN CONTROL STATE");
|
|
}
|
|
}
|
|
|
|
|
|
char *CallStateToString(ULONG State)
|
|
{
|
|
switch( State ){
|
|
CASE_RETURN_NAME(STATE_CALL_INVALID);
|
|
CASE_RETURN_NAME(STATE_CALL_CLOSED);
|
|
CASE_RETURN_NAME(STATE_CALL_IDLE);
|
|
CASE_RETURN_NAME(STATE_CALL_OFFHOOK);
|
|
CASE_RETURN_NAME(STATE_CALL_OFFERING);
|
|
CASE_RETURN_NAME(STATE_CALL_PAC_OFFERING);
|
|
CASE_RETURN_NAME(STATE_CALL_PAC_WAIT);
|
|
CASE_RETURN_NAME(STATE_CALL_DIALING);
|
|
CASE_RETURN_NAME(STATE_CALL_PROCEEDING);
|
|
CASE_RETURN_NAME(STATE_CALL_ESTABLISHED);
|
|
CASE_RETURN_NAME(STATE_CALL_WAIT_DISCONNECT);
|
|
CASE_RETURN_NAME(STATE_CALL_CLEANUP);
|
|
default:
|
|
return DTEXT("UNKNOWN CALL STATE");
|
|
}
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
#if LOCK_CHECKING
|
|
VOID FASTCALL
|
|
_MyAcquireSpinLock(
|
|
PMY_SPIN_LOCK pLock,
|
|
PUCHAR file,
|
|
UINT line
|
|
)
|
|
{
|
|
UINT FileNameLen = strlen(file);
|
|
NdisAcquireSpinLock((PNDIS_SPIN_LOCK)pLock);
|
|
if (FileNameLen>sizeof(pLock->File)-1)
|
|
strcpy(pLock->File, &file[FileNameLen-sizeof(pLock->File)+1]);
|
|
else
|
|
strcpy(pLock->File, file);
|
|
pLock->Line = line;
|
|
}
|
|
#endif
|