diff options
Diffstat (limited to 'sys/arch/mvme88k')
-rw-r--r-- | sys/arch/mvme88k/ddb/db_disasm.c | 124 | ||||
-rw-r--r-- | sys/arch/mvme88k/ddb/db_interface.c | 117 | ||||
-rw-r--r-- | sys/arch/mvme88k/ddb/db_sstep.c | 4 | ||||
-rw-r--r-- | sys/arch/mvme88k/ddb/db_trace.c | 7 |
4 files changed, 99 insertions, 153 deletions
diff --git a/sys/arch/mvme88k/ddb/db_disasm.c b/sys/arch/mvme88k/ddb/db_disasm.c index c5bbf03118c..e97647618cb 100644 --- a/sys/arch/mvme88k/ddb/db_disasm.c +++ b/sys/arch/mvme88k/ddb/db_disasm.c @@ -1,4 +1,4 @@ -/* $OpenBSD: db_disasm.c,v 1.12 2003/10/05 20:25:06 miod Exp $ */ +/* $OpenBSD: db_disasm.c,v 1.13 2004/01/07 17:52:30 miod Exp $ */ /* * Mach Operating System * Copyright (c) 1993-1991 Carnegie Mellon University @@ -40,15 +40,15 @@ #include <ddb/db_output.h> /* db_printf() */ #include <ddb/db_interface.h> -static char *instwidth[4] = { +static const char *instwidth[4] = { ".d", " ", ".h", ".b" }; -static char *condname[6] = { +static const char *condname[6] = { "gt0 ", "eq0 ", "ge0 ", "lt0 ", "ne0 ", "le0 " }; -static char *m88100_ctrlreg[64] = { +static const char *m88100_ctrlreg[64] = { "cr0(PID) ", "cr1(PSR) ", "cr2(EPSR) ", @@ -79,26 +79,29 @@ static char *m88100_ctrlreg[64] = { "fcr6(FPRH) ", "fcr7(FPRL) ", "fcr8(FPIT) ", - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, + NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, + NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, + NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, + NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "fcr62(FPSR)", "fcr63(FPCR)" }; -static char *m88110_ctrlreg[64] = { +static const char *m88110_ctrlreg[64] = { "cr0(PID) ", "cr1(PSR) ", "cr2(EPSR) ", - 0, + NULL, "cr4(EXIP) ", "cr5(ENIP) ", - 0, + NULL, "cr7(VBR) ", - 0, - 0, - 0, - 0, - 0, - 0, + NULL, + NULL, + NULL, + NULL, + NULL, + NULL, "cr14(RES1) ", "cr15(RES2) ", "cr16(SR0) ", @@ -107,9 +110,9 @@ static char *m88110_ctrlreg[64] = { "cr19(SR3) ", "cr20(SR4) ", "fcr0(FPECR)", - 0, - 0, - 0, + NULL, + NULL, + NULL, "cr25(ICMD) ", "cr26(ICTL) ", "cr27(ISAR) ", @@ -122,7 +125,9 @@ static char *m88110_ctrlreg[64] = { "cr34(ISR) ", "cr35(ILAR) ", "cr36(IPAR) ", - 0,0,0, + NULL, + NULL, + NULL, "cr40(DCMD) ", "cr41(DCTL) ", "cr42(DSAR) ", @@ -135,7 +140,8 @@ static char *m88110_ctrlreg[64] = { "cr49(DSR) ", "cr50(DLAR) ", "cr51(DPAR) ", - 0,0,0,0,0,0,0,0,0,0, + NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, + NULL, NULL, "fcr62(FPSR)", "fcr63(FPCR)" }; @@ -149,26 +155,26 @@ static char *m88110_ctrlreg[64] = { } while (0) /* prototypes */ -void oimmed(int, char *, long); -void ctrlregs(int, char *, long); +void oimmed(int, const char *, long); +void ctrlregs(int, const char *, long); void printsod(int); -void sindou(int, char *, long); -void jump(int, char *, long); -void instset(int, char *, long); +void sindou(int, const char *, long); +void jump(int, const char *, long); +void instset(int, const char *, long); void symofset(int, int, int); -void obranch(int, char *, long); -void brcond(int, char *, long); -void otrap(int, char *, long); -void obit(int, char *, long); -void bitman(int, char *, long); -void immem(int, char *, long); -void nimmem(int, char *, long); -void lognim(int, char *, long); -void onimmed(int, char *, long); +void obranch(int, const char *, long); +void brcond(int, const char *, long); +void otrap(int, const char *, long); +void obit(int, const char *, long); +void bitman(int, const char *, long); +void immem(int, const char *, long); +void nimmem(int, const char *, long); +void lognim(int, const char *, long); +void onimmed(int, const char *, long); /* Handlers immediate integer arithmetic instructions */ void -oimmed(int inst, char *opcode, long iadr) +oimmed(int inst, const char *opcode, long iadr) { int Linst = inst & 0177777; int Hinst = inst >> 16; @@ -189,7 +195,7 @@ oimmed(int inst, char *opcode, long iadr) /* Handles instructions dealing with control registers */ void -ctrlregs(int inst, char *opcode, long iadr) +ctrlregs(int inst, const char *opcode, long iadr) { int L6inst = (inst >> 11) & 037; int creg = (inst >> 5) & 077; @@ -221,7 +227,7 @@ printsod(int t) /* Handles floating point instructions */ void -sindou(int inst, char *opcode, long iadr) +sindou(int inst, const char *opcode, long iadr) { int rs2 = inst & 037; int td = ( inst >> 5 ) & 03; @@ -248,7 +254,7 @@ sindou(int inst, char *opcode, long iadr) void -jump(int inst, char *opcode, long iadr) +jump(int inst, const char *opcode, long iadr) { int rs2 = inst & 037; int Nbit = ( inst >> 10 ) & 01; @@ -264,7 +270,7 @@ jump(int inst, char *opcode, long iadr) /* Handles ff1, ff0, tbnd and rte instructions */ void -instset(int inst, char *opcode, long iadr) +instset(int inst, const char *opcode, long iadr) { int rs2 = inst & 037; int rs1 = ( inst >> 16 ) & 037; @@ -298,7 +304,7 @@ symofset(int disp, int bit, int iadr) } void -obranch(int inst, char *opcode, long iadr) +obranch(int inst, const char *opcode, long iadr) { int cond = ( inst >> 26 ) & 01; int disp = inst &0377777777; @@ -315,7 +321,7 @@ obranch(int inst, char *opcode, long iadr) /* Handles branch on conditions instructions */ void -brcond(int inst, char *opcode, long iadr) +brcond(int inst, const char *opcode, long iadr) { int cond = ( inst >> 26 ) & 1; int match = ( inst >> 21 ) & 037; @@ -347,7 +353,7 @@ brcond(int inst, char *opcode, long iadr) void -otrap(int inst, char *opcode, long iadr) +otrap(int inst, const char *opcode, long iadr) { int vecno = inst & 0777; int match = ( inst >> 21 ) & 037; @@ -375,7 +381,7 @@ otrap(int inst, char *opcode, long iadr) /* Handles 10 bit immediate bit field operations */ void -obit(int inst, char *opcode, long iadr) +obit(int inst, const char *opcode, long iadr) { int rs = ( inst >> 16 ) & 037; int rd = ( inst >> 21 ) & 037; @@ -398,7 +404,7 @@ obit(int inst, char *opcode, long iadr) /* Handles triadic mode bit field instructions */ void -bitman(int inst, char *opcode, long iadr) +bitman(int inst, const char *opcode, long iadr) { int rs1 = ( inst >> 16 ) & 037; @@ -411,7 +417,7 @@ bitman(int inst, char *opcode, long iadr) /* Handles immediate load/store/exchange instructions */ void -immem(int inst, char *opcode, long iadr) +immem(int inst, const char *opcode, long iadr) { int immed = inst & 0xFFFF; int rd = (inst >> 21) & 037; @@ -441,7 +447,7 @@ immem(int inst, char *opcode, long iadr) /* Handles triadic mode load/store/exchange instructions */ void -nimmem(int inst, char *opcode, long iadr) +nimmem(int inst, const char *opcode, long iadr) { int scaled = (inst >> 9) & 01; int rd = (inst >> 21) & 037; @@ -499,7 +505,7 @@ nimmem(int inst, char *opcode, long iadr) /* Handles triadic mode logical instructions */ void -lognim(int inst, char *opcode, long iadr) +lognim(int inst, const char *opcode, long iadr) { int rd = (inst >> 21) & 037; int rs1 = (inst >> 16) & 037; @@ -516,7 +522,7 @@ lognim(int inst, char *opcode, long iadr) /* Handles triadic mode arithmetic instructions */ void -onimmed(int inst, char *opcode, long iadr) +onimmed(int inst, const char *opcode, long iadr) { int rd = (inst >> 21) & 037; int rs1 = (inst >> 16) & 037; @@ -549,16 +555,16 @@ onimmed(int inst, char *opcode, long iadr) tab, rd, rs1, rs2); } -static struct opdesc { +static const struct opdesc { unsigned mask, match; - void (*opfun)(int, char *, long); - char *farg; + void (*opfun)(int, const char *, long); + const char *farg; } opdecode[] = { /* ORDER IS IMPORTANT BELOW */ - { 0xF0000000U, 0x00000000U, immem, 0,}, - { 0xF0000000U, 0x10000000U, immem, 0,}, + { 0xF0000000U, 0x00000000U, immem, NULL}, + { 0xF0000000U, 0x10000000U, immem, NULL}, { 0xF0000000U, 0x20000000U, immem, "st"}, { 0xF0000000U, 0x30000000U, immem, "lda"}, @@ -610,10 +616,10 @@ static struct opdesc { { 0xFC00FE00U, 0xF000D800U, otrap, "tb1"}, { 0xFC00FE00U, 0xF000E800U, otrap, "tcnd"}, - { 0xFC00F2E0U, 0xF4000000U, nimmem, 0,}, - { 0xFC00F2E0U, 0xF4000200U, nimmem, 0,}, - { 0xFC00F2E0U, 0xF4001000U, nimmem, 0,}, - { 0xFC00F2E0U, 0xF4001200U, nimmem, 0,}, + { 0xFC00F2E0U, 0xF4000000U, nimmem, NULL}, + { 0xFC00F2E0U, 0xF4000200U, nimmem, NULL}, + { 0xFC00F2E0U, 0xF4001000U, nimmem, NULL}, + { 0xFC00F2E0U, 0xF4001200U, nimmem, NULL}, { 0xFC00F2E0U, 0xF4002000U, nimmem, "st"}, { 0xFC00F2E0U, 0xF4002200U, nimmem, "st"}, { 0xFC00F2E0U, 0xF4003000U, nimmem, "lda"}, @@ -647,15 +653,15 @@ static struct opdesc { { 0xFC00FFE0U, 0xF400F800U, instset, "tbnd"}, { 0xFC00FFE0U, 0xF400FC00U, instset, "rte"}, { 0xFC000000U, 0xF8000000U, instset, "tbnd"}, - { 0,0,0,0} + { 0, 0, NULL, NULL} }; -static char *badop = "\t???"; +static const char *badop = "\t???"; int m88k_print_instruction(unsigned iadr, long inst) { - struct opdesc *p; + const struct opdesc *p; /* this messes up "orb" instructions ever so slightly, */ /* but keeps us in sync between routines... */ diff --git a/sys/arch/mvme88k/ddb/db_interface.c b/sys/arch/mvme88k/ddb/db_interface.c index 64e20996811..29e17e31e45 100644 --- a/sys/arch/mvme88k/ddb/db_interface.c +++ b/sys/arch/mvme88k/ddb/db_interface.c @@ -1,4 +1,4 @@ -/* $OpenBSD: db_interface.c,v 1.35 2004/01/07 16:22:17 miod Exp $ */ +/* $OpenBSD: db_interface.c,v 1.36 2004/01/07 17:52:30 miod Exp $ */ /* * Mach Operating System * Copyright (c) 1993-1991 Carnegie Mellon University @@ -64,8 +64,6 @@ int ddb_nmi_trap(int, db_regs_t *); void ddb_error_trap(char *, db_regs_t *); void db_putc(int); int db_getc(void); -void cpu_interrupt_to_db(int); -char *db_task_name(void); int m88k_dmx_print(unsigned, unsigned, unsigned, unsigned); void m88k_db_pause(unsigned); void m88k_db_print_frame(db_expr_t, int, db_expr_t, char *); @@ -90,7 +88,7 @@ db_regs_t ddb_regs; * If you really feel like understanding the following procedure and * macros, see pages 6-22 to 6-30 (Section 6.7.3) of * - * MC881000 RISC Microprocessor User's Manual Second Edition + * MC88100 RISC Microprocessor User's Manual Second Edition * (Motorola Order: MC88100UM/AD REV 1) * * and ERRATA-5 (6-23, 6-24, 6-24) of @@ -101,6 +99,7 @@ db_regs_t ddb_regs; * */ +#ifdef M88100 /* macros for decoding dmt registers */ /* @@ -110,21 +109,21 @@ int m88k_dmx_print(t, d, a, no) unsigned t, d, a, no; { - static unsigned addr_mod[16] = { + static const unsigned addr_mod[16] = { 0, 3, 2, 2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; - static char *mode[16] = { + static const char *mode[16] = { "?", ".b", ".b", ".h", ".b", "?", "?", "?", ".b", "?", "?" , "?" , ".h" , "?", "?", "" }; - static unsigned mask[16] = { + static const unsigned mask[16] = { 0, 0xff, 0xff00, 0xffff, 0xff0000, 0, 0, 0, 0xff000000, 0, 0, 0, 0xffff0000, 0, 0, 0xffffffff }; - static unsigned shift[16] = { + static const unsigned shift[16] = { 0, 0, 8, 0, 16, 0, 0, 0, 24, 0, 0, 0, 16, 0, 0, 0 }; @@ -170,6 +169,7 @@ m88k_dmx_print(t, d, a, no) } return 0; } +#endif /* M88100 */ void m88k_db_print_frame(addr, have_addr, count, modif) @@ -294,6 +294,7 @@ m88k_db_print_frame(addr, have_addr, count, modif) return; } +#ifdef M88100 if (cputyp != CPU_88110) { if (s->vector == /*data*/3 || s->dmt0 & DMT_VALID) { db_printf("dmt,d,a0: 0x%08x 0x%08x 0x%08x ", @@ -335,16 +336,19 @@ m88k_db_print_frame(addr, have_addr, count, modif) (s->dpfsr >> 16) & 0x07, s->dpfsr); } } +#endif /* M88100 */ if (s->fpecr & 255) { /* floating point error occurred */ db_printf("fpecr: 0x%08x fpsr: 0x%08x fpcr: 0x%08x\n", s->fpecr, s->fpsr, s->fpcr); +#ifdef M88100 if (cputyp != CPU_88110) { db_printf("fcr1-4: 0x%08x 0x%08x 0x%08x 0x%08x\n", s->fphs1, s->fpls1, s->fphs2, s->fpls2); db_printf("fcr5-8: 0x%08x 0x%08x 0x%08x 0x%08x\n", s->fppt, s->fprh, s->fprl, s->fpit); } +#endif } db_printf("\n"); } @@ -799,11 +803,6 @@ m88k_db_cmmucfg(addr, have_addr, count, modif) cmmu_dump_config(); } -void cpu_interrupt_to_db(cpu_no) - int cpu_no; -{ -} - void m88k_db_prom_cmd(addr, have_addr, count, modif) db_expr_t addr; @@ -818,88 +817,28 @@ m88k_db_prom_cmd(addr, have_addr, count, modif) /* COMMAND TABLE / INIT */ /************************/ -struct db_command m88k_cache_cmds[] = -{ - { "iflush", m88k_db_iflush, 0, 0}, - { "dflush", m88k_db_dflush, 0, 0}, - { "peek", m88k_db_peek, 0, 0}, - { (char *) 0,} +struct db_command m88k_cache_cmds[] = { + { "iflush", m88k_db_iflush, 0, NULL }, + { "dflush", m88k_db_dflush, 0, NULL }, + { "peek", m88k_db_peek, 0, NULL }, + { NULL, NULL, 0, NULL } }; -struct db_command db_machine_cmds[] = -{ - {"cache", 0, 0, m88k_cache_cmds}, - {"frame", m88k_db_print_frame, 0, 0}, - {"regs", m88k_db_registers, 0, 0}, - {"noise", m88k_db_noise, 0, 0}, - {"searchframe", m88k_db_frame_search, 0, 0}, - {"translate", m88k_db_translate, 0, 0}, - {"cmmucfg", m88k_db_cmmucfg, 0, 0}, - {"where", m88k_db_where, 0, 0}, - {"prom", m88k_db_prom_cmd, 0, 0}, - {(char *) 0,} +struct db_command db_machine_cmds[] = { + { "cache", NULL, 0, m88k_cache_cmds }, + { "frame", m88k_db_print_frame, 0, NULL }, + { "regs", m88k_db_registers, 0, NULL }, + { "noise", m88k_db_noise, 0, NULL }, + { "searchframe",m88k_db_frame_search, 0, NULL }, + { "translate", m88k_db_translate, 0, NULL }, + { "cmmucfg", m88k_db_cmmucfg, 0, NULL }, + { "where", m88k_db_where, 0, NULL }, + { "prom", m88k_db_prom_cmd, 0, NULL }, + { NULL, NULL, 0, NULL } }; -/* - * Called from "m88k/m1x7_init.c" - */ void db_machine_init() { db_machine_commands_install(db_machine_cmds); } - -/* - * Attempt to figure out the UX name of the task. - * This is kludgy at best... we can't even be sure the task is a UX task... - */ -#define TOP_OF_USER_STACK USRSTACK -#define MAX_DISTANCE_TO_LOOK (1024 * 10) - -#define DB_TASK_NAME_LEN 50 - -char * -db_task_name() -{ - static unsigned buffer[(DB_TASK_NAME_LEN + 5) / sizeof(unsigned)]; - vaddr_t ptr = (vaddr_t)(TOP_OF_USER_STACK - 4); - vaddr_t limit = ptr - MAX_DISTANCE_TO_LOOK; - unsigned word; - int i; - - /* skip zeros at the end */ - while (ptr > limit && - (i = db_trace_get_val(ptr, &word)) && (word == 0)) { - ptr -= 4; /* continue looking for a non-null word */ - } - - if (ptr <= limit) { - db_printf("bad name at line %d\n", __LINE__); - return "<couldn't find 1>"; - } else if (i != 1) { - return "<nostack>"; - } - - /* skip looking for null before all the text */ - while (ptr > limit && - (i = db_trace_get_val(ptr, &word)) && (word != 0)) { - ptr -= 4; /* continue looking for a null word */ - } - - if (ptr <= limit) { - db_printf("bad name at line %d\n", __LINE__); - return "<couldn't find 2>"; - } else if (i != 1) { - db_printf("bad name read of %lx at line %d\n", ptr, __LINE__); - return "<bad read 2>"; - } - - ptr += 4; /* go back to the non-null word after this one */ - - for (i = 0; i < sizeof(buffer); i++, ptr += 4) { - buffer[i] = 0; /* just in case it's not read */ - db_trace_get_val(ptr, &buffer[i]); - } - return (char *)buffer; -} - diff --git a/sys/arch/mvme88k/ddb/db_sstep.c b/sys/arch/mvme88k/ddb/db_sstep.c index 5b1563ffb3d..e281eebe6b5 100644 --- a/sys/arch/mvme88k/ddb/db_sstep.c +++ b/sys/arch/mvme88k/ddb/db_sstep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: db_sstep.c,v 1.13 2003/12/21 13:23:32 miod Exp $ */ +/* $OpenBSD: db_sstep.c,v 1.14 2004/01/07 17:52:30 miod Exp $ */ /* * Mach Operating System * Copyright (c) 1993-1991 Carnegie Mellon University @@ -28,7 +28,9 @@ #include <sys/param.h> #include <sys/systm.h> + #include <machine/db_machdep.h> + #include <ddb/db_access.h> /* db_get_value() */ #include <ddb/db_break.h> /* db_breakpoint_t */ diff --git a/sys/arch/mvme88k/ddb/db_trace.c b/sys/arch/mvme88k/ddb/db_trace.c index d70d5c31cb1..e62dbc6172b 100644 --- a/sys/arch/mvme88k/ddb/db_trace.c +++ b/sys/arch/mvme88k/ddb/db_trace.c @@ -1,4 +1,4 @@ -/* $OpenBSD: db_trace.c,v 1.22 2004/01/07 16:22:17 miod Exp $ */ +/* $OpenBSD: db_trace.c,v 1.23 2004/01/07 17:52:30 miod Exp $ */ /* * Mach Operating System * Copyright (c) 1993-1991 Carnegie Mellon University @@ -116,7 +116,7 @@ unsigned db_trace_get_val(vaddr_t addr, unsigned *ptr); /* st r1, r31, IMM */ #define ST_R1_R31_IMM(I) (((I) & 0xffff0000U) == 0x243f0000U) -static int trace_flags = 0; +static int trace_flags; #define TRACE_DEBUG_FLAG 0x01 #define TRACE_SHOWCALLPRESERVED_FLAG 0x02 #define TRACE_SHOWADDRESS_FLAG 0x04 @@ -201,7 +201,7 @@ struct db_variable *db_eregs = db_regs + sizeof(db_regs)/sizeof(db_regs[0]); static unsigned m88k_instruction_info(unsigned instruction) { - static struct { + static const struct { unsigned mask, value, flags; } *ptr, control[] = { /* runs in the same order as 2nd Ed 88100 manual Table 3-14 */ @@ -1144,4 +1144,3 @@ db_stack_trace_print(db_expr_t addr, } db_stack_trace_cmd2(regs, pr); } - |