* gdbint.texinfo: Add a cautionary note about macro use.
[deliverable/binutils-gdb.git] / gdb / remote-eb.c
index 6fbea888c24114ded245c9c1e95aaf6406ecd4de..fa003c643261c7da9b5a6a70d63967a6aa89107f 100644 (file)
@@ -1,22 +1,24 @@
 /* Remote debugging interface for AMD 29000 EBMON on IBM PC, for GDB.
-   Copyright 1990, 1991, 1992 Free Software Foundation, Inc.
+   Copyright 1990, 1991, 1992, 1993, 1994, 1995, 1998, 1999, 2000, 2001
+   Free Software Foundation, Inc.
    Contributed by Cygnus Support.  Written by Jim Kingdon for Cygnus.
 
-This file is part of GDB.
+   This file is part of GDB.
 
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation; either version 2 of the License, or
-(at your option) any later version.
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 2 of the License, or
+   (at your option) any later version.
 
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
 
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
+   You should have received a copy of the GNU General Public License
+   along with this program; if not, write to the Free Software
+   Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
 
 /* This is like remote.c but is for an esoteric situation--
    having a a29k board in a PC hooked up to a unix machine with
@@ -27,11 +29,11 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 
 #include "defs.h"
 #include "gdb_string.h"
+#include "regcache.h"
 
 #include "inferior.h"
 #include "bfd.h"
 #include "symfile.h"
-#include "wait.h"
 #include "value.h"
 #include <ctype.h>
 #include <fcntl.h>
@@ -41,9 +43,9 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 #include "target.h"
 #include "gdbcore.h"
 
-extern struct target_ops eb_ops;               /* Forward declaration */
+extern struct target_ops eb_ops;       /* Forward declaration */
 
-static void eb_close();
+static void eb_close ();
 
 #define LOG_FILE "eb.log"
 #if defined (LOG_FILE)
@@ -64,7 +66,7 @@ FILE *eb_stream;
 /* Read a character from the remote system, doing all the fancy
    timeout stuff.  */
 static int
