make serial_ops const
authorTom Tromey <tromey@redhat.com>
Fri, 6 Dec 2013 17:58:50 +0000 (10:58 -0700)
committerTom Tromey <tromey@redhat.com>
Thu, 19 Dec 2013 15:50:46 +0000 (08:50 -0700)
I noticed that the serial_ops vtable is not const, but really it ought
to be.

This patch constifies it, removing the only mutable field in the
process.

Tested by rebuilding on x86-64 Fedora 18, both natively and using the
mingw cross tools.

2013-12-19  Tom Tromey  <tromey@redhat.com>

* serial.c (serial_ops_p): New typedef.
(serial_ops_list): Now a VEC.
(serial_interface_lookup): Return const.  Use VEC_iterate.
(serial_add_interface): Make parameter const.
(serial_open): Update.
(serial_fdopen_ops): Make 'ops' const.
(serial_pipe): Update.
* ser-tcp.c (_initialize_ser_tcp): Update.
* ser-pipe.c (_initialize_ser_pipe): Update.
* ser-unix.c (_initialize_ser_hardwire): Update.
* ser-mingw.c (_initialize_ser_windows): Update.
* ser-go32.c (dos_ops): Now const.  Update.
* serial.h (struct serial) <ops>: Now const.
(struct serial_ops) <next>: Remove.
(serial_add_interface): Make parameter const.

gdb/ChangeLog
gdb/ser-go32.c
gdb/ser-mingw.c
gdb/ser-pipe.c
gdb/ser-tcp.c
gdb/ser-unix.c
gdb/serial.c
gdb/serial.h

index 513c593c6d0bc98452149e498215a6da654e10c9..b11726dd5bab2712d7c6cdc40f3278ab32fe563c 100644 (file)
@@ -1,3 +1,21 @@
+2013-12-19  Tom Tromey  <tromey@redhat.com>
+
+       * serial.c (serial_ops_p): New typedef.
+       (serial_ops_list): Now a VEC.
+       (serial_interface_lookup): Return const.  Use VEC_iterate.
+       (serial_add_interface): Make parameter const.
+       (serial_open): Update.
+       (serial_fdopen_ops): Make 'ops' const.
+       (serial_pipe): Update.
+       * ser-tcp.c (_initialize_ser_tcp): Update.
+       * ser-pipe.c (_initialize_ser_pipe): Update.
+       * ser-unix.c (_initialize_ser_hardwire): Update.
+       * ser-mingw.c (_initialize_ser_windows): Update.
+       * ser-go32.c (dos_ops): Now const.  Update.
+       * serial.h (struct serial) <ops>: Now const.
+       (struct serial_ops) <next>: Remove.
+       (serial_add_interface): Make parameter const.
+
 2013-12-18  Yufeng Zhang  <yufeng.zhang@arm.com>
 
        * aarch64-linux-nat.c (aarch64_linux_set_debug_regs): Set
index 4268e2c150a859466f1f0b05dbef2e99e63c961f..6b87f86289b0e4350c897bcad0bb94f5341609e6 100644 (file)
@@ -848,10 +848,9 @@ dos_sendbreak (struct serial *scb)
 }
 
 
