2012-06-13 Pedro Alves <palves@redhat.com>
Partial revert of previous change. * serial.c (scb_base): New global. (serial_for_fd): New. (serial_open, serial_fdopen_ops): Link new serial in open serials chain. (do_serial_close): Unlink serial from the open serials chain.
This commit is contained in:
parent
b0f0569128
commit
5eb3b0622d
3 changed files with 46 additions and 0 deletions
|
@ -1,3 +1,13 @@
|
|||
2012-06-13 Pedro Alves <palves@redhat.com>
|
||||
|
||||
Partial revert of previous change.
|
||||
|
||||
* serial.c (scb_base): New global.
|
||||
(serial_for_fd): New.
|
||||
(serial_open, serial_fdopen_ops): Link new serial in open serials
|
||||
chain.
|
||||
(do_serial_close): Unlink serial from the open serials chain.
|
||||
|
||||
2012-06-12 Pedro Alves <palves@redhat.com>
|
||||
|
||||
* infrun.c (infrun_thread_stop_requested_callback): Don't switch
|
||||
|
|
35
gdb/serial.c
35
gdb/serial.c
|
@ -33,6 +33,10 @@ static int global_serial_debug_p;
|
|||
|
||||
static struct serial_ops *serial_ops_list = NULL;
|
||||
|
||||
/* Pointer to list of scb's. */
|
||||
|
||||
static struct serial *scb_base;
|
||||
|
||||
/* Non-NULL gives filename which contains a recording of the remote session,
|
||||
suitable for playback by gdbserver. */
|
||||
|
||||
|
@ -157,6 +161,21 @@ serial_add_interface (struct serial_ops *optable)
|
|||
serial_ops_list = optable;
|
||||
}
|
||||
|
||||
/* Return the open serial device for FD, if found, or NULL if FD is
|
||||
not already opened. */
|
||||
|
||||
struct serial *
|
||||
serial_for_fd (int fd)
|
||||
{
|
||||
struct serial *scb;
|
||||
|
||||
for (scb = scb_base; scb; scb = scb->next)
|
||||
if (scb->fd == fd)
|
||||
return scb;
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Open up a device or a network socket, depending upon the syntax of NAME. */
|
||||
|
||||
struct serial *
|
||||
|
@ -206,10 +225,12 @@ serial_open (const char *name)
|
|||
}
|
||||
|
||||
scb->name = xstrdup (name);
|
||||
scb->next = scb_base;
|
||||
scb->debug_p = 0;
|
||||
scb->async_state = 0;
|
||||
scb->async_handler = NULL;
|
||||
scb->async_context = NULL;
|
||||
scb_base = scb;
|
||||
|
||||
if (serial_logfile != NULL)
|
||||
{
|
||||
|
@ -249,10 +270,12 @@ serial_fdopen_ops (const int fd, struct serial_ops *ops)
|
|||
scb->refcnt = 1;
|
||||
|
||||
scb->name = NULL;
|
||||
scb->next = scb_base;
|
||||
scb->debug_p = 0;
|
||||
scb->async_state = 0;
|
||||
scb->async_handler = NULL;
|
||||
scb->async_context = NULL;
|
||||
scb_base = scb;
|
||||
|
||||
if ((ops->fdopen) != NULL)
|
||||
(*ops->fdopen) (scb, fd);
|
||||
|
@ -296,6 +319,18 @@ do_serial_close (struct serial *scb, int really_close)
|
|||
/* For serial_is_open. */
|
||||
scb->bufp = NULL;
|
||||
|
||||
if (scb_base == scb)
|
||||
scb_base = scb_base->next;
|
||||
else
|
||||
for (tmp_scb = scb_base; tmp_scb; tmp_scb = tmp_scb->next)
|
||||
{
|
||||
if (tmp_scb->next != scb)
|
||||
continue;
|
||||
|
||||
tmp_scb->next = tmp_scb->next->next;
|
||||
break;
|
||||
}
|
||||
|
||||
serial_unref (scb);
|
||||
}
|
||||
|
||||
|
|
|
@ -249,6 +249,7 @@ struct serial
|
|||
still need to wait for this many
|
||||
more seconds. */
|
||||
char *name; /* The name of the device or host */
|
||||
struct serial *next; /* Pointer to the next `struct serial *' */
|
||||
int debug_p; /* Trace this serial devices operation. */
|
||||
int async_state; /* Async internal state. */
|
||||
void *async_context; /* Async event thread's context */
|
||||
|
|
Loading…
Reference in a new issue