diff options
author | Grace Sainsbury <graces@redhat.com> | 2002-06-26 15:14:32 +0000 |
---|---|---|
committer | Grace Sainsbury <graces@redhat.com> | 2002-06-26 15:14:32 +0000 |
commit | 1c617db829e6a6fbcfebd3ad86fa93c88ee3c222 (patch) | |
tree | ca1541e0a36b17e80f8460518c9bace2fd2005f9 /gdb/dbug-rom.c | |
parent | eb3f2f5cfd7ff8acc1f6f03bc289643bd5384791 (diff) | |
download | gdb-1c617db829e6a6fbcfebd3ad86fa93c88ee3c222.zip gdb-1c617db829e6a6fbcfebd3ad86fa93c88ee3c222.tar.gz gdb-1c617db829e6a6fbcfebd3ad86fa93c88ee3c222.tar.bz2 |
* monitor.h: Add the function regname to monitor_ops
structure. This way NUM_REGS does not have to be a constant.
* monitor.c (monitor_fetch_register): Added support for regname
function. The function is called if the array regnames is NULL.
(monitor_store_register): Same.
* cpu32bug-rom.c (cpu32bug_regname): Add function. Replaces regnames array.
(init_cpu32bug_cmds): set cpu32bug_cmds.regnames to NULL,
cpu32bug_cmds.regname to point to new function.
* abug-rom.c (abug_regname): Same as above.
(init_abug_cmds): Same.
* dbug-rom.c (dbug_regname): Same as above.
(init_dbug_cmds): Same.
* remote-est.c (est_regname): Same.
(init_est_cmds): Same.
* rom68k-rom.c (rom68k_regname): Same.
(init_rom68k_cmds): Same.
Diffstat (limited to 'gdb/dbug-rom.c')
-rw-r--r-- | gdb/dbug-rom.c | 27 |
1 files changed, 20 insertions, 7 deletions
diff --git a/gdb/dbug-rom.c b/gdb/dbug-rom.c index f315557..bd20184 100644 --- a/gdb/dbug-rom.c +++ b/gdb/dbug-rom.c @@ -76,13 +76,25 @@ dbug_supply_register (char *regname, int regnamelen, char *val, int vallen) different names than GDB does, and don't support all the registers either. So, typing "info reg sp" becomes an "A7". */ -static char *dbug_regnames[NUM_REGS] = +static const char * +dbug_regname (int index) { - "D0", "D1", "D2", "D3", "D4", "D5", "D6", "D7", - "A0", "A1", "A2", "A3", "A4", "A5", "A6", "A7", - "SR", "PC" - /* no float registers */ -}; + static char *regnames[] = + { + "D0", "D1", "D2", "D3", "D4", "D5", "D6", "D7", + "A0", "A1", "A2", "A3", "A4", "A5", "A6", "A7", + "SR", "PC" + /* no float registers */ + }; + + if ((index >= (sizeof (regnames) / sizeof (regnames[0]))) + || (index < 0) || (index >= NUM_REGS)) + return NULL; + else + return regnames[index]; + +} + static struct target_ops dbug_ops; static struct monitor_ops dbug_cmds; @@ -135,7 +147,8 @@ init_dbug_cmds (void) dbug_cmds.cmd_end = NULL; /* optional command terminator */ dbug_cmds.target = &dbug_ops; /* target operations */ dbug_cmds.stopbits = SERIAL_1_STOPBITS; /* number of stop bits */ - dbug_cmds.regnames = dbug_regnames; /* registers names */ + dbug_cmds.regnames = NULL; /* registers names */ + dbug_cmds.regname = dbug_regname; dbug_cmds.magic = MONITOR_OPS_MAGIC; /* magic */ } /* init_debug_ops */ |