-static struct serial_ops dos_ops =
+static const struct serial_ops dos_ops =
 {
   "hardwire",
-  0,
   dos_open,
   dos_close,
   NULL,                                /* fdopen, not implemented */
index 0431ea95ecd3acc7177bb15fc161c9fe99804de4..eef40ce27122ecbeeb6c3b7be52686068e0613b3 100644 (file)
@@ -1232,7 +1232,6 @@ _initialize_ser_windows (void)
   ops = XMALLOC (struct serial_ops);
   memset (ops, 0, sizeof (struct serial_ops));
   ops->name = "hardwire";
-  ops->next = 0;
   ops->open = ser_windows_open;
   ops->close = ser_windows_close;
 
@@ -1268,7 +1267,6 @@ _initialize_ser_windows (void)
   memset (ops, 0, sizeof (struct serial_ops));
 
   ops->name = "terminal";
-  ops->next = 0;
 
   ops->close = ser_console_close;
   ops->get_tty_state = ser_console_get_tty_state;
@@ -1287,7 +1285,6 @@ _initialize_ser_windows (void)
   ops = XMALLOC (struct serial_ops);
   memset (ops, 0, sizeof (struct serial_ops));
   ops->name = "pipe";
-  ops->next = 0;
   ops->open = pipe_windows_open;
   ops->close = pipe_windows_close;
   ops->fdopen = pipe_windows_fdopen;
@@ -1323,7 +1320,6 @@ _initialize_ser_windows (void)
   ops = XMALLOC (struct serial_ops);
   memset (ops, 0, sizeof (struct serial_ops));
   ops->name = "tcp";
-  ops->next = 0;
   ops->open = net_windows_open;
   ops->close = net_windows_close;
   ops->readchar = ser_base_readchar;
index b4ab672664e5b8fd3afd7ab325732069565fecf4..70bec5ef53831121074020af5dcadefbe252babe 100644 (file)
@@ -213,7 +213,6 @@ _initialize_ser_pipe (void)
 
   memset (ops, 0, sizeof (struct serial_ops));
   ops->name = "pipe";
-  ops->next = 0;
   ops->open = pipe_open;
   ops->close = pipe_close;
   ops->readchar = ser_base_readchar;
index d8c1ed62881fde245a11e32f4864769d6a0e9d53..c5c5600b2f17cb8ba5ae8972df5619a079623531 100644 (file)
@@ -385,7 +385,6 @@ _initialize_ser_tcp (void)
   ops = XMALLOC (struct serial_ops);
   memset (ops, 0, sizeof (struct serial_ops));
   ops->name = "tcp";
-  ops->next = 0;
   ops->open = net_open;
   ops->close = net_close;
   ops->readchar = ser_base_readchar;
index 1f1372baad91ee1141eefbd175df78cd76e18459..d8e429414d901ebcbb757007da0e47799be4ab44 100644 (file)
@@ -912,7 +912,6 @@ _initialize_ser_hardwire (void)
 
   memset (ops, 0, sizeof (struct serial_ops));
   ops->name = "hardwire";
-  ops->next = 0;
   ops->open = hardwire_open;
   ops->close = hardwire_close;
   /* FIXME: Don't replace this with the equivalent ser_base*() until
index 78e9085df2f980a86dee428eab59d6322ea18872..0e0c4f7183313374a4c09eea1f717de14053c9e5 100644 (file)
@@ -30,9 +30,12 @@ extern void _initialize_serial (void);
 
 static unsigned int global_serial_debug_p;
 
-/* Linked list of serial I/O handlers.  */
+typedef const struct serial_ops *serial_ops_p;
+DEF_VEC_P (serial_ops_p);
 
-static struct serial_ops *serial_ops_list = NULL;
+/* Serial I/O handlers.  */
+
+VEC (serial_ops_p) *serial_ops_list = NULL;
 
 /* Pointer to list of scb's.  */
 
@@ -44,7 +47,7 @@ static struct serial *scb_base;
 static char *serial_logfile = NULL;
 static struct ui_file *serial_logfp = NULL;
 
-static struct serial_ops *serial_interface_lookup (const char *);
+static const struct serial_ops *serial_interface_lookup (const char *);
 static void serial_logchar (struct ui_file *stream,
                            int ch_type, int ch, int timeout);
 static const char logbase_hex[] = "hex";
@@ -143,12 +146,13 @@ serial_log_command (const char *cmd)
 }
 
 \f
-static struct serial_ops *
+static const struct serial_ops *
 serial_interface_lookup (const char *name)
 {
-  struct serial_ops *ops;
+  const struct serial_ops *ops;
+  int i;
 
-  for (ops = serial_ops_list; ops; ops = ops->next)
+  for (i = 0; VEC_iterate (serial_ops_p, serial_ops_list, i, ops); ++i)
     if (strcmp (name, ops->name) == 0)
       return ops;
 
@@ -156,10 +160,9 @@ serial_interface_lookup (const char *name)
 }
 
 void
-serial_add_interface (struct serial_ops *optable)
+serial_add_interface (const struct serial_ops *optable)
 {
-  optable->next = serial_ops_list;
-  serial_ops_list = optable;
+  VEC_safe_push (serial_ops_p, serial_ops_list, optable);
 }
 
 /* Return the open serial device for FD, if found, or NULL if FD is
@@ -183,7 +186,7 @@ struct serial *
 serial_open (const char *name)
 {
   struct serial *scb;
-  struct serial_ops *ops;
+  const struct serial_ops *ops;
   const char *open_name = name;
 
   if (strcmp (name, "pc") == 0)
@@ -246,7 +249,7 @@ serial_open (const char *name)
    interface ops OPS.  */
 
 static struct serial *
-serial_fdopen_ops (const int fd, struct serial_ops *ops)
+serial_fdopen_ops (const int fd, const struct serial_ops *ops)
 {
   struct serial *scb;
 
@@ -584,7 +587,7 @@ serial_done_wait_handle (struct serial *scb)
 int
 serial_pipe (struct serial *scbs[2])
 {
-  struct serial_ops *ops;
+  const struct serial_ops *ops;
   int fildes[2];
 
   ops = serial_interface_lookup ("pipe");
index 7a97e282a0bc2d363254296dbf39e7ef6da8d530..86c39608e48c729317495608803480ecfda2cc18 100644 (file)
@@ -228,7 +228,7 @@ struct serial
        If != -1, this descriptor should be non-blocking or
        ops->avail should be non-NULL.  */
     int error_fd;               
-    struct serial_ops *ops;    /* Function vector */
+    const struct serial_ops *ops; /* Function vector */
     void *state;                       /* Local context info for open FD */
     serial_ttystate ttystate;  /* Not used (yet) */
     int bufcnt;                        /* Amount of data remaining in receive
@@ -251,7 +251,6 @@ struct serial
 struct serial_ops
   {
     char *name;
-    struct serial_ops *next;
     int (*open) (struct serial *, const char *name);
     void (*close) (struct serial *);
     int (*fdopen) (struct serial *, int fd);
@@ -301,7 +300,7 @@ struct serial_ops
 
 /* Add a new serial interface to the interface list.  */
 
-extern void serial_add_interface (struct serial_ops * optable);
+extern void serial_add_interface (const struct serial_ops * optable);
 
 /* File in which to record the remote debugging session.  */