X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=gdb%2Fdink32-rom.c;h=4a6814093a050533ef6fe1c6619c02c909186482;hb=ba3e8e46435a896352acc4be831145dfec819f5f;hp=2d60d67209fe9c9e246da21732e556840b921563;hpb=c5aa993b1f4add48fbdc6cc3117059f616e49875;p=deliverable%2Fbinutils-gdb.git diff --git a/gdb/dink32-rom.c b/gdb/dink32-rom.c index 2d60d67209..4a6814093a 100644 --- a/gdb/dink32-rom.c +++ b/gdb/dink32-rom.c @@ -1,6 +1,6 @@ /* Remote debugging interface for DINK32 (PowerPC) ROM monitor for GDB, the GNU debugger. - Copyright 1997 Free Software Foundation, Inc. + Copyright 1997, 1999, 2000, 2001 Free Software Foundation, Inc. This file is part of GDB. @@ -24,17 +24,16 @@ #include "target.h" #include "monitor.h" #include "serial.h" +#include "symfile.h" /* For generic_load() */ +#include "inferior.h" /* For write_pc() */ +#include "regcache.h" -static void dink32_open PARAMS ((char *args, int from_tty)); +static void dink32_open (char *args, int from_tty); static void -dink32_supply_register (regname, regnamelen, val, vallen) - char *regname; - int regnamelen; - char *val; - int vallen; +dink32_supply_register (char *regname, int regnamelen, char *val, int vallen) { - int regno = 0, base = 0; + int regno = 0; if (regnamelen < 2 || regnamelen > 4) return; @@ -97,30 +96,12 @@ dink32_supply_register (regname, regnamelen, val, vallen) monitor_supply_register (regno, val); } -static void -dink32_load (monops, filename, from_tty) - struct monitor_ops *monops; - char *filename; - int from_tty; -{ - extern int inferior_pid; - - generic_load (filename, from_tty); - - /* Finally, make the PC point at the start address */ - if (exec_bfd) - write_pc (bfd_get_start_address (exec_bfd)); - - inferior_pid = 0; /* No process now */ -} - - /* This array of registers needs to match the indexes used by GDB. The whole reason this exists is because the various ROM monitors use different names than GDB does, and don't support all the registers either. */ -static char *dink32_regnames[NUM_REGS] = +static char *dink32_regnames[] = { "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15", @@ -143,15 +124,15 @@ static char *dink32_inits[] = static struct monitor_ops dink32_cmds; static void -dink32_open (args, from_tty) - char *args; - int from_tty; +dink32_open (char *args, int from_tty) { monitor_open (args, &dink32_cmds, from_tty); } +extern initialize_file_ftype _initialize_dink32_rom; /* -Wmissing-prototypes */ + void -_initialize_dink32_rom () +_initialize_dink32_rom (void) { dink32_cmds.flags = MO_HEX_PREFIX | MO_GETMEM_NEEDS_RANGE | MO_FILL_USES_ADDR | MO_HANDLE_NL | MO_32_REGS_PAIRED | MO_SETREG_INTERACTIVE | MO_SETMEM_INTERACTIVE | MO_GETMEM_16_BOUNDARY | MO_CLR_BREAK_1_BASED | MO_SREC_ACK | MO_SREC_ACK_ROTATE; dink32_cmds.init = dink32_inits; @@ -178,9 +159,6 @@ _initialize_dink32_rom () /* S-record download, via "keyboard port". */ dink32_cmds.load = "dl -k\r"; dink32_cmds.loadresp = "Set Input Port : set to Keyboard Port\r"; -#if 0 /* slow load routine not needed if S-records work... */ - dink32_cmds.load_routine = dink32_load; -#endif dink32_cmds.prompt = "DINK32_603 >>"; dink32_cmds.line_term = "\r"; dink32_cmds.target = &dink32_ops;