Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

376 lines
7.7 KiB

/*** debug.c - Debug functions
*
* This module contains all the debug functions.
*
* Author: Michael Tsang (MikeTs)
* Created 10/08/97
*
* MODIFICATION HISTORY
* 10/06/98 YanL Modified to be used in WUBIOS.VXD
*/
#include "wubiosp.h"
//Miscellaneous Constants
#ifdef TRACING
#define MAX_TRIG_PTS 10
#define MAX_TRIGPT_LEN 31
#define TF_TRIG_MODE 0x00000001
#endif
//Local function prototypes
#ifdef TRACING
VOID CM_LOCAL TraceIndent(VOID);
BOOL CM_LOCAL IsTrigPt(char *pszProcName);
PCHAR CM_LOCAL InStr(PCHAR pszStr, PCHAR pszSubStr);
VOID CM_INTERNAL DebugSetTraceLevel(VOID);
VOID CM_INTERNAL DebugToggleTrigMode(VOID);
VOID CM_INTERNAL DebugClearTrigPts(VOID);
VOID CM_INTERNAL DebugAddTrigPt(VOID);
VOID CM_INTERNAL DebugZapTrigPt(VOID);
PCHAR CM_LOCAL GetString(PCHAR pszPrompt, PCHAR pszBuff, BYTE bcLen, BOOL fUpper);
#endif
//Local Data
#ifdef TRACING
#pragma CM_DEBUG_DATA
int giTraceLevel = 3, giIndent = 0;
char aszTrigPtBuff[MAX_TRIG_PTS][MAX_TRIGPT_LEN + 1] = {0};
DWORD dwfTrace = 0, dwcTriggers = 0;
#endif
#ifdef DEBUGGER
#pragma CM_DEBUG_DATA
CMDDC DebugCmds[] =
{
#ifdef TRACING
{'t', DebugSetTraceLevel, "set Trace level ", "Set Trace Level"},
{'g', DebugToggleTrigMode, "toGgle trigger mode ", "Toggle Trace Trigger mode"},
{'x', DebugClearTrigPts, "clear trigger points", "Clear all trace trigger points"},
{'y', DebugAddTrigPt, "add trigger point ", "Add a trace trigger point"},
{'z', DebugZapTrigPt, "Zap trigger point ", "Delete a trace trigger point"},
#endif
{'q', NULL, "Quit ", "Quit the debugger"},
{'\0'}
};
#endif //ifdef DEBUGGER
#ifdef TRACING
#pragma CM_DEBUG_DATA
#pragma CM_DEBUG_CODE
/***LP TraceIndent - Indent trace output
*
* ENTRY
* None
*
* EXIT
* None
*/
VOID CM_LOCAL TraceIndent(VOID)
{
int i;
CMDD(WARNNAME ":");
for (i = 0; i < giIndent; i++)
{
CMDD("..");
}
} //TraceIndent
/***LP IsTraceOn - Determine if tracing is on for the given procedure
*
* ENTRY
* n - trace level
* pszProcName -> procedure name
* fEnter - TRUE if EnterProc trace
*
* EXIT-SUCCESS
* returns TRUE
* EXIT-FAILURE
* returns FALSE
*/
BOOL CM_LOCAL IsTraceOn(BYTE n, char *pszProcName, BOOL fEnter)
{
BOOL rc = FALSE;
if ((dwfTrace & TF_TRIG_MODE) && IsTrigPt(pszProcName))
{
if (fEnter)
dwcTriggers++;
else
dwcTriggers--;
rc = TRUE;
}
else if ((n <= giTraceLevel) &&
(!(dwfTrace & TF_TRIG_MODE) || (dwcTriggers > 0)))
{
rc = TRUE;
}
if (rc == TRUE)
TraceIndent();
return rc;
} //IsTraceOn
/***LP IsTrigPt - Find the procedure name in the TrigPt buffer
*
* ENTRY
* pszProcName -> procedure name
*
* EXIT-SUCCESS
* returns TRUE - matched whole or partial name in the TrigPt buffer
* EXIT-FAILURE
* returns FALSE - no match
*/
BOOL CM_LOCAL IsTrigPt(char *pszProcName)
{
BOOL rc = FALSE;
BYTE i;
for (i = 0; (rc == FALSE) && (i < MAX_TRIG_PTS); ++i)
{
if (InStr(pszProcName, &aszTrigPtBuff[i][0]) != NULL)
rc = TRUE;
}
return rc;
} //IsTrigPt
/***LP InStr - Match a sub-string in a given string
*
* ENTRY
* pszStr -> string
* pszSubStr -> sub-string
*
* EXIT-SUCCESS
* returns pointer to the string where the substring is found
* EXIT-FAILURE
* returns NULL
*/
PCHAR CM_LOCAL InStr(PCHAR pszStr, PCHAR pszSubStr)
{
PCHAR psz = NULL;
BYTE bcStrLen = (BYTE)_lstrlen(pszStr);
BYTE bcSubStrLen = (BYTE)_lstrlen(pszSubStr);
_asm
{
cld
mov edi,pszStr
Next:
mov esi,pszSubStr
movzx ecx,BYTE PTR bcStrLen
lodsb
repne scasb
jnz NotFound
movzx ecx,BYTE PTR bcSubStrLen
repe cmpsb
jne Next
movzx ecx,BYTE PTR bcSubStrLen
sub edi,ecx
mov psz,edi
NotFound:
}
return psz;
} //InStr
#endif //ifdef TRACING
#ifdef DEBUGGER
#pragma CM_DEBUG_DATA
#pragma CM_DEBUG_CODE
/***EP WUBIOS_Debug - Debugger entry point
*
* ENTRY
* None
*
* EXIT
* None
*/
VOID CM_SYSCTRL WUBIOS_Debug(VOID)
{
CMDMenu(WARNNAME, DebugCmds);
} //WUBIOS_Debug
#ifdef TRACING
/***LP DebugSetTraceLevel - Set Trace Level
*
* ENTRY
* None
*
* EXIT
* None
*/
VOID CM_INTERNAL DebugSetTraceLevel(VOID)
{
CMDD("\n");
giTraceLevel = (int)CMDReadNumber("Trace Level", 1, FALSE);
CMDD("\n\n");
} //DebugSetTraceLevel
/***LP DebugToggleTrigMode - Toggle Trace Trigger mode
*
* ENTRY
* None
*
* EXIT
* None
*/
VOID CM_INTERNAL DebugToggleTrigMode(VOID)
{
dwfTrace ^= TF_TRIG_MODE;
if (!(dwfTrace & TF_TRIG_MODE))
dwcTriggers = 0;
CMDD("\nTrace Trigger Mode is %s\n\n",
(dwfTrace & TF_TRIG_MODE)? "On": "Off");
} //DebugToggleTrigMode
/***LP DebugClearTrigPts - Clear all trace trigger points
*
* ENTRY
* None
*
* EXIT
* None
*/
VOID CM_INTERNAL DebugClearTrigPts(VOID)
{
BYTE i;
for (i = 0; i < MAX_TRIG_PTS; ++i)
aszTrigPtBuff[i][0] = '\0';
CMDD("\n");
} //DebugClearTrigPts
/***LP DebugAddTrigPt - Add a trace trigger point
*
* ENTRY
* None
*
* EXIT
* None
*/
VOID CM_INTERNAL DebugAddTrigPt(VOID)
{
char szTrigPt[MAX_TRIGPT_LEN + 1];
BYTE i;
CMDD("\n");
GetString("Trigger Point", szTrigPt, sizeof(szTrigPt), TRUE);
CMDD("\n");
for (i = 0; i < MAX_TRIG_PTS; ++i)
{
if (aszTrigPtBuff[i][0] == '\0')
{
_lstrcpyn(aszTrigPtBuff[i], szTrigPt, MAX_TRIGPT_LEN + 1);
break;
}
}
if (i == MAX_TRIG_PTS)
CMDD("No free trigger point.\n");
CMDD("\n");
} //DebugAddTrigPt
/***LP DebugZapTrigPt - Delete a trace trigger point
*
* ENTRY
* None
*
* EXIT
* None
*/
VOID CM_INTERNAL DebugZapTrigPt(VOID)
{
BYTE i, bcTrigPts;
CMDD("\n");
for (i = 0, bcTrigPts = 0; i < MAX_TRIG_PTS; ++i)
{
if (aszTrigPtBuff[i][0] != '\0')
{
CMDD("%2d: %s\n", i, &aszTrigPtBuff[i][0]);
bcTrigPts++;
}
}
if (bcTrigPts > 0)
{
CMDD("\n");
i = (BYTE)CMDReadNumber("Trigger Point", 1, FALSE);
CMDD("\n");
if ((i < MAX_TRIG_PTS) && (aszTrigPtBuff[i][0] != '\0'))
aszTrigPtBuff[i][0] = '\0';
else
CMDD("Invalid Trace Trigger Point.\n");
}
else
CMDD("No Trace Trigger Point set.\n");
CMDD("\n");
} //DebugZapTrigPt
/***LP GetString - Read a string from the debug terminal
*
* ENTRY
* pszPrompt -> prompt string
* pszBuff -> buffer to hold the string
* bcLen - buffer length
* fUpper - TRUE if convert to upper case
*
* EXIT
* always returns pszBuff
*/
PCHAR CM_LOCAL GetString(PCHAR pszPrompt, PCHAR pszBuff, BYTE bcLen, BOOL fUpper)
{
BYTE i, ch;
CMDD("%s: ", pszPrompt);
for (i = 0; i < bcLen - 1; ++i)
{
ch = CMDInChar();
if ((ch == '\r') || (ch == '\n'))
break;
else if (ch == '\b')
{
if (i > 0)
i -= 2;
}
else if (fUpper && (ch >= 'a') && (ch <= 'z'))
pszBuff[i] = (BYTE)(ch - 'a' + 'A');
else if ((ch < ' ') || (ch > '~'))
{
ch = '\a'; //change it to a BELL character
i--; //don't store it
}
else
pszBuff[i] = ch;
CMDD("%c", ch);
}
pszBuff[i] = '\0';
return pszBuff;
} //GetString
#endif //ifdef TRACING
#endif //ifdef DEBUGGER