aboutsummaryrefslogtreecommitdiff
path: root/gdb/rom68k-rom.c
diff options
context:
space:
mode:
Diffstat (limited to 'gdb/rom68k-rom.c')
-rw-r--r--gdb/rom68k-rom.c143
1 files changed, 143 insertions, 0 deletions
diff --git a/gdb/rom68k-rom.c b/gdb/rom68k-rom.c
new file mode 100644
index 0000000..719cb4d
--- /dev/null
+++ b/gdb/rom68k-rom.c
@@ -0,0 +1,143 @@
+#include "defs.h"
+#include "gdbcore.h"
+#include "target.h"
+#include "monitor.h"
+
+extern int baud_rate;
+
+void rom68k_open();
+void monitor_open();
+
+/*
+ * this array of registers need to match the indexes used by GDB. The
+ * whole reason this exists is cause the various ROM monitors use
+ * different strings than GDB does, and doesn't support all the
+ * registers either. So, typing "info reg sp" becomes a "r30".
+ */
+static char *rom68k_regnames[] = {
+ "d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7", "a0", "a1",
+ "a2", "a3", "a4", "a5", "a6", "usp", "ssp","pc", "", "",
+ "", "", "", "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "", "",
+ "", "", "", "", "", "", "", ""
+};
+
+/*
+ * Define the monitor command strings. Since these are passed directly
+ * through to a printf style function, we need can include formatting
+ * strings. We also need a CR or LF on the end.
+ */
+
+struct target_ops rom68k_ops = {
+ "rom68k",
+ "WinBond's debug monitor for the Rom68k Eval board",
+ "Debug on a Motorola IDP eval board running the ROM68K monitor.\n\
+Specify the serial device it is connected to (e.g. /dev/ttya).",
+ rom68k_open,
+ monitor_close,
+ monitor_attach,
+ monitor_detach,
+ monitor_resume,
+ monitor_wait,
+ monitor_fetch_register,
+ monitor_store_register,
+ monitor_prepare_to_store,
+ monitor_xfer_inferior_memory,
+ monitor_files_info,
+ monitor_insert_breakpoint,
+ monitor_remove_breakpoint, /* Breakpoints */
+ 0,
+ 0,
+ 0,
+ 0,
+ 0, /* Terminal handling */
+ monitor_kill,
+ monitor_load, /* load */
+ 0, /* lookup_symbol */
+ monitor_create_inferior,
+ monitor_mourn_inferior,
+ 0, /* can_run */
+ 0, /* notice_signals */
+ process_stratum,
+ 0, /* next */
+ 1,
+ 1,
+ 1,
+ 1,
+ 1, /* all mem, mem, stack, regs, exec */
+ 0,
+ 0, /* Section pointers */
+ OPS_MAGIC, /* Always the last thing */
+};
+
+struct monitor_ops rom68k_cmds = {
+ 1, /* 1 for ASCII, 0 for binary */
+ "\n", /* monitor init string */
+ "go \n", /* execute or usually GO command */
+ "go \n", /* continue command */
+ "st \n", /* single step */
+ "db %x\n", /* set a breakpoint */
+ "cb %x\r", /* clear a breakpoint */
+ 0, /* 0 for number, 1 for address */
+ {
+ "pm %x %x\r", /* set memory */
+ "=", /* delimiter */
+ "", /* the result */
+ },
+ {
+ "dm %x 1\r", /* get memory */
+ "", /* delimiter */
+ "", /* the result */
+ },
+ {
+ "pr %s %x\r", /* set a register */
+ "", /* delimiter between registers */
+ "", /* the result */
+ },
+ {
+ "pr %s\n", /* get a register */
+ ":", /* delimiter between registers */
+ "", /* the result */
+ },
+ "dc\n", /* download command */
+ "ROM68K :->", /* monitor command prompt */
+ "=", /* end-of-command delimitor */
+ ".\n", /* optional command terminator */
+ &rom68k_ops, /* target operations */
+ "srec,xmodem-ascii,xmodem-srec,default",/* load types */
+ rom68k_regnames /* registers names */
+};
+
+void
+rom68k_open(args, from_tty)
+ char *args;
+ int from_tty;
+{
+ target_preopen(from_tty);
+ push_target (&rom68k_ops);
+ push_monitor (&rom68k_cmds);
+ monitor_open (args, "rom68k", from_tty);
+}
+
+void
+_initialize_rom68k ()
+{
+ add_target (&rom68k_ops);
+
+ /* this is the default, since it's the only baud rate supported by the hardware */
+ baud_rate = 9600;
+}
+
+
+
+