aboutsummaryrefslogtreecommitdiff
path: root/gdb/remote-mips.c
diff options
context:
space:
mode:
Diffstat (limited to 'gdb/remote-mips.c')
-rw-r--r--gdb/remote-mips.c122
1 files changed, 104 insertions, 18 deletions
diff --git a/gdb/remote-mips.c b/gdb/remote-mips.c
index 37c50d1..5bcd110 100644
--- a/gdb/remote-mips.c
+++ b/gdb/remote-mips.c
@@ -71,6 +71,8 @@ static void mips_open PARAMS ((char *name, int from_tty));
static void pmon_open PARAMS ((char *name, int from_tty));
+static void cairo_open PARAMS ((char *name, int from_tty));
+
static void mips_close PARAMS ((int quitting));
static void mips_detach PARAMS ((char *args, int from_tty));
@@ -133,6 +135,7 @@ static void common_open PARAMS ((struct target_ops *ops, char *name,
/* Forward declarations. */
extern struct target_ops mips_ops;
extern struct target_ops pmon_ops;
+extern struct target_ops cairo_ops;
/* The MIPS remote debugging interface is built on top of a simple
packet protocol. Each packet is organized as follows:
@@ -272,7 +275,8 @@ enum mips_monitor_type {
/* IDT/SIM monitor being used: */
MON_IDT,
/* PMON monitor being used: */
- MON_PMON,
+ MON_PMON, /* 3.0.83 [COGENT,EB,FP,NET] Algorithmics Ltd. Nov 9 1995 17:19:50 */
+ MON_CAIRO, /* 2.7.473 [Cairo ,EL,FP,NET] Risq Modular Systems, Thu Jun 6 09:28:40 PDT 1996 */
/* Last and unused value, for sizing vectors, etc. */
MON_LAST
};
@@ -1154,7 +1158,7 @@ mips_enter_debug ()
mips_send_seq = 0;
mips_receive_seq = 0;
- if (mips_monitor == MON_PMON)
+ if (mips_monitor == MON_PMON || mips_monitor == MON_CAIRO)
mips_send_command ("debug\015", 0);
else /* assume IDT monitor by default */
mips_send_command ("db tty0\015", 0);
@@ -1165,7 +1169,7 @@ mips_enter_debug ()
mips_receive_header will eat up a reasonable number of characters
whilst looking for the SYN, however this avoids the "garbage"
being displayed to the user. */
- if (mips_monitor == MON_PMON)
+ if (mips_monitor == MON_PMON || mips_monitor == MON_CAIRO)
mips_expect ("\015");
{
@@ -1181,14 +1185,31 @@ mips_exit_debug ()
{
int err;
- mips_request ('x', (unsigned int) 0, (unsigned int) 0, &err,
+ if (mips_monitor == MON_CAIRO)
+ {
+ /* The Cairo version of PMON exits immediately, so we do not get
+ a reply to this command: */
+ mips_request ('x', (unsigned int) 0, (unsigned int) 0, NULL,
mips_receive_wait, NULL);
+ mips_need_reply = 0;
+ if (!mips_expect (" break!"))
+ return -1;
+ }
+ else
+ mips_request ('x', (unsigned int) 0, (unsigned int) 0, &err,
+ mips_receive_wait, NULL);
if (mips_monitor == MON_PMON && !mips_expect ("Exiting remote debug mode"))
return -1;
- if (!mips_expect ("\015\012"))
- return -1;
+ if (mips_monitor == MON_CAIRO)
+ {
+ if (!mips_expect ("\012"))
+ return -1;
+ }
+ else
+ if (!mips_expect ("\015\012"))
+ return -1;
if (!mips_expect (mips_monitor_prompt))
return -1;
@@ -1224,7 +1245,7 @@ mips_initialize ()
/* Force the system into the monitor. After this we *should* be at
the mips_monitor_prompt. */
- if (mips_monitor == MON_PMON)
+ if (mips_monitor == MON_PMON || mips_monitor == MON_CAIRO)
j = 0; /* start by checking if we are already at the prompt */
else
j = 1; /* start by sending a break */
@@ -1244,7 +1265,7 @@ mips_initialize ()
break;
case 3: /* Then, try escaping from download */
{
- if (mips_monitor == MON_PMON)
+ if (mips_monitor == MON_PMON || mips_monitor == MON_CAIRO)
{
char tbuff[7];
@@ -1293,7 +1314,7 @@ mips_initialize ()
break;
}
- if (mips_monitor == MON_PMON)
+ if (mips_monitor == MON_PMON || mips_monitor == MON_CAIRO)
{
/* Ensure the correct target state: */
mips_send_command ("set regsize 64\015", -1);
@@ -1410,6 +1431,17 @@ pmon_open (name, from_tty)
common_open (&pmon_ops, name, from_tty);
}
+static void
+cairo_open (name, from_tty)
+ char *name;
+ int from_tty;
+{
+ /* The PMON monitor has a prompt different from the default
+ "TARGET_MONITOR_PROMPT": */
+ mips_monitor_prompt = "NEC010>";
+ mips_monitor = MON_CAIRO;
+ common_open (&cairo_ops, name, from_tty);
+}
/* Close a connection to the remote board. */
@@ -1713,15 +1745,14 @@ mips_fetch_registers (regno)
val = 0;
else
{
-#if 0 /* Unfortunately the PMON version in the Vr4300 board has been
+ /* Unfortunately the PMON version in the Vr4300 board has been
compiled without the 64bit register access commands. This
means we cannot get hold of the full register width. */
- if (mips_monitor == MON_PMON)
- val = mips_request ('t', (unsigned int) mips_map_regno (regno),
+ if (mips_monitor == MON_CAIRO)
+ val = (unsigned)mips_request ('t', (unsigned int) mips_map_regno (regno),
(unsigned int) 0, &err, mips_receive_wait, NULL);
else
-#endif
- val = mips_request ('r', (unsigned int) mips_map_regno (regno),
+ val = (unsigned)mips_request ('r', (unsigned int) mips_map_regno (regno),
(unsigned int) 0, &err, mips_receive_wait, NULL);
if (err)
mips_error ("Can't read register %d: %s", regno,
@@ -2305,9 +2336,13 @@ common_breakpoint (cmd, addr, mask, flags)
if (rerrflg != 0)
{
+ /* Cairo returns "0x0 b 0x16 0x0\000", whereas
+ Cogent returns "0x0 b 0xffffffff 0x16\000": */
+ if (mips_monitor == MON_CAIRO)
+ rresponse = rerrflg;
if (rresponse != 22) /* invalid argument */
fprintf_unfiltered (stderr, "common_breakpoint (0x%x): Got error: 0x%x\n",
- addr, rresponse);
+ (unsigned int)addr, rresponse);
return 1;
}
@@ -2745,8 +2780,8 @@ pmon_load_fast (file)
bintotal += s->_raw_size;
final = (s->vma + s->_raw_size);
- printf_filtered ("%s\t: 0x%4x .. 0x%4x ", s->name, s->vma,
- s->vma + s->_raw_size);
+ printf_filtered ("%s\t: 0x%4x .. 0x%4x ", s->name, (unsigned int)s->vma,
+ (unsigned int)(s->vma + s->_raw_size));
gdb_flush (gdb_stdout);
/* Output the starting address */
@@ -2859,7 +2894,7 @@ mips_load (file, from_tty)
if (mips_exit_debug ())
error ("mips_load: Couldn't get into monitor mode.");
- if (mips_monitor == MON_PMON)
+ if (mips_monitor == MON_PMON || mips_monitor == MON_CAIRO)
pmon_load_fast (file);
else
mips_load_srec (file);
@@ -2979,11 +3014,62 @@ colon, HOST:PORT to access a board over a network", /* to_doc */
OPS_MAGIC /* to_magic */
};
+/* Another alternative target vector. This is a PMON system, but with
+ a different monitor prompt, aswell as some other operational
+ differences: */
+struct target_ops cairo_ops =
+{
+ "cairo", /* to_shortname */
+ "Remote MIPS debugging over serial line", /* to_longname */
+ "\
+Debug a board using the PMON MIPS remote debugging protocol over a serial\n\
+line. The argument is the device it is connected to or, if it contains a\n\
+colon, HOST:PORT to access a board over a network", /* to_doc */
+ cairo_open, /* to_open */
+ mips_close, /* to_close */
+ NULL, /* to_attach */
+ mips_detach, /* to_detach */
+ mips_resume, /* to_resume */
+ pmon_wait, /* to_wait */
+ mips_fetch_registers, /* to_fetch_registers */
+ mips_store_registers, /* to_store_registers */
+ mips_prepare_to_store, /* to_prepare_to_store */
+ mips_xfer_memory, /* to_xfer_memory */
+ mips_files_info, /* to_files_info */
+ mips_insert_breakpoint, /* to_insert_breakpoint */
+ mips_remove_breakpoint, /* to_remove_breakpoint */
+ NULL, /* to_terminal_init */
+ NULL, /* to_terminal_inferior */
+ NULL, /* to_terminal_ours_for_output */
+ NULL, /* to_terminal_ours */
+ NULL, /* to_terminal_info */
+ mips_kill, /* to_kill */
+ mips_load, /* to_load */
+ NULL, /* to_lookup_symbol */
+ mips_create_inferior, /* to_create_inferior */
+ mips_mourn_inferior, /* to_mourn_inferior */
+ NULL, /* to_can_run */
+ NULL, /* to_notice_signals */
+ 0, /* to_thread_alive */
+ 0, /* to_stop */
+ process_stratum, /* to_stratum */
+ NULL, /* to_next */
+ 1, /* to_has_all_memory */
+ 1, /* to_has_memory */
+ 1, /* to_has_stack */
+ 1, /* to_has_registers */
+ 1, /* to_has_execution */
+ NULL, /* sections */
+ NULL, /* sections_end */
+ OPS_MAGIC /* to_magic */
+};
+
void
_initialize_remote_mips ()
{
add_target (&mips_ops);
add_target (&pmon_ops);
+ add_target (&cairo_ops);
add_show_from_set (
add_set_cmd ("timeout", no_class, var_zinteger,