diff options
Diffstat (limited to 'sys')
-rw-r--r-- | sys/arch/sparc64/include/cpu.h | 11 | ||||
-rw-r--r-- | sys/arch/sparc64/include/db_machdep.h | 9 | ||||
-rw-r--r-- | sys/arch/sparc64/sparc64/autoconf.c | 20 | ||||
-rw-r--r-- | sys/arch/sparc64/sparc64/locore.s | 210 |
4 files changed, 12 insertions, 238 deletions
diff --git a/sys/arch/sparc64/include/cpu.h b/sys/arch/sparc64/include/cpu.h index 424d67ed523..46e45da2b06 100644 --- a/sys/arch/sparc64/include/cpu.h +++ b/sys/arch/sparc64/include/cpu.h @@ -1,4 +1,4 @@ -/* $OpenBSD: cpu.h,v 1.56 2008/03/15 22:05:51 kettenis Exp $ */ +/* $OpenBSD: cpu.h,v 1.57 2008/03/17 23:10:21 kettenis Exp $ */ /* $NetBSD: cpu.h,v 1.28 2001/06/14 22:56:58 thorpej Exp $ */ /* @@ -255,19 +255,10 @@ void fpusave_proc(struct proc *, int); int cnrom(void); /* zs.c */ void zsconsole(struct tty *, int, int, void (**)(struct tty *, int)); -#ifdef KGDB -void zs_kgdb_init(void); -#endif /* fb.c */ void fb_unblank(void); /* tda.c */ void tda_full_blast(void); -/* kgdb_stub.c */ -#ifdef KGDB -void kgdb_attach(int (*)(void *), void (*)(void *, int), void *); -void kgdb_connect(int); -void kgdb_panic(void); -#endif /* emul.c */ int fixalign(struct proc *, struct trapframe64 *); int emulinstr(vaddr_t, struct trapframe64 *); diff --git a/sys/arch/sparc64/include/db_machdep.h b/sys/arch/sparc64/include/db_machdep.h index f0da0f7d7de..9bc6d9c21bf 100644 --- a/sys/arch/sparc64/include/db_machdep.h +++ b/sys/arch/sparc64/include/db_machdep.h @@ -1,4 +1,4 @@ -/* $OpenBSD: db_machdep.h,v 1.9 2005/01/04 21:14:35 espie Exp $ */ +/* $OpenBSD: db_machdep.h,v 1.10 2008/03/17 23:10:21 kettenis Exp $ */ /* $NetBSD: db_machdep.h,v 1.12 2001/07/07 15:16:13 eeh Exp $ */ /* @@ -144,11 +144,4 @@ int kdb_trap(int, struct trapframe64 *); #define DB_ELF_SYMBOLS #define DB_ELFSIZE 64 -/* - * KGDB definitions - */ -typedef u_long kgdb_reg_t; -#define KGDB_NUMREGS 72 -#define KGDB_BUFLEN 1024 - #endif /* _SPARC_DB_MACHDEP_H_ */ diff --git a/sys/arch/sparc64/sparc64/autoconf.c b/sys/arch/sparc64/sparc64/autoconf.c index 06f8542148c..c28e66226a3 100644 --- a/sys/arch/sparc64/sparc64/autoconf.c +++ b/sys/arch/sparc64/sparc64/autoconf.c @@ -1,4 +1,4 @@ -/* $OpenBSD: autoconf.c,v 1.81 2008/03/14 17:04:48 kettenis Exp $ */ +/* $OpenBSD: autoconf.c,v 1.82 2008/03/17 23:10:21 kettenis Exp $ */ /* $NetBSD: autoconf.c,v 1.51 2001/07/24 19:32:11 eeh Exp $ */ /* @@ -97,10 +97,6 @@ int stdinnode; /* node ID of ROM's console input device */ int fbnode; /* node ID of ROM's console output device */ int optionsnode; /* node ID of ROM's options */ -#ifdef KGDB -extern int kgdb_debug_panic; -#endif - static int rootnode; char platform_type[64]; @@ -260,6 +256,9 @@ bootstrap(nctx) extern int end; /* End of kernel */ int ncpus; + /* Initialize the PROM console so printf will not panic. */ + (*cn_tab->cn_init)(cn_tab); + /* * Initialize ddb first and register OBP callbacks. * We can do this because ddb_init() does not allocate anything, @@ -269,12 +268,6 @@ bootstrap(nctx) * By doing this first and installing the OBP callbacks * we get to do symbolic debugging of pmap_bootstrap(). */ -#ifdef KGDB -/* Moved zs_kgdb_init() to dev/zs.c:consinit(). */ - zs_kgdb_init(); /* XXX */ -#endif - /* Initialize the PROM console so printf will not panic */ - (*cn_tab->cn_init)(cn_tab); #ifdef DDB db_machine_init(); ddb_init(); @@ -427,10 +420,7 @@ bootpath_build() /* specialties */ if (*cp == 'd') { -#if defined(KGDB) - kgdb_debug_panic = 1; - kgdb_connect(1); -#elif defined(DDB) +#if defined(DDB) Debugger(); #else printf("kernel has no debugger\n"); diff --git a/sys/arch/sparc64/sparc64/locore.s b/sys/arch/sparc64/sparc64/locore.s index dfc47770ecc..08d4699d950 100644 --- a/sys/arch/sparc64/sparc64/locore.s +++ b/sys/arch/sparc64/sparc64/locore.s @@ -1,4 +1,4 @@ -/* $OpenBSD: locore.s,v 1.113 2008/03/13 20:37:46 kettenis Exp $ */ +/* $OpenBSD: locore.s,v 1.114 2008/03/17 23:10:21 kettenis Exp $ */ /* $NetBSD: locore.s,v 1.137 2001/08/13 06:10:10 jdolecek Exp $ */ /* @@ -283,16 +283,6 @@ _C_LABEL(data_start): ! Start of data segment _C_LABEL(u0): .xword 0 estack0: .xword 0 -#ifdef KGDB -/* - * Another item that must be aligned, easiest to put it here. - */ -KGDB_STACK_SIZE = 2048 - .globl _C_LABEL(kgdb_stack) -_C_LABEL(kgdb_stack): - .space KGDB_STACK_SIZE ! hope this is enough -#endif /* KGDB */ - #ifdef DEBUG /* * This stack is used when we detect kernel stack corruption. @@ -409,15 +399,6 @@ _C_LABEL(cold): VTRAP \type, slowtrap .endm -/* breakpoint acts differently under kgdb */ -#ifdef KGDB -#define BPT VTRAP T_BREAKPOINT, bpt -#define BPT_KGDB_EXEC VTRAP T_KGDB_EXEC, bpt -#else /* KGDB */ -#define BPT TRAP T_BREAKPOINT -#define BPT_KGDB_EXEC TRAP T_KGDB_EXEC -#endif /* KGDB */ - #define SYSCALL VTRAP 0x100, syscall_setup #define ZS_INTERRUPT4U HARDINT4U 12 @@ -778,11 +759,11 @@ TABLE/**/ufillk: UTRAP 0x0fc; TA32 ! 0x0fc fill_7_other TABLE/**/syscall: SYSCALL ! 0x100 = sun syscall - BPT ! 0x101 = pseudo breakpoint instruction + TRAP T_BREAKPOINT ! 0x101 = pseudo breakpoint instruction STRAP 0x102; STRAP 0x103; STRAP 0x104; STRAP 0x105; STRAP 0x106; STRAP 0x107 SYSCALL ! 0x108 = svr4 syscall SYSCALL ! 0x109 = bsd syscall - BPT_KGDB_EXEC ! 0x10a = enter kernel gdb on kernel startup + TRAP T_KGDB_EXEC ! 0x10a = enter kernel gdb on kernel startup STRAP 0x10b; STRAP 0x10c; STRAP 0x10d; STRAP 0x10e; STRAP 0x10f; STRAP 0x110; STRAP 0x111; STRAP 0x112; STRAP 0x113; STRAP 0x114; STRAP 0x115; STRAP 0x116; STRAP 0x117 STRAP 0x118; STRAP 0x119; STRAP 0x11a; STRAP 0x11b; STRAP 0x11c; STRAP 0x11d; STRAP 0x11e; STRAP 0x11f @@ -937,11 +918,11 @@ TABLE/**/kfill: UTRAP 0x0fc; TA32 ! 0x0fc fill_7_other TABLE/**/syscall: SYSCALL ! 0x100 = sun syscall - BPT ! 0x101 = pseudo breakpoint instruction + TRAP T_BREAKPOINT ! 0x101 = pseudo breakpoint instruction STRAP 0x102; STRAP 0x103; STRAP 0x104; STRAP 0x105; STRAP 0x106; STRAP 0x107 SYSCALL ! 0x108 = svr4 syscall SYSCALL ! 0x109 = bsd syscall - BPT_KGDB_EXEC ! 0x10a = enter kernel gdb on kernel startup + TRAP T_KGDB_EXEC ! 0x10a = enter kernel gdb on kernel startup STRAP 0x10b; STRAP 0x10c; STRAP 0x10d; STRAP 0x10e; STRAP 0x10f; STRAP 0x110; STRAP 0x111; STRAP 0x112; STRAP 0x113; STRAP 0x114; STRAP 0x115; STRAP 0x116; STRAP 0x117 STRAP 0x118; STRAP 0x119; STRAP 0x11a; STRAP 0x11b; STRAP 0x11c; STRAP 0x11d; STRAP 0x11e; STRAP 0x11f @@ -2801,187 +2782,6 @@ breakpoint: #endif /* 0 */ /* - * I will not touch any of the DDB or KGDB stuff until I know what's going - * on with the symbol table. This is all still v7/v8 code and needs to be fixed. - */ -#ifdef KGDB -/* - * bpt is entered on all breakpoint traps. - * If this is a kernel breakpoint, we do not want to call trap(). - * Among other reasons, this way we can set breakpoints in trap(). - */ -bpt: - set TSTATE_PRIV, %l4 - andcc %l4, %l0, %g0 ! breakpoint from kernel? - bz slowtrap ! no, go do regular trap - nop - - /* - * Build a trap frame for kgdb_trap_glue to copy. - * Enable traps but set ipl high so that we will not - * see interrupts from within breakpoints. - */ - save %sp, -CCFSZ-TF_SIZE, %sp ! allocate a trap frame - TRAP_SETUP -CCFSZ-TF_SIZE - or %l0, PSR_PIL, %l4 ! splhigh() - wr %l4, 0, %psr ! the manual claims that this - wr %l4, PSR_ET, %psr ! song and dance is necessary - std %l0, [%sp + CCFSZ + 0] ! tf.tf_psr, tf.tf_pc - mov %l3, %o0 ! trap type arg for kgdb_trap_glue - rd %y, %l3 - std %l2, [%sp + CCFSZ + 8] ! tf.tf_npc, tf.tf_y - rd %wim, %l3 - st %l3, [%sp + CCFSZ + 16] ! tf.tf_wim (a kgdb-only r/o field) - st %g1, [%sp + CCFSZ + 20] ! tf.tf_global[1] - std %g2, [%sp + CCFSZ + 24] ! etc - std %g4, [%sp + CCFSZ + 32] - std %g6, [%sp + CCFSZ + 40] - std %i0, [%sp + CCFSZ + 48] ! tf.tf_in[0..1] - std %i2, [%sp + CCFSZ + 56] ! etc - std %i4, [%sp + CCFSZ + 64] - std %i6, [%sp + CCFSZ + 72] - - /* - * Now call kgdb_trap_glue(); if it returns, call trap(). - */ - mov %o0, %l3 ! gotta save trap type - call _C_LABEL(kgdb_trap_glue) ! kgdb_trap_glue(type, &trapframe) - add %sp, CCFSZ, %o1 ! (&trapframe) - - /* - * Use slowtrap to call trap---but first erase our tracks - * (put the registers back the way they were). - */ - mov %l3, %o0 ! slowtrap will need trap type - ld [%sp + CCFSZ + 12], %l3 - wr %l3, 0, %y - ld [%sp + CCFSZ + 20], %g1 - ldd [%sp + CCFSZ + 24], %g2 - ldd [%sp + CCFSZ + 32], %g4 - b Lslowtrap_reenter - ldd [%sp + CCFSZ + 40], %g6 - -/* - * Enter kernel breakpoint. Write all the windows (not including the - * current window) into the stack, so that backtrace works. Copy the - * supplied trap frame to the kgdb stack and switch stacks. - * - * kgdb_trap_glue(type, tf0) - * int type; - * struct trapframe *tf0; - */ - .globl _C_LABEL(kgdb_trap_glue) -_C_LABEL(kgdb_trap_glue): - save %sp, -CCFSZ, %sp - - flushw ! flush all windows - mov %sp, %l4 ! %l4 = current %sp - - /* copy trapframe to top of kgdb stack */ - set _C_LABEL(kgdb_stack) + KGDB_STACK_SIZE - 80, %l0 - ! %l0 = tfcopy -> end_of_kgdb_stack - mov 80, %l1 -1: ldd [%i1], %l2 - inc 8, %i1 - deccc 8, %l1 - std %l2, [%l0] - bg 1b - inc 8, %l0 - -#ifdef DEBUG - /* save old red zone and then turn it off */ - sethi %hi(_C_LABEL(redzone)), %l7 - ld [%l7 + %lo(_C_LABEL(redzone))], %l6 - st %g0, [%l7 + %lo(_C_LABEL(redzone))] -#endif /* DEBUG */ - /* switch to kgdb stack */ - add %l0, -CCFSZ-TF_SIZE, %sp - - /* if (kgdb_trap(type, tfcopy)) kgdb_rett(tfcopy); */ - mov %i0, %o0 - call _C_LABEL(kgdb_trap) - add %l0, -80, %o1 - tst %o0 - bnz,a kgdb_rett - add %l0, -80, %g1 - - /* - * kgdb_trap() did not handle the trap at all so the stack is - * still intact. A simple `restore' will put everything back, - * after we reset the stack pointer. - */ - mov %l4, %sp -#ifdef DEBUG - st %l6, [%l7 + %lo(_C_LABEL(redzone))] ! restore red zone -#endif /* DEBUG */ - ret - restore - -/* - * Return from kgdb trap. This is sort of special. - * - * We know that kgdb_trap_glue wrote the window above it, so that we will - * be able to (and are sure to have to) load it up. We also know that we - * came from kernel land and can assume that the %fp (%i6) we load here - * is proper. We must also be sure not to lower ipl (it is at splhigh()) - * until we have traps disabled, due to the SPARC taking traps at the - * new ipl before noticing that PSR_ET has been turned off. We are on - * the kgdb stack, so this could be disastrous. - * - * Note that the trapframe argument in %g1 points into the current stack - * frame (current window). We abandon this window when we move %g1->tf_psr - * into %psr, but we will not have loaded the new %sp yet, so again traps - * must be disabled. - */ -kgdb_rett: - rd %psr, %g4 ! turn off traps - wr %g4, PSR_ET, %psr - /* use the three-instruction delay to do something useful */ - ld [%g1], %g2 ! pick up new %psr - ld [%g1 + 12], %g3 ! set %y - wr %g3, 0, %y -#ifdef DEBUG - st %l6, [%l7 + %lo(_C_LABEL(redzone))] ! and restore red zone -#endif /* DEBUG */ - wr %g0, 0, %wim ! enable window changes - nop; nop; nop - /* now safe to set the new psr (changes CWP, leaves traps disabled) */ - wr %g2, 0, %psr ! set rett psr (including cond codes) - /* 3 instruction delay before we can use the new window */ -/*1*/ ldd [%g1 + 24], %g2 ! set new %g2, %g3 -/*2*/ ldd [%g1 + 32], %g4 ! set new %g4, %g5 -/*3*/ ldd [%g1 + 40], %g6 ! set new %g6, %g7 - - /* now we can use the new window */ - mov %g1, %l4 - ld [%l4 + 4], %l1 ! get new pc - ld [%l4 + 8], %l2 ! get new npc - ld [%l4 + 20], %g1 ! set new %g1 - - /* set up returnee's out registers, including its %sp */ - ldd [%l4 + 48], %i0 - ldd [%l4 + 56], %i2 - ldd [%l4 + 64], %i4 - ldd [%l4 + 72], %i6 - - /* load returnee's window, making the window above it be invalid */ - restore - restore %g0, 1, %l1 ! move to inval window and set %l1 = 1 - rd %psr, %l0 - srl %l1, %l0, %l1 - wr %l1, 0, %wim ! %wim = 1 << (%psr & 31) - sethi %hi(CPCB), %l1 - ldx [%l1 + %lo(CPCB)], %l1 - and %l0, 31, %l0 ! CWP = %psr & 31; - st %l0, [%l1 + PCB_WIM] ! cpcb->pcb_wim = CWP; - save %g0, %g0, %g0 ! back to window to reload - LOADWIN(%sp) - save %g0, %g0, %g0 ! back to trap window - /* note, we have not altered condition codes; safe to just rett */ - RETT -#endif /* KGDB */ - -/* * syscall_setup() builds a trap frame and calls syscall(). * sun_syscall is same but delivers sun system call number * XXX should not have to save&reload ALL the registers just for |