Added BreakOnDllLoad internal var, cleaned up register validation on

exception.
This commit is contained in:
Eric Pouech 2000-06-25 12:49:13 +00:00 committed by Alexandre Julliard
parent 4b4e978106
commit 5b471bae6e
4 changed files with 15 additions and 11 deletions

View File

@ -397,12 +397,9 @@ BOOL DEBUG_Parser(void)
do { do {
__TRY { __TRY {
issue_prompt(); issue_prompt();
ret_ok = TRUE;
if ((ret = yyparse())) { if ((ret = yyparse())) {
DEBUG_FlushSymbols(); DEBUG_FlushSymbols();
ret_ok = (DEBUG_CurrThread) ? DEBUG_ValidateRegisters() : TRUE;
} else {
ret_ok = TRUE;
} }
} __EXCEPT(wine_dbg_cmd) { } __EXCEPT(wine_dbg_cmd) {
ret_ok = FALSE; ret_ok = FALSE;

View File

@ -10,6 +10,7 @@ INTERNAL_VAR(BreakAllThreadsStartup, FALSE, NULL, DEBUG_TypeIntConst)
INTERNAL_VAR(BreakOnCritSectTimeOut, FALSE, NULL, DEBUG_TypeIntConst) INTERNAL_VAR(BreakOnCritSectTimeOut, FALSE, NULL, DEBUG_TypeIntConst)
INTERNAL_VAR(BreakOnAttach, FALSE, NULL, DEBUG_TypeIntConst) INTERNAL_VAR(BreakOnAttach, FALSE, NULL, DEBUG_TypeIntConst)
INTERNAL_VAR(BreakOnFirstChance, TRUE, NULL, DEBUG_TypeIntConst) INTERNAL_VAR(BreakOnFirstChance, TRUE, NULL, DEBUG_TypeIntConst)
INTERNAL_VAR(BreakOnDllLoad, FALSE, NULL, DEBUG_TypeIntConst)
/* output handling */ /* output handling */
INTERNAL_VAR(ConChannelMask, DBG_CHN_MESG, NULL, DEBUG_TypeIntConst) INTERNAL_VAR(ConChannelMask, DBG_CHN_MESG, NULL, DEBUG_TypeIntConst)

View File

@ -441,11 +441,12 @@ static BOOL DEBUG_HandleException(EXCEPTION_RECORD *rec, BOOL first_chance, BOOL
DEBUG_CurrThread->dbg_exec_mode, DEBUG_CurrThread->dbg_exec_count); DEBUG_CurrThread->dbg_exec_mode, DEBUG_CurrThread->dbg_exec_count);
if (DEBUG_ExceptionProlog(is_debug, force, rec->ExceptionCode)) { if (DEBUG_ExceptionProlog(is_debug, force, rec->ExceptionCode)) {
for (;;) { while ((ret = DEBUG_Parser())) {
ret = DEBUG_Parser(); if (DEBUG_ValidateRegisters()) {
if (!ret || DEBUG_CurrThread->dbg_exec_mode != EXEC_PASS || first_chance) if (DEBUG_CurrThread->dbg_exec_mode != EXEC_PASS || first_chance)
break; break;
DEBUG_Printf(DBG_CHN_MESG, "Cannot pass on last chance exception. You must use cont\n"); DEBUG_Printf(DBG_CHN_MESG, "Cannot pass on last chance exception. You must use cont\n");
}
} }
} }
*cont = DEBUG_ExceptionEpilog(); *cont = DEBUG_ExceptionEpilog();
@ -667,6 +668,7 @@ static BOOL DEBUG_HandleDebugEvent(DEBUG_EVENT* de, LPDWORD cont)
de->u.LoadDll.nDebugInfoSize); de->u.LoadDll.nDebugInfoSize);
CharUpper(buffer); CharUpper(buffer);
DEBUG_LoadModule32(buffer, de->u.LoadDll.hFile, (DWORD)de->u.LoadDll.lpBaseOfDll); DEBUG_LoadModule32(buffer, de->u.LoadDll.hFile, (DWORD)de->u.LoadDll.lpBaseOfDll);
if (DBG_IVAR(BreakOnDllLoad)) ret = DEBUG_Parser();
break; break;
case UNLOAD_DLL_DEBUG_EVENT: case UNLOAD_DLL_DEBUG_EVENT:

View File

@ -196,6 +196,9 @@ BreakOnAttach, set to TRUE if when WineDbg attaches to an
context of an exception event (the next event context of an exception event (the next event
which is the exception event is of course which is the exception event is of course
relevant), that option is likely to be FALSE. relevant), that option is likely to be FALSE.
BreakOnDllLoad When set to TRUE, allows the debugger to be
entered when a new DLL is loaded into the system.
FALSE by default.
BreakOnFirstChance an exception can generate two debug events. BreakOnFirstChance an exception can generate two debug events.
The first one is passed to the debugger (known The first one is passed to the debugger (known
as a first chance) just after the as a first chance) just after the
@ -466,7 +469,8 @@ V.3 Main differences between winedbg and regular Unix debuggers
VI Limitations VI Limitations
============== ==============
16 bit processes are not supported (but calls to 16 bit code in 32 bit + 16 bit processes are not supported (but calls to 16 bit code in 32
applications is). bit applications is).
+ there are reports of debugger's freeze when loading large PDB files
Last updated: 6/14/2000 by ericP Last updated: 6/14/2000 by ericP