Added BreakOnDllLoad internal var, cleaned up register validation on
exception.
This commit is contained in:
parent
4b4e978106
commit
5b471bae6e
|
@ -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;
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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:
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue