Initial revision
[deliverable/binutils-gdb.git] / gdb / remote-z8k.c
CommitLineData
a332e593 1/* Remote debugging interface for Zilog Z8000 simulator
f48c6d1a 2 Copyright 1992,1993 Free Software Foundation, Inc.
a332e593
SC
3 Contributed by Cygnus Support. Written by Steve Chamberlain
4 (sac@cygnus.com).
5
6This file is part of GDB.
7
8This program is free software; you can redistribute it and/or modify
9it under the terms of the GNU General Public License as published by
10the Free Software Foundation; either version 2 of the License, or
11(at your option) any later version.
12
13This program is distributed in the hope that it will be useful,
14but WITHOUT ANY WARRANTY; without even the implied warranty of
15MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16GNU General Public License for more details.
17
18You should have received a copy of the GNU General Public License
19along with this program; if not, write to the Free Software
20Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
21
22#include "defs.h"
23#include "inferior.h"
24#include "wait.h"
25#include "value.h"
26#include <string.h>
27#include <ctype.h>
28#include <fcntl.h>
29#include <signal.h>
30#include <setjmp.h>
31#include <errno.h>
32#include "terminal.h"
33#include "target.h"
34#include "gdbcore.h"
6d2f03fe 35#include "../sim/z8k/sim.h"
a332e593
SC
36
37/* External data declarations */
e4ebb8e5 38extern int stop_soon_quietly; /* for wait_for_inferior */
a332e593
SC
39
40/* Forward data declarations */
e4ebb8e5 41extern struct target_ops sim_ops; /* Forward declaration */
a332e593 42
e4ebb8e5
SC
43void sim_store_register ();
44void sim_set_oc ();
a332e593
SC
45
46int
47sim_write_inferior_memory (memaddr, myaddr, len)
48 CORE_ADDR memaddr;
49 unsigned char *myaddr;
50 int len;
51{
e4ebb8e5 52 sim_write (memaddr, myaddr, len);
1f21d3dc 53 return 1;
a332e593
SC
54}
55
1f21d3dc 56static void
e4ebb8e5
SC
57store_register (regno)
58 int regno;
a332e593 59{
e4ebb8e5
SC
60 if (regno == -1)
61 {
62 for (regno = 0; regno < 16; regno++)
63 {
64 store_register (regno);
65 }
66 }
67 else
f48c6d1a 68 {
e4ebb8e5 69 sim_store_register (regno, read_register (regno));
f48c6d1a 70 }
a332e593
SC
71}
72
a332e593 73void
e4ebb8e5
SC
74sim_kill (arg, from_tty)
75 char *arg;
76 int from_tty;
a332e593
SC
77{
78
79}
80
a332e593 81/*
e4ebb8e5 82 * Download a file specified in 'args', to the sim.
a332e593
SC
83 */
84static void
e4ebb8e5
SC
85sim_load (args, fromtty)
86 char *args;
87 int fromtty;
a332e593 88{
e4ebb8e5 89 bfd *abfd;
a332e593
SC
90 asection *s;
91
e4ebb8e5
SC
92 inferior_pid = 0;
93 abfd = bfd_openr (args, "coff-z8k");
a332e593 94
e4ebb8e5
SC
95 if (!abfd)
96 {
97 printf_filtered ("Unable to open file %s\n", args);
98 return;
99 }
a332e593 100
e4ebb8e5
SC
101 if (bfd_check_format (abfd, bfd_object) == 0)
102 {
103 printf_filtered ("File is not an object file\n");
104 return;
105 }
a332e593
SC
106
107 s = abfd->sections;
e4ebb8e5 108 while (s != (asection *) NULL)
a332e593 109 {
e4ebb8e5
SC
110 if (s->flags & SEC_LOAD)
111 {
112 int i;
113 int delta = 4096;
114 char *buffer = xmalloc (delta);
115
116 printf_filtered ("%s\t: 0x%4x .. 0x%4x ",
117 s->name, s->vma, s->vma + s->_raw_size);
118 for (i = 0; i < s->_raw_size; i += delta)
119 {
120 int sub_delta = delta;
121
122 if (sub_delta > s->_raw_size - i)
123 sub_delta = s->_raw_size - i;
124
125 bfd_get_section_contents (abfd, s, buffer, i, sub_delta);
126 sim_write_inferior_memory (s->vma + i, buffer, sub_delta);
127 printf_filtered ("*");
199b2450 128 gdb_flush (gdb_stdout);
e4ebb8e5
SC
129 }
130 printf_filtered ("\n");
131 free (buffer);
132 }
133 s = s->next;
a332e593 134 }
a332e593 135
e4ebb8e5 136 sim_set_pc (abfd->start_address);
a332e593
SC
137}
138
139/* This is called not only when we first attach, but also when the
140 user types "run" after having attached. */
1f21d3dc 141static void
a332e593
SC
142sim_create_inferior (execfile, args, env)
143 char *execfile;
144 char *args;
145 char **env;
146{
147 int entry_pt;
a332e593
SC
148
149 if (args && *args)
e4ebb8e5 150 error ("Can't pass arguments to remote sim process.");
a332e593
SC
151
152 if (execfile == 0 || exec_bfd == 0)
e4ebb8e5 153 error ("No exec file specified");
a332e593
SC
154
155 entry_pt = (int) bfd_get_start_address (exec_bfd);
156
e4ebb8e5
SC
157 sim_kill (NULL, NULL);
158 sim_clear_breakpoints ();
a332e593 159 init_wait_for_inferior ();
1f21d3dc 160 insert_breakpoints ();
e4ebb8e5 161 proceed (entry_pt, -1, 0);
a332e593
SC
162}
163
a332e593
SC
164static void
165sim_open (name, from_tty)
166 char *name;
167 int from_tty;
168{
e4ebb8e5
SC
169 if (name == 0)
170 {
171 name = "";
172 }
a332e593
SC
173
174 /* Clear any break points */
e4ebb8e5 175 sim_clear_breakpoints ();
a332e593
SC
176
177 push_target (&sim_ops);
e4ebb8e5 178 target_fetch_registers (-1);
a332e593 179
e4ebb8e5 180 printf_filtered ("Connected to the Z8000 Simulator.\n");
a332e593
SC
181}
182
183/* Close out all files and local state before this target loses control. */
184
185static void
186sim_close (quitting)
187 int quitting;
188{
e4ebb8e5 189 sim_clear_breakpoints ();
a332e593
SC
190}
191
192/* Terminate the open connection to the remote debugger.
193 Use this when you want to detach and do something else
194 with your gdb. */
1f21d3dc 195static void
e4ebb8e5 196sim_detach (args, from_tty)
a332e593
SC
197 char *args;
198 int from_tty;
199{
e4ebb8e5
SC
200 sim_clear_breakpoints ();
201
202 pop_target (); /* calls sim_close to do the real work */
a332e593 203 if (from_tty)
e4ebb8e5 204 printf_filtered ("Ending remote %s debugging\n", target_shortname);
a332e593 205}
a332e593 206
e4ebb8e5 207/* Tell the remote machine to resume. */
a332e593
SC
208
209/* Wait until the remote machine stops, then return,
210 storing status in STATUS just as `wait' would. */
211
212int
de43d7d0
SG
213sim_wait (pid, status)
214 int pid;
a332e593
SC
215 WAITTYPE *status;
216{
e4ebb8e5 217 *status = sim_stop_signal ();
1f21d3dc 218 return 0;
a332e593
SC
219}
220
a332e593
SC
221/* Get ready to modify the registers array. On machines which store
222 individual registers, this doesn't need to do anything. On machines
223 which store all the registers in one fell swoop, this makes sure
224 that registers contains all the registers from the program being
225 debugged. */
226
1f21d3dc 227static void
a332e593
SC
228sim_prepare_to_store ()
229{
230 /* Do nothing, since we can store individual regs */
231}
232
a332e593 233static void
e4ebb8e5
SC
234fetch_register (regno)
235 int regno;
a332e593 236{
e4ebb8e5
SC
237 if (regno == -1)
238 {
239 for (regno = 0; regno < 16; regno++)
240 fetch_register (regno);
241 }
242 else
243 {
244 char buf[MAX_REGISTER_RAW_SIZE];
245
246 sim_fetch_register (regno, buf);
247 supply_register (regno, buf);
248 }
a332e593
SC
249}
250
251/* Write a word WORD into remote address ADDR.
252 This goes through the data cache. */
253
254void
255sim_store_word (addr, word)
256 CORE_ADDR addr;
257 int word;
258{
259/* dcache_poke (addr, word);*/
260}
261
262int
e4ebb8e5 263sim_xfer_inferior_memory (memaddr, myaddr, len, write, target)
a332e593
SC
264 CORE_ADDR memaddr;
265 char *myaddr;
266 int len;
267 int write;
e4ebb8e5 268 struct target_ops *target; /* ignored */
a332e593
SC
269{
270 if (write)
e4ebb8e5
SC
271 {
272 sim_write (memaddr, myaddr, len);
273
274 }
275 else
276 {
277 sim_read (memaddr, myaddr, len);
278 }
279 return len;
a332e593
SC
280}
281
282void
283sim_files_info ()
284{
f48c6d1a 285 char *file = "nothing";
e4ebb8e5 286
f48c6d1a 287 if (exec_bfd)
e4ebb8e5 288 file = bfd_get_filename (exec_bfd);
f48c6d1a 289
e4ebb8e5 290 printf_filtered ("\tAttached to %s running on the z8k simulator\n", file);
a332e593
SC
291}
292
293/* This routine is run as a hook, just before the main command loop is
294 entered. If gdb is configured for the H8, but has not had its
295 target specified yet, this will loop prompting the user to do so.
296*/
297
298void
299sim_before_main_loop ()
300{
a332e593
SC
301 push_target (&sim_ops);
302}
303
a332e593 304/* Clear the sims notion of what the break points are */
1f21d3dc 305static void
e4ebb8e5
SC
306sim_mourn ()
307{
308 sim_clear_breakpoints ();
71607f9d 309 unpush_target (&sim_ops);
a332e593 310 generic_mourn_inferior ();
a332e593
SC
311}
312
e4ebb8e5 313static void
25286543
SG
314rem_resume (pid, a, b)
315 int pid;
e4ebb8e5
SC
316 int a;
317 int b;
a332e593 318{
e4ebb8e5 319 sim_resume (a, b);
a332e593
SC
320}
321
322/* Define the target subroutine names */
323
e4ebb8e5 324struct target_ops sim_ops =
a332e593
SC
325{
326 "sim", "Remote SIM monitor",
327 "Use the Z8000 simulator",
e4ebb8e5
SC
328 sim_open, sim_close,
329 0, sim_detach, rem_resume, sim_wait, /* attach */
a332e593
SC
330 fetch_register, store_register,
331 sim_prepare_to_store,
e4ebb8e5 332 sim_xfer_inferior_memory,
a332e593 333 sim_files_info,
e4ebb8e5 334 0, 0, /* Breakpoints */
a332e593
SC
335 0, 0, 0, 0, 0, /* Terminal handling */
336 sim_kill, /* FIXME, kill */
e4ebb8e5 337 sim_load,
a332e593 338 0, /* lookup_symbol */
e4ebb8e5 339 sim_create_inferior, /* create_inferior */
a332e593
SC
340 sim_mourn, /* mourn_inferior FIXME */
341 0, /* can_run */
342 0, /* notice_signals */
343 process_stratum, 0, /* next */
344 1, 1, 1, 1, 1, /* all mem, mem, stack, regs, exec */
e4ebb8e5 345 0, 0, /* Section pointers */
a332e593
SC
346 OPS_MAGIC, /* Always the last thing */
347};
348
a332e593
SC
349/***********************************************************************/
350
351void
352_initialize_remote_sim ()
353{
354 extern int sim_z8001_mode;
e4ebb8e5 355
a332e593
SC
356 sim_z8001_mode = z8001_mode;
357 add_target (&sim_ops);
a332e593 358
e4ebb8e5 359}
This page took 0.096113 seconds and 4 git commands to generate.