summaryrefslogtreecommitdiff
path: root/gdb/remote-est.c
diff options
context:
space:
mode:
authorGrace Sainsbury <graces@redhat.com>2002-06-26 15:14:32 +0000
committerGrace Sainsbury <graces@redhat.com>2002-06-26 15:14:32 +0000
commit7fbe7183ee75ab23bb3e694728c9e11b7da6e996 (patch)
tree3f3c68c3b8ebfaf6d5f9635eec218228b3723a7f /gdb/remote-est.c
parent77dbbcb0e4a7a58fb60b6d1a758055c214ce4f60 (diff)
downloadgdb-7fbe7183ee75ab23bb3e694728c9e11b7da6e996.tar.gz
* 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/remote-est.c')
-rw-r--r--gdb/remote-est.c25
1 files changed, 19 insertions, 6 deletions
diff --git a/gdb/remote-est.c b/gdb/remote-est.c
index e045a8951cd..86310e9033d 100644
--- a/gdb/remote-est.c
+++ b/gdb/remote-est.c
@@ -76,12 +76,24 @@ est_supply_register (char *regname, int regnamelen, char *val, int vallen)
* registers either. So, typing "info reg sp" becomes a "r30".
*/
-static char *est_regnames[NUM_REGS] =
+static char *
+est_regname (int index)
{
- "D0", "D1", "D2", "D3", "D4", "D5", "D6", "D7",
- "A0", "A1", "A2", "A3", "A4", "A5", "A6", "A7",
- "SR", "PC",
-};
+
+ static char *regnames[] =
+ {
+ "D0", "D1", "D2", "D3", "D4", "D5", "D6", "D7",
+ "A0", "A1", "A2", "A3", "A4", "A5", "A6", "A7",
+ "SR", "PC",
+ };
+
+
+ if ((index >= (sizeof (regnames) / sizeof (regnames[0])))
+ || (index < 0) || (index >= NUM_REGS))
+ return NULL;
+ else
+ return regnames[index];
+}
/*
* Define the monitor command strings. Since these are passed directly
@@ -143,7 +155,8 @@ init_est_cmds (void)
est_cmds.cmd_end = NULL; /* optional command terminator */
est_cmds.target = &est_ops; /* target operations */
est_cmds.stopbits = SERIAL_1_STOPBITS; /* number of stop bits */
- est_cmds.regnames = est_regnames; /* registers names */
+ est_cmds.regnames = NULL;
+ est_cmds.regname = est_regname; /*register names*/
est_cmds.magic = MONITOR_OPS_MAGIC; /* magic */
} /* init_est_cmds */