Change defn of LOCAL_LABEL_PREFIX to ""
[external/binutils.git] / gdb / mcore-rom.c
1 /* Remote debugging interface to Motorola picobug monitor for gdb,
2    the GNU debugger.
3    Copyright 1999 Free Software Foundation, Inc.
4
5    This file is part of GDB.
6
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16
17    You should have received a copy of the GNU General Public License
18    along with this program; if not, write to the Free Software
19    Foundation, Inc., 59 Temple Place - Suite 330,
20    Boston, MA 02111-1307, USA.  */
21
22 #include "defs.h"
23 #include "gdbcore.h"
24 #include "target.h"
25 #include "monitor.h"
26 #include "gdb_string.h"
27
28 /* Functions used only in this file. */
29
30 static void init_picobug_cmds (void);
31
32
33 /* Functions exported from this file. */
34
35 void _initialize_picobug_rom (void);
36
37 void picobug_open (char *args, int from_tty);
38
39 int picobug_dumpregs (void);
40
41
42 static char *picobug_inits[] =
43 {"\r", NULL};
44
45 static struct target_ops picobug_ops;
46 static struct monitor_ops picobug_cmds;
47
48 /* Picobug only supports a subset of registers from MCore. In reality,
49    it doesn't support ss1, either. */
50 /* *INDENT-OFF* */
51 static char *picobug_regnames[] = {
52   "r0",   "r1",   "r2",   "r3",   "r4",   "r5",   "r6",   "r7",
53   "r8",   "r9",   "r10",  "r11",  "r12",  "r13",  "r14",  "r15",
54   0,      0,      0,      0,      0,      0,      0,      0,
55   0,      0,      0,      0,      0,      0,      0,      0,
56   "psr",  "vbr",  "epsr", "fpsr", "epc",  "fpc",  0,      "ss1",
57   "ss2",  "ss3",  "ss4",  0,      0,      0,      0,      0,
58   0,      0,      0,      0,      0,      0,      0,      0,
59   0,      0,      0,      0,      0,      0,      0,      0,
60   "pc" };
61 /* *INDENT-ON* */
62
63
64
65 void
66 picobug_open (char *args, int from_tty)
67 {
68   monitor_open (args, &picobug_cmds, from_tty);
69 }
70 /* *INDENT-OFF* */
71 /* We choose to write our own dumpregs routine, since the output of
72    the register dumping is rather difficult to encapsulate in a
73    regexp:
74
75 picobug> rd                                                                 
76      pc 2f00031e      epc 2f00031e      fpc 00000000
77     psr 80000101     epsr 80000101     fpsr 00000000
78 ss0-ss4 bad0beef 00000000 00000000 00000000 00000000      vbr 30005c00
79   r0-r7 2f0fff4c 00000090 00000001 00000002 00000003 00000004 00000005 00000006
80  r8-r15 2f0fff64 00000000 00000000 00000000 00000000 00000000 00000000 2f00031e */
81 /* *INDENT-ON* */
82
83
84
85 int
86 picobug_dumpregs (void)
87 {
88   char buf[1024];
89   int resp_len;
90   char *p;
91
92   /* Send the dump register command to the monitor and
93      get the reply. */
94   monitor_printf (picobug_cmds.dump_registers);
95   resp_len = monitor_expect_prompt (buf, sizeof (buf));
96
97   p = strtok (buf, " \t\r\n");
98   while (p)
99     {
100       if (strchr (p, '-'))
101         {
102           /* got a range. either r0-r7, r8-r15 or ss0-ss4 */
103           if (STREQN (p, "r0", 2) || STREQN (p, "r8", 2))
104             {
105               int rn = (p[1] == '0' ? 0 : 8);
106               int i = 0;
107
108               /* Get the next 8 values and record them. */
109               while (i < 8)
110                 {
111                   p = strtok (NULL, " \t\r\n");
112                   if (p)
113                     monitor_supply_register (rn + i, p);
114                   i++;
115                 }
116             }
117           else if (STREQN (p, "ss", 2))
118             {
119               /* get the next five values, ignoring the first */
120               int rn;
121               p = strtok (NULL, " \t\r\n");
122               for (rn = 39; rn < 43; rn++)
123                 {
124                   p = strtok (NULL, " \t\r\n");
125                   if (p)
126                     monitor_supply_register (rn, p);
127                 }
128             }
129           else
130             {
131               break;
132             }
133         }
134       else
135         {
136           /* Simple register type, paired */
137           char *name = p;
138           int i;
139
140           /* Get and record value */
141           p = strtok (NULL, " \t\r\n");
142           if (p)
143             {
144               for (i = 0; i < NUM_REGS; i++)
145                 {
146                   if (picobug_regnames[i] && STREQ (picobug_regnames[i], name))
147                     break;
148                 }
149
150               if (i <= NUM_REGS)
151                 monitor_supply_register (i, p);
152             }
153         }
154       p = strtok (NULL, " \t\r\n");
155     }
156
157   return 0;
158 }
159
160 static void
161 init_picobug_cmds (void)
162 {
163   picobug_cmds.flags = MO_GETMEM_NEEDS_RANGE | MO_CLR_BREAK_USES_ADDR | MO_PRINT_PROGRAM_OUTPUT;
164
165   picobug_cmds.init = picobug_inits;    /* Init strings                       */
166   picobug_cmds.cont = "g\n";    /* continue command                   */
167   picobug_cmds.step = "s\n";    /* single step                        */
168   picobug_cmds.set_break = "br %x\n";   /* set a breakpoint                   */
169   picobug_cmds.clr_break = "nobr %x\n";         /* clear a breakpoint                 */
170   picobug_cmds.clr_all_break = "nobr\n";        /* clear all breakpoints              */
171   picobug_cmds.setmem.cmdb = "mm %x %x ;b\n";   /* setmem.cmdb (addr, value)          */
172   picobug_cmds.setmem.cmdw = "mm %x %x ;h\n";   /* setmem.cmdw (addr, value)          */
173   picobug_cmds.setmem.cmdl = "mm %x %x ;w\n";   /* setmem.cmdl (addr, value)          */
174   picobug_cmds.getmem.cmdb = "md %x %x\n";      /* getmem.cmdb (start addr, end addr) */
175   picobug_cmds.getmem.resp_delim = ":";         /* getmem.resp_delim                  */
176   picobug_cmds.setreg.cmd = "rm %s %x\n";       /* setreg.cmd (name, value)           */
177   picobug_cmds.getreg.cmd = "rd %s\n";  /* getreg.cmd (name)                  */
178   picobug_cmds.getreg.resp_delim = ":";         /* getreg.resp_delim                  */
179   picobug_cmds.dump_registers = "rd\n";         /* dump_registers                     */
180   picobug_cmds.dumpregs = picobug_dumpregs;     /* dump registers parser              */
181   picobug_cmds.load = "lo\n";   /* download command                   */
182   picobug_cmds.prompt = "picobug> ";    /* monitor command prompt             */
183   picobug_cmds.line_term = "\n";        /* end-of-line terminator             */
184   picobug_cmds.target = &picobug_ops;   /* target operations                  */
185   picobug_cmds.stopbits = SERIAL_1_STOPBITS;    /* number of stop bits                */
186   picobug_cmds.regnames = picobug_regnames;     /* registers names                    */
187   picobug_cmds.num_breakpoints = 20;    /* number of breakpoints              */
188   picobug_cmds.magic = MONITOR_OPS_MAGIC;       /* magic                              */
189 }
190
191 void
192 _initialize_picobug_rom (void)
193 {
194   int i;
195
196   /* Initialize m32r RevC monitor target */
197   init_picobug_cmds ();
198   init_monitor_ops (&picobug_ops);
199   picobug_ops.to_shortname = "picobug";
200   picobug_ops.to_longname = "picobug monitor";
201   picobug_ops.to_doc = "Debug via the picobug monitor.\n\
202 Specify the serial device it is connected to (e.g. /dev/ttya).";
203   picobug_ops.to_open = picobug_open;
204
205   add_target (&picobug_ops);
206 }