diff options
-rw-r--r-- | sys/arch/mips64/mips64/trap.c | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/sys/arch/mips64/mips64/trap.c b/sys/arch/mips64/mips64/trap.c index 6feb27c7b19..5472f4c4c85 100644 --- a/sys/arch/mips64/mips64/trap.c +++ b/sys/arch/mips64/mips64/trap.c @@ -1,4 +1,4 @@ -/* $OpenBSD: trap.c,v 1.24 2005/09/15 21:14:27 miod Exp $ */ +/* $OpenBSD: trap.c,v 1.25 2005/10/24 20:20:03 kettenis Exp $ */ /* tracked to 1.23 */ /* @@ -148,7 +148,9 @@ extern void MipsSwitchFPState16(struct proc *, struct trap_frame *); extern void MipsFPTrap(u_int, u_int, u_int, union sigval); register_t trap(struct trap_frame *); +#ifdef PTRACE int cpu_singlestep(struct proc *); +#endif u_long MipsEmulateBranch(struct trap_frame *, long, int, u_int); /* @@ -570,10 +572,7 @@ printf("SIG-BUSB @%p pc %p, ra %p\n", trapframe->badvaddr, trapframe->pc, trapfr { caddr_t va; u_int32_t instr; - struct uio uio; - struct iovec iov; struct trap_frame *locr0 = p->p_md.md_regs; - int error; /* compute address of break instruction */ va = (caddr_t)trapframe->pc; @@ -610,8 +609,13 @@ printf("SIG-BUSB @%p pc %p, ra %p\n", trapframe->badvaddr, trapframe->pc, trapfr else locr0->pc += 4; break; +#ifdef PTRACE case BREAK_SSTEP_VAL: if (p->p_md.md_ss_addr == (long)va) { + struct uio uio; + struct iovec iov; + int error; + /* * Restore original instruction and clear BP */ @@ -639,6 +643,7 @@ printf("SIG-BUSB @%p pc %p, ra %p\n", trapframe->badvaddr, trapframe->pc, trapfr } i = SIGTRAP; break; +#endif default: typ = TRAP_TRACE; i = SIGTRAP; @@ -1029,6 +1034,8 @@ MipsEmulateBranch(framePtr, instPC, fpcCSR, curinst) return (retAddr); } +#ifdef PTRACE + /* * This routine is called by procxmt() to single step one instruction. * We do this by storing a break instruction after the current instruction, @@ -1113,6 +1120,8 @@ cpu_singlestep(p) return (0); } +#endif /* PTRACE */ + #if defined(DDB) || defined(DEBUG) #define MIPS_JR_RA 0x03e00008 /* instruction code for jr ra */ |