Use db_recover. Print trap name when entering DDB. Use trap_type and
trap_types like m68k.
This commit is contained in:
parent
ebc818a088
commit
8d49c8420a
@ -24,25 +24,26 @@
|
|||||||
* rights to redistribute these changes.
|
* rights to redistribute these changes.
|
||||||
*
|
*
|
||||||
* From: db_interface.c,v 2.4 1991/02/05 17:11:13 mrt (CMU)
|
* From: db_interface.c,v 2.4 1991/02/05 17:11:13 mrt (CMU)
|
||||||
* $Id: db_interface.c,v 1.6 1994/01/04 00:24:02 mycroft Exp $
|
* $Id: db_interface.c,v 1.7 1994/01/09 22:53:31 mycroft Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Interface to new debugger.
|
* Interface to new debugger.
|
||||||
*/
|
*/
|
||||||
#include "param.h"
|
#include <sys/param.h>
|
||||||
#include "proc.h"
|
#include <sys/proc.h>
|
||||||
|
#include <sys/reboot.h>
|
||||||
|
#include <sys/systm.h> /* just for boothowto --eichin */
|
||||||
|
#include <setjmp.h>
|
||||||
|
|
||||||
|
#include <vm/vm.h>
|
||||||
|
|
||||||
#include <machine/cpufunc.h>
|
#include <machine/cpufunc.h>
|
||||||
#include <machine/db_machdep.h>
|
#include <machine/db_machdep.h>
|
||||||
|
|
||||||
#include <sys/reboot.h>
|
extern jmp_buf *db_recover;
|
||||||
#include <vm/vm_statistics.h>
|
|
||||||
#include <vm/pmap.h>
|
|
||||||
|
|
||||||
#include <setjmp.h>
|
|
||||||
#include <sys/systm.h> /* just for boothowto --eichin */
|
|
||||||
int db_active = 0;
|
int db_active = 0;
|
||||||
extern jmp_buf db_jmpbuf;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Received keyboard interrupt sequence.
|
* Received keyboard interrupt sequence.
|
||||||
@ -59,9 +60,6 @@ kdb_kbd_trap(regs)
|
|||||||
/*
|
/*
|
||||||
* kdb_trap - field a TRACE or BPT trap
|
* kdb_trap - field a TRACE or BPT trap
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static jmp_buf *db_nofault = 0;
|
|
||||||
|
|
||||||
kdb_trap(type, code, regs)
|
kdb_trap(type, code, regs)
|
||||||
int type, code;
|
int type, code;
|
||||||
register struct i386_saved_state *regs;
|
register struct i386_saved_state *regs;
|
||||||
@ -72,27 +70,19 @@ kdb_trap(type, code, regs)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case T_BPTFLT: /* breakpoint */
|
case T_BPTFLT: /* breakpoint */
|
||||||
case T_TRCTRAP: /* single_step */
|
case T_TRCTRAP: /* single_step */
|
||||||
|
case -1: /* keyboard interrupt */
|
||||||
case -1: /* keyboard interrupt */
|
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
default:
|
|
||||||
kdbprinttrap(type, code);
|
kdbprinttrap(type, code);
|
||||||
|
if (db_recover != 0) {
|
||||||
if (db_nofault) {
|
db_error("Faulted in DDB; continuing...\n");
|
||||||
jmp_buf *no_fault = db_nofault;
|
/*NOTREACHED*/
|
||||||
db_nofault = 0;
|
|
||||||
longjmp(*no_fault, 1);
|
|
||||||
} else if (db_active) {
|
|
||||||
db_printf("Faulted in DDB; continuing...\n");
|
|
||||||
db_flush_lex();
|
|
||||||
longjmp(db_jmpbuf, 1);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Should switch to kdb`s own stack here. */
|
/* Should switch to kdb`s own stack here. */
|
||||||
|
|
||||||
ddb_regs = *regs;
|
ddb_regs = *regs;
|
||||||
|
|
||||||
@ -143,6 +133,9 @@ kdb_trap(type, code, regs)
|
|||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern char *trap_type[];
|
||||||
|
extern int trap_types;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Print trap reason.
|
* Print trap reason.
|
||||||
*/
|
*/
|
||||||
@ -150,7 +143,10 @@ kdbprinttrap(type, code)
|
|||||||
int type, code;
|
int type, code;
|
||||||
{
|
{
|
||||||
printf("kernel: ");
|
printf("kernel: ");
|
||||||
printf("type %d", type);
|
if (type >= trap_types || type < 0)
|
||||||
|
printf("type %d", type);
|
||||||
|
else
|
||||||
|
printf("%s", trap_type[type]);
|
||||||
printf(" trap, code=%x\n", code);
|
printf(" trap, code=%x\n", code);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -165,13 +161,9 @@ db_read_bytes(addr, size, data)
|
|||||||
{
|
{
|
||||||
register char *src;
|
register char *src;
|
||||||
|
|
||||||
db_nofault = &db_jmpbuf;
|
|
||||||
|
|
||||||
src = (char *)addr;
|
src = (char *)addr;
|
||||||
while (--size >= 0)
|
while (--size >= 0)
|
||||||
*data++ = *src++;
|
*data++ = *src++;
|
||||||
|
|
||||||
db_nofault = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
struct pte *pmap_pte(pmap_t, vm_offset_t);
|
struct pte *pmap_pte(pmap_t, vm_offset_t);
|
||||||
@ -194,8 +186,6 @@ db_write_bytes(addr, size, data)
|
|||||||
pt_entry_t oldmap1 = { 0 };
|
pt_entry_t oldmap1 = { 0 };
|
||||||
extern char etext;
|
extern char etext;
|
||||||
|
|
||||||
db_nofault = &db_jmpbuf;
|
|
||||||
|
|
||||||
if (addr >= VM_MIN_KERNEL_ADDRESS &&
|
if (addr >= VM_MIN_KERNEL_ADDRESS &&
|
||||||
addr < (vm_offset_t)&etext) {
|
addr < (vm_offset_t)&etext) {
|
||||||
ptep0 = pmap_pte(kernel_pmap, addr);
|
ptep0 = pmap_pte(kernel_pmap, addr);
|
||||||
@ -217,8 +207,6 @@ db_write_bytes(addr, size, data)
|
|||||||
while (--size >= 0)
|
while (--size >= 0)
|
||||||
*dst++ = *data++;
|
*dst++ = *data++;
|
||||||
|
|
||||||
db_nofault = 0;
|
|
||||||
|
|
||||||
if (ptep0) {
|
if (ptep0) {
|
||||||
*ptep0 = oldmap0;
|
*ptep0 = oldmap0;
|
||||||
if (ptep1)
|
if (ptep1)
|
||||||
|
@ -34,7 +34,7 @@
|
|||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* from: @(#)trap.c 7.4 (Berkeley) 5/13/91
|
* from: @(#)trap.c 7.4 (Berkeley) 5/13/91
|
||||||
* $Id: trap.c,v 1.23 1994/01/04 00:15:28 mycroft Exp $
|
* $Id: trap.c,v 1.24 1994/01/09 22:53:16 mycroft Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -67,7 +67,6 @@
|
|||||||
|
|
||||||
struct sysent sysent[];
|
struct sysent sysent[];
|
||||||
int nsysent;
|
int nsysent;
|
||||||
unsigned rcr2();
|
|
||||||
extern int cpl;
|
extern int cpl;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -126,7 +125,7 @@ userret(p, pc, syst)
|
|||||||
curpri = p->p_pri;
|
curpri = p->p_pri;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *trapstr[] = {
|
char *trap_type[] = {
|
||||||
"privileged instruction fault", /* 0 T_PRIVINFLT */
|
"privileged instruction fault", /* 0 T_PRIVINFLT */
|
||||||
"breakpoint trap", /* 1 T_BPTFLT */
|
"breakpoint trap", /* 1 T_BPTFLT */
|
||||||
"arithmetic trap", /* 2 T_ARITHTRAP */
|
"arithmetic trap", /* 2 T_ARITHTRAP */
|
||||||
@ -146,6 +145,7 @@ char *trapstr[] = {
|
|||||||
"segment not present fault", /* 16 T_SEGNPFLT */
|
"segment not present fault", /* 16 T_SEGNPFLT */
|
||||||
"stack fault", /* 17 T_STKFLT */
|
"stack fault", /* 17 T_STKFLT */
|
||||||
};
|
};
|
||||||
|
int trap_types = sizeof trap_type / sizeof trap_type[0];
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* trap(frame):
|
* trap(frame):
|
||||||
@ -219,9 +219,8 @@ trap(frame)
|
|||||||
return;
|
return;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (frame.tf_trapno < (sizeof(trapstr) / sizeof(trapstr[0])) &&
|
if (frame.tf_trapno < trap_types)
|
||||||
trapstr[frame.tf_trapno])
|
printf("fatal %s", trap_type[frame.tf_trapno]);
|
||||||
printf("fatal %s", trapstr[frame.tf_trapno]);
|
|
||||||
else
|
else
|
||||||
printf("unknown trap %d", frame.tf_trapno);
|
printf("unknown trap %d", frame.tf_trapno);
|
||||||
printf(" in %s mode\n", (type & T_USER) ? "user" : "supervisor");
|
printf(" in %s mode\n", (type & T_USER) ? "user" : "supervisor");
|
||||||
|
Loading…
Reference in New Issue
Block a user