-readchar ()
+readchar (void)
 {
   char buf;
 
@@ -95,20 +97,19 @@ readchar ()
 /* Keep discarding input from the remote system, until STRING is found. 
    Let the user break out immediately.  */
 static void
-expect (string)
-     char *string;
+expect (char *string)
 {
   char *p = string;
 
-  immediate_quit = 1;
+  immediate_quit++;
   while (1)
     {
-      if (readchar() == *p)
+      if (readchar () == *p)
        {
          p++;
          if (*p == '\0')
            {
-             immediate_quit = 0;
+             immediate_quit--;
              return;
            }
        }
@@ -132,7 +133,7 @@ expect (string)
    necessary to prevent getting into states from which we can't
    recover.  */
 static void
-expect_prompt ()
+expect_prompt (void)
 {
 #if defined (LOG_FILE)
   /* This is a convenient place to do this.  The idea is to do it often
@@ -145,8 +146,7 @@ expect_prompt ()
 /* Get a hex digit from the remote system & return its value.
    If ignore_space is nonzero, ignore spaces (not newline, tab, etc).  */
 static int
-get_hex_digit (ignore_space)
-     int ignore_space;
+get_hex_digit (int ignore_space)
 {
   int ch;
   while (1)
@@ -171,8 +171,7 @@ get_hex_digit (ignore_space)
 /* Get a byte from eb_desc and put it in *BYT.  Accept any number
    leading spaces.  */
 static void
-get_hex_byte (byt)
-     char *byt;
+get_hex_byte (char *byt)
 {
   int val;
 
@@ -184,9 +183,7 @@ get_hex_byte (byt)
 /* Get N 32-bit words from remote, each preceded by a space,
    and put them in registers starting at REGNO.  */
 static void
-get_hex_regs (n, regno)
-     int n;
-     int regno;
+get_hex_regs (int n, int regno)
 {
   long val;
   int i;
@@ -194,7 +191,7 @@ get_hex_regs (n, regno)
   for (i = 0; i < n; i++)
     {
       int j;
-      
+
       val = 0;
       for (j = 0; j < 8; j++)
        val = (val << 4) + get_hex_digit (j == 0);
@@ -205,13 +202,10 @@ get_hex_regs (n, regno)
 /* Called when SIGALRM signal sent due to alarm() timeout.  */
 #ifndef HAVE_TERMIO
 
-#ifndef __STDC__
-#define volatile /**/
-#endif
 volatile int n_alarms;
 
 void
-eb_timer ()
+eb_timer (void)
 {
 #if 0
   if (kiodebug)
@@ -237,10 +231,7 @@ static int need_artificial_trap = 0;
 /* This is called not only when we first attach, but also when the
    user types "run" after having attached.  */
 static void
-eb_create_inferior (execfile, args, env)
-     char *execfile;
-     char *args;
-     char **env;
+eb_create_inferior (char *execfile, char *args, char **env)
 {
   int entry_pt;
 
@@ -248,7 +239,7 @@ eb_create_inferior (execfile, args, env)
     error ("Can't pass arguments to remote EBMON process");
 
   if (execfile == 0 || exec_bfd == 0)
-    error ("No exec file specified");
+    error ("No executable file specified");
 
   entry_pt = (int) bfd_get_start_address (exec_bfd);
 
@@ -259,7 +250,7 @@ eb_create_inferior (execfile, args, env)
     fprintf (eb_stream, "YC D,0:%s", prog_name);
 
     if (args != NULL)
-       fprintf(eb_stream, " %s", args);
+      fprintf (eb_stream, " %s", args);
 
     fprintf (eb_stream, "\n");
     fflush (eb_stream);
@@ -285,7 +276,7 @@ eb_create_inferior (execfile, args, env)
   target_terminal_inferior ();
 
   /* insert_step_breakpoint ();  FIXME, do we need this?  */
-  proceed ((CORE_ADDR)entry_pt, TARGET_SIGNAL_DEFAULT, 0);             /* Let 'er rip... */
+  proceed ((CORE_ADDR) entry_pt, TARGET_SIGNAL_DEFAULT, 0);    /* Let 'er rip... */
 }
 
 /* Translate baud rates from integers to damn B_codes.  Unix should
@@ -298,34 +289,91 @@ eb_create_inferior (execfile, args, env)
 #define B38400 EXTB
 #endif
 
-struct {int rate, damn_b;} baudtab[] = {
-       {0, B0},
-       {50, B50},
-       {75, B75},
-       {110, B110},
-       {134, B134},
-       {150, B150},
-       {200, B200},
-       {300, B300},
-       {600, B600},
-       {1200, B1200},
-       {1800, B1800},
-       {2400, B2400},
-       {4800, B4800},
-       {9600, B9600},
-       {19200, B19200},
-       {38400, B38400},
-       {-1, -1},
+struct
+{
+  int rate, damn_b;
+}
+baudtab[] =
+{
+  {
+    0, B0
+  }
+  ,
+  {
+    50, B50
+  }
+  ,
+  {
+    75, B75
+  }
+  ,
+  {
+    110, B110
+  }
+  ,
+  {
+    134, B134
+  }
+  ,
+  {
+    150, B150
+  }
+  ,
+  {
+    200, B200
+  }
+  ,
+  {
+    300, B300
+  }
+  ,
+  {
+    600, B600
+  }
+  ,
+  {
+    1200, B1200
+  }
+  ,
+  {
+    1800, B1800
+  }
+  ,
+  {
+    2400, B2400
+  }
+  ,
+  {
+    4800, B4800
+  }
+  ,
+  {
+    9600, B9600
+  }
+  ,
+  {
+    19200, B19200
+  }
+  ,
+  {
+    38400, B38400
+  }
+  ,
+  {
+    -1, -1
+  }
+  ,
 };
 
-int damn_b (rate)
-     int rate;
+int
+damn_b (int rate)
 {
   int i;
 
   for (i = 0; baudtab[i].rate != -1; i++)
-    if (rate == baudtab[i].rate) return baudtab[i].damn_b;
-  return B38400;       /* Random */
+    if (rate == baudtab[i].rate)
+      return baudtab[i].damn_b;
+  return B38400;               /* Random */
 }
 
 
@@ -336,16 +384,14 @@ int damn_b (rate)
 static int baudrate = 9600;
 static char *dev_name;
 void
-eb_open (name, from_tty)
-     char *name;
-     int from_tty;
+eb_open (char *name, int from_tty)
 {
   TERMINAL sg;
 
   char *p;
 
   target_preopen (from_tty);
-  
+
   /* Find the first whitespace character, it separates dev_name from
      prog_name.  */
   if (name == 0)
@@ -355,7 +401,7 @@ eb_open (name, from_tty)
        *p != '\0' && !isspace (*p); p++)
     ;
   if (*p == '\0')
-erroid:
+  erroid:
     error ("\
 Please include the name of the device for the serial port,\n\
 the baud rate, and the name of the program to run on the remote system.");
@@ -365,19 +411,19 @@ the baud rate, and the name of the program to run on the remote system.");
 
   /* Skip over the whitespace after dev_name */
   for (; isspace (*p); p++)
-    /*EMPTY*/;
-  
+    /*EMPTY */ ;
+
   if (1 != sscanf (p, "%d ", &baudrate))
     goto erroid;
 
   /* Skip the number and then the spaces */
   for (; isdigit (*p); p++)
-    /*EMPTY*/;
+    /*EMPTY */ ;
   for (; isspace (*p); p++)
-    /*EMPTY*/;
-  
+    /*EMPTY */ ;
+
   if (prog_name != NULL)
-    free (prog_name);
+    xfree (prog_name);
   prog_name = savestring (p, strlen (p));
 
   eb_close (0);
@@ -427,36 +473,36 @@ the baud rate, and the name of the program to run on the remote system.");
 
   /* Hello?  Are you there?  */
   write (eb_desc, "\n", 1);
-  
+
   expect_prompt ();
 }
 
 /* Close out all files and local state before this target loses control. */
 
 static void
-eb_close (quitting)
-     int quitting;
+eb_close (int quitting)
 {
 
   /* Due to a bug in Unix, fclose closes not only the stdio stream,
      but also the file descriptor.  So we don't actually close
      eb_desc.  */
   if (eb_stream)
-    fclose (eb_stream);        /* This also closes eb_desc */
+    fclose (eb_stream);                /* This also closes eb_desc */
   if (eb_desc >= 0)
     /* close (eb_desc); */
 
-  /* Do not try to close eb_desc again, later in the program.  */
-  eb_stream = NULL;
+    /* Do not try to close eb_desc again, later in the program.  */
+    eb_stream = NULL;
   eb_desc = -1;
 
 #if defined (LOG_FILE)
-  if (log_file) {
-    if (ferror (log_file))
-      printf ("Error writing log file.\n");
-    if (fclose (log_file) != 0)
-      printf ("Error closing log file.\n");
-  }
+  if (log_file)
+    {
+      if (ferror (log_file))
+       printf ("Error writing log file.\n");
+      if (fclose (log_file) != 0)
+       printf ("Error closing log file.\n");
+    }
 #endif
 }
 
@@ -464,20 +510,17 @@ eb_close (quitting)
    Use this when you want to detach and do something else
    with your gdb.  */
 void
-eb_detach (from_tty)
-     int from_tty;
+eb_detach (int from_tty)
 {
-  pop_target();                /* calls eb_close to do the real work */
+  pop_target ();               /* calls eb_close to do the real work */
   if (from_tty)
     printf ("Ending remote %s debugging\n", target_shortname);
 }
+
 /* Tell the remote machine to resume.  */
 
 void
-eb_resume (pid, step, sig)
-     int pid, step;
-     enum target_signal sig;
+eb_resume (ptid_t ptid, int step, enum target_signal sig)
 {
   if (step)
     {
@@ -500,7 +543,7 @@ eb_resume (pid, step, sig)
        {
          need_gi = 0;
          write (eb_desc, "gi\n", 3);
-         
+
          /* Swallow the echo of "gi".  */
          expect ("gi\r");
        }
@@ -516,15 +559,14 @@ eb_resume (pid, step, sig)
 /* Wait until the remote machine stops, then return,
    storing status in STATUS just as `wait' would.  */
 
-int
-eb_wait (status)
-     struct target_waitstatus *status;
+ptid_t
+eb_wait (ptid_t ptid, struct target_waitstatus *status)
 {
   /* Strings to look for.  '?' means match any single character.  
      Note that with the algorithm we use, the initial character
      of the string cannot recur in the string, or we will not
      find some cases of the string in the input.  */
-  
+
   static char bpt[] = "Invalid interrupt taken - #0x50 - ";
   /* It would be tempting to look for "\n[__exit + 0x8]\n"
      but that requires loading symbols with "yc i" and even if
@@ -554,7 +596,7 @@ eb_wait (status)
       return 0;
     }
 
-  timeout = 0;         /* Don't time out -- user program is running. */
+  timeout = 0;                 /* Don't time out -- user program is running. */
   while (1)
     {
       ch_handled = 0;
@@ -592,12 +634,12 @@ eb_wait (status)
          for (p = swallowed; p < swallowed_p; ++p)
            putc (*p, stdout);
          swallowed_p = swallowed;
-         
+
          putc (ch, stdout);
        }
     }
   expect_prompt ();
-  if (*bp== '\0')
+  if (*bp == '\0')
     {
       status->kind = TARGET_WAITKIND_STOPPED;
       status->value.sig = TARGET_SIGNAL_TRAP;
@@ -617,8 +659,7 @@ eb_wait (status)
 
    Returns a pointer to a static buffer containing the answer.  */
 static char *
-get_reg_name (regno)
-     int regno;
+get_reg_name (int regno)
 {
   static char buf[80];
   if (regno >= GR96_REGNUM && regno < GR96_REGNUM + 32)
@@ -643,7 +684,7 @@ get_reg_name (regno)
 /* Read the remote registers into the block REGS.  */
 
 static void
-eb_fetch_registers ()
+eb_fetch_registers (void)
 {
   int reg_index;
   int regnum_index;
@@ -674,7 +715,7 @@ eb_fetch_registers ()
   for (i = 0; i < 128; i += 32)
     {
       /* The PC has a tendency to hang if we get these
-        all in one fell swoop ("dw lr0,lr127").  */
+         all in one fell swoop ("dw lr0,lr127").  */
       sprintf (tempbuf, "dw lr%d\n", i);
       write (eb_desc, tempbuf, strlen (tempbuf));
       for (reg_index = i, regnum_index = LR0_REGNUM + i;
@@ -737,8 +778,7 @@ eb_fetch_registers ()
 /* Fetch register REGNO, or all registers if REGNO is -1.
    Returns errno value.  */
 void
-eb_fetch_register (regno)
-     int regno;
+eb_fetch_register (int regno)
 {
   if (regno == -1)
     eb_fetch_registers ();
@@ -757,7 +797,7 @@ eb_fetch_register (regno)
 /* Store the remote registers from the contents of the block REGS.  */
 
 static void
-eb_store_registers ()
+eb_store_registers (void)
 {
   int i, j;
   fprintf (eb_stream, "s gr1,%x\n", read_register (GR1_REGNUM));
@@ -796,8 +836,7 @@ eb_store_registers ()
 /* Store register REGNO, or all if REGNO == 0.
    Return errno value.  */
 void
-eb_store_register (regno)
-     int regno;
+eb_store_register (int regno)
 {
   if (regno == -1)
     eb_store_registers ();
@@ -806,11 +845,11 @@ eb_store_register (regno)
       char *name = get_reg_name (regno);
       fprintf (eb_stream, "s %s,%x\n", name, read_register (regno));
       /* Setting GR1 changes the numbers of all the locals, so
-        invalidate the register cache.  Do this *after* calling
-        read_register, because we want read_register to return the
-        value that write_register has just stuffed into the registers
-        array, not the value of the register fetched from the
-        inferior.  */
+         invalidate the register cache.  Do this *after* calling
+         read_register, because we want read_register to return the
+         value that write_register has just stuffed into the registers
+         array, not the value of the register fetched from the
+         inferior.  */
       if (regno == GR1_REGNUM)
        registers_changed ();
       expect_prompt ();
@@ -824,20 +863,21 @@ eb_store_register (regno)
    debugged.  */
 
 void
-eb_prepare_to_store ()
+eb_prepare_to_store (void)
 {
   /* Do nothing, since we can store individual regs */
 }
 
+/* Transfer LEN bytes between GDB address MYADDR and target address
+   MEMADDR.  If WRITE is non-zero, transfer them to the target,
+   otherwise transfer them from the target.  TARGET is unused.
+
+   Returns the number of bytes transferred. */
 
-/* FIXME-someday!  Merge these two.  */
 int
-eb_xfer_inferior_memory (memaddr, myaddr, len, write, target)
-     CORE_ADDR memaddr;
-     char *myaddr;
-     int len;
-     int write;
-     struct target_ops *target;                /* ignored */
+eb_xfer_inferior_memory (CORE_ADDR memaddr, char *myaddr, int len, int write,
+                        struct mem_attrib *attrib ATTRIBUTE_UNUSED,
+                        struct target_ops *target ATTRIBUTE_UNUSED)
 {
   if (write)
     return eb_write_inferior_memory (memaddr, myaddr, len);
@@ -846,7 +886,7 @@ eb_xfer_inferior_memory (memaddr, myaddr, len, write, target)
 }
 
 void
-eb_files_info ()
+eb_files_info (void)
 {
   printf ("\tAttached to %s at %d baud and running program %s.\n",
          dev_name, baudrate, prog_name);
@@ -855,10 +895,7 @@ eb_files_info ()
 /* Copy LEN bytes of data from debugger memory at MYADDR
    to inferior's memory at MEMADDR.  Returns length moved.  */
 int
-eb_write_inferior_memory (memaddr, myaddr, len)
-     CORE_ADDR memaddr;
-     char *myaddr;
-     int len;
+eb_write_inferior_memory (CORE_ADDR memaddr, char *myaddr, int len)
 {
   int i;
 
@@ -868,11 +905,11 @@ eb_write_inferior_memory (memaddr, myaddr, len)
        fprintf (eb_stream, "sb %x,", memaddr + i);
       if ((i % 16) == 15 || i == len - 1)
        {
-         fprintf (eb_stream, "%x\n", ((unsigned char *)myaddr)[i]);
+         fprintf (eb_stream, "%x\n", ((unsigned char *) myaddr)[i]);
          expect_prompt ();
        }
       else
-       fprintf (eb_stream, "%x,", ((unsigned char *)myaddr)[i]);
+       fprintf (eb_stream, "%x,", ((unsigned char *) myaddr)[i]);
     }
   return len;
 }
@@ -880,10 +917,7 @@ eb_write_inferior_memory (memaddr, myaddr, len)
 /* Read LEN bytes from inferior memory at MEMADDR.  Put the result
    at debugger address MYADDR.  Returns length moved.  */
 int
-eb_read_inferior_memory(memaddr, myaddr, len)
-     CORE_ADDR memaddr;
-     char *myaddr;
-     int len;
+eb_read_inferior_memory (CORE_ADDR memaddr, char *myaddr, int len)
 {
   int i;
 
@@ -905,11 +939,12 @@ eb_read_inferior_memory(memaddr, myaddr, len)
      eb_read_bytes (CORE_ADDR_MAX - 3, foo, 4)
      doesn't need to work.  Detect it and give up if there's an attempt
      to do that.  */
-  if (((memaddr - 1) + len) < memaddr) {
-    errno = EIO;
-    return 0;
-  }
-  
+  if (((memaddr - 1) + len) < memaddr)
+    {
+      errno = EIO;
+      return 0;
+    }
+
   startaddr = memaddr;
   count = 0;
   while (count < len)
@@ -952,11 +987,9 @@ eb_read_inferior_memory(memaddr, myaddr, len)
 }
 
 static void
-eb_kill (args, from_tty)
-     char *args;
-     int from_tty;
+eb_kill (char *args, int from_tty)
 {
-  return;              /* Ignore attempts to kill target system */
+  return;                      /* Ignore attempts to kill target system */
 }
 
 /* Clean up when a program exits.
@@ -966,7 +999,7 @@ eb_kill (args, from_tty)
    instructions.  */
 
 void
-eb_mourn_inferior ()
+eb_mourn_inferior (void)
 {
   remove_breakpoints ();
   unpush_target (&eb_ops);
@@ -974,58 +1007,82 @@ eb_mourn_inferior ()
 }
 /* Define the target subroutine names */
 
-struct target_ops eb_ops ;
-static void init_eb_ops(void)
+struct target_ops eb_ops;
+
+static void
+init_eb_ops (void)
 {
-  eb_ops.to_shortname =        "amd-eb";
-  eb_ops.to_longname =         "Remote serial AMD EBMON target";
-  eb_ops.to_doc =      "Use a remote computer running EBMON connected by a serial line.\n\
+  eb_ops.to_shortname = "amd-eb";
+  eb_ops.to_longname = "Remote serial AMD EBMON target";
+  eb_ops.to_doc = "Use a remote computer running EBMON connected by a serial line.\n\
 Arguments are the name of the device for the serial line,\n\
 the speed to connect at in bits per second, and the filename of the\n\
 executable as it exists on the remote computer.  For example,\n\
 target amd-eb /dev/ttya 9600 demo",
-    eb_ops.to_open =   eb_open;
-  eb_ops.to_close =    eb_close;
-  eb_ops.to_attach =   0;
-  eb_ops.to_detach =   eb_detach;
-  eb_ops.to_resume =   eb_resume;
-  eb_ops.to_wait  =    eb_wait;
-  eb_ops.to_fetch_registers  =         eb_fetch_register;
-  eb_ops.to_store_registers  =         eb_store_register;
-  eb_ops.to_prepare_to_store =         eb_prepare_to_store;
-  eb_ops.to_xfer_memory  =     eb_xfer_inferior_memory;
-  eb_ops.to_files_info  =      eb_files_info;
-  eb_ops.to_insert_breakpoint =        0;
-  eb_ops.to_remove_breakpoint =        0;      /* Breakpoints */
-  eb_ops.to_terminal_init  =   0;
-  eb_ops.to_terminal_inferior =        0;
-  eb_ops.to_terminal_ours_for_output =         0;
-  eb_ops.to_terminal_ours  =   0;
-  eb_ops.to_terminal_info  =   0;      /* Terminal handling */
-  eb_ops.to_kill  =    eb_kill;
-  eb_ops.to_load  =    generic_load;   /* load */
-  eb_ops.to_lookup_symbol =    0; /* lookup_symbol */
-  eb_ops.to_create_inferior =  eb_create_inferior;
-  eb_ops.to_mourn_inferior =   eb_mourn_inferior;
-  eb_ops.to_can_run  =         0;      /* can_run */
-  eb_ops.to_notice_signals =           0; /* notice_signals */
-  eb_ops.to_thread_alive  =    0; /* thread-alive */
-  eb_ops.to_stop  =    0;                      /* to_stop */
-  eb_ops.to_stratum =  process_stratum;
-  eb_ops.DONT_USE =    0; /* next */
-  eb_ops.to_has_all_memory =   1;
-  eb_ops.to_has_memory =       1;
-  eb_ops.to_has_stack =        1;
-  eb_ops.to_has_registers =    1;
-  eb_ops.to_has_execution =    1;      /* all mem, mem, stack, regs, exec */
-  eb_ops.to_sections =         0; /* sections */
-  eb_ops.to_sections_end =     0; /* sections end */
-  eb_ops.to_magic =    OPS_MAGIC;              /* Always the last thing */
+    eb_ops.to_open = eb_open;
+  eb_ops.to_close = eb_close;
+  eb_ops.to_attach = 0;
+  eb_ops.to_post_attach = NULL;
+  eb_ops.to_require_attach = NULL;
+  eb_ops.to_detach = eb_detach;
+  eb_ops.to_require_detach = NULL;
+  eb_ops.to_resume = eb_resume;
+  eb_ops.to_wait = eb_wait;
+  eb_ops.to_post_wait = NULL;
+  eb_ops.to_fetch_registers = eb_fetch_register;
+  eb_ops.to_store_registers = eb_store_register;
+  eb_ops.to_prepare_to_store = eb_prepare_to_store;
+  eb_ops.to_xfer_memory = eb_xfer_inferior_memory;
+  eb_ops.to_files_info = eb_files_info;
+  eb_ops.to_insert_breakpoint = 0;
+  eb_ops.to_remove_breakpoint = 0;     /* Breakpoints */
+  eb_ops.to_terminal_init = 0;
+  eb_ops.to_terminal_inferior = 0;
+  eb_ops.to_terminal_ours_for_output = 0;
+  eb_ops.to_terminal_ours = 0;
+  eb_ops.to_terminal_info = 0; /* Terminal handling */
+  eb_ops.to_kill = eb_kill;
+  eb_ops.to_load = generic_load;       /* load */
+  eb_ops.to_lookup_symbol = 0; /* lookup_symbol */
+  eb_ops.to_create_inferior = eb_create_inferior;
+  eb_ops.to_post_startup_inferior = NULL;
+  eb_ops.to_acknowledge_created_inferior = NULL;
+  eb_ops.to_clone_and_follow_inferior = NULL;
+  eb_ops.to_post_follow_inferior_by_clone = NULL;
+  eb_ops.to_insert_fork_catchpoint = NULL;
+  eb_ops.to_remove_fork_catchpoint = NULL;
+  eb_ops.to_insert_vfork_catchpoint = NULL;
+  eb_ops.to_remove_vfork_catchpoint = NULL;
+  eb_ops.to_has_forked = NULL;
+  eb_ops.to_has_vforked = NULL;
+  eb_ops.to_can_follow_vfork_prior_to_exec = NULL;
+  eb_ops.to_post_follow_vfork = NULL;
+  eb_ops.to_insert_exec_catchpoint = NULL;
+  eb_ops.to_remove_exec_catchpoint = NULL;
+  eb_ops.to_has_execd = NULL;
+  eb_ops.to_reported_exec_events_per_exec_call = NULL;
+  eb_ops.to_has_exited = NULL;
+  eb_ops.to_mourn_inferior = eb_mourn_inferior;
+  eb_ops.to_can_run = 0;       /* can_run */
+  eb_ops.to_notice_signals = 0;        /* notice_signals */
+  eb_ops.to_thread_alive = 0;  /* thread-alive */
+  eb_ops.to_stop = 0;          /* to_stop */
+  eb_ops.to_pid_to_exec_file = NULL;
+  eb_ops.to_stratum = process_stratum;
+  eb_ops.DONT_USE = 0;         /* next */
+  eb_ops.to_has_all_memory = 1;
+  eb_ops.to_has_memory = 1;
+  eb_ops.to_has_stack = 1;
+  eb_ops.to_has_registers = 1;
+  eb_ops.to_has_execution = 1; /* all mem, mem, stack, regs, exec */
+  eb_ops.to_sections = 0;      /* sections */
+  eb_ops.to_sections_end = 0;  /* sections end */
+  eb_ops.to_magic = OPS_MAGIC; /* Always the last thing */
 };
 
 void
-_initialize_remote_eb ()
+_initialize_remote_eb (void)
 {
-  init_eb_ops() ;
+  init_eb_ops ();
   add_target (&eb_ops);
 }
This page took 0.072892 seconds and 4 git commands to generate.