diff options
author | Daniel Jacobowitz <drow@false.org> | 2006-02-10 22:01:43 +0000 |
---|---|---|
committer | Daniel Jacobowitz <drow@false.org> | 2006-02-10 22:01:43 +0000 |
commit | 0ea3f30e219bd42259f09f68bcd605bf4ed4a1ea (patch) | |
tree | 07c791175cea3abee634fa9ccec99e18031ed5cd /gdb/ser-tcp.c | |
parent | 121ce6e53dd5751c6938ab86cbec2742702d06eb (diff) | |
download | gdb-0ea3f30e219bd42259f09f68bcd605bf4ed4a1ea.zip gdb-0ea3f30e219bd42259f09f68bcd605bf4ed4a1ea.tar.gz gdb-0ea3f30e219bd42259f09f68bcd605bf4ed4a1ea.tar.bz2 |
* NEWS: Mention native Windows support.
* Makefile.in (gdb_select_h, ser_tcp_h): New.
(ALLDEPFILES): Add ser-mingw.c.
(event-loop.o, inflow.o, mingw-hdep.o, posix-hdep.o, ser-base.o)
(ser-tcp.o, ser-unix.o): Update.
(ser-mingw.o): New rule.
* configure: Regenerated.
* configure.ac: Add ser-mingw.o for mingw32.
* ser-mingw.c: New file.
* event-loop.c: Include "gdb_select.h".
(gdb_select): Remove, moved to mingw-hdep.c and posix-hdep.c.
* ser-base.c: Include "gdb_select.h".
(ser_base_wait_for): Use gdb_select.
* serial.c (serial_for_fd): New function.
(serial_fdopen): Try "terminal" before "hardwire". Initialize
the allocated struct serial.
(serial_wait_handle): New function.
* serial.h (serial_for_fd, serial_wait_handle): New prototypes.
(struct serial_ops) [USE_WIN32API]: Add wait_handle.
* gdb_select.h: New file.
* ser-tcp.c: Include "ser-tcp.h". Remove unused "ser-unix.h" include.
(net_close, net_read_prim, net_write_prim): Make global.
(net_open): Likewise. Pass an exception set to select. Whitespace fix.
Document why we can not use gdb_select.
(_initialize_ser_tcp) [USE_WIN32API]: Do not register TCP support here.
* ser-tcp.h: New file.
* inflow.c (gdb_has_a_terminal): Don't initialize stdin_serial here.
(handle_sigio): Use gdb_select.
(initialize_stdin_serial): New function.
* terminal.h (initialize_stdin_serial): New prototype.
* top.c (gdb_init): Call initialize_stdin_serial.
* mingw-hdep.c (gdb_select): New function, moved from gdb_select in
event-loop.c. Add exception condition support. Use serial_for_fd
and serial_wait_handle. Fix timeout handling.
* posix-hdep.c: Include "gdb_select.h".
(gdb_select): New function.
* remote-st.c (connect_command): Use gdb_select.
* ser-unix.c: Include "gdb_select.h".
(hardwire_send_break, wait_for): Use gdb_select.
Diffstat (limited to 'gdb/ser-tcp.c')
-rw-r--r-- | gdb/ser-tcp.c | 41 |
1 files changed, 24 insertions, 17 deletions
diff --git a/gdb/ser-tcp.c b/gdb/ser-tcp.c index aed91c2..bd104aa 100644 --- a/gdb/ser-tcp.c +++ b/gdb/ser-tcp.c @@ -1,6 +1,6 @@ /* Serial interface for raw TCP connections on Un*x like systems. - Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2001, 2005 + Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2001, 2005, 2006 Free Software Foundation, Inc. This file is part of GDB. @@ -23,7 +23,7 @@ #include "defs.h" #include "serial.h" #include "ser-base.h" -#include "ser-unix.h" +#include "ser-tcp.h" #include <sys/types.h> @@ -56,8 +56,6 @@ typedef int socklen_t; #endif -static int net_open (struct serial *scb, const char *name); -static void net_close (struct serial *scb); void _initialize_ser_tcp (void); /* seconds to wait for connect */ @@ -67,7 +65,7 @@ void _initialize_ser_tcp (void); /* Open a tcp socket */ -static int +int net_open (struct serial *scb, const char *name) { char *port_str, hostname[100]; @@ -153,7 +151,7 @@ net_open (struct serial *scb, const char *name) { /* looks like we need to wait for the connect */ struct timeval t; - fd_set rset, wset; + fd_set rset, wset, eset; int polls = 0; FD_ZERO (&rset); @@ -174,10 +172,19 @@ net_open (struct serial *scb, const char *name) FD_SET (scb->fd, &rset); wset = rset; + eset = rset; t.tv_sec = 0; t.tv_usec = 1000000 / POLL_INTERVAL; - n = select (scb->fd + 1, &rset, &wset, NULL, &t); + /* POSIX systems return connection success or failure by signalling + wset. Windows systems return success in wset and failure in + eset. + + We must call select here, rather than gdb_select, because + the serial structure has not yet been initialized - the + MinGW select wrapper will not know that this FD refers + to a socket. */ + n = select (scb->fd + 1, &rset, &wset, &eset, &t); polls++; } while (n == 0 && polls <= TIMEOUT * POLL_INTERVAL); @@ -194,7 +201,7 @@ net_open (struct serial *scb, const char *name) { int res, err; socklen_t len; - len = sizeof(err); + len = sizeof (err); /* On Windows, the fourth parameter to getsockopt is a "char *"; on UNIX systems it is generally "void *". The cast to "void *" is OK everywhere, since in C "void *" can be implicitly @@ -230,7 +237,7 @@ net_open (struct serial *scb, const char *name) return 0; } -static void +void net_close (struct serial *scb) { if (scb->fd < 0) @@ -240,13 +247,13 @@ net_close (struct serial *scb) scb->fd = -1; } -static int +int net_read_prim (struct serial *scb, size_t count) { return recv (scb->fd, scb->buf, count, 0); } -static int +int net_write_prim (struct serial *scb, const void *buf, size_t count) { return send (scb->fd, buf, count, 0); @@ -255,13 +262,12 @@ net_write_prim (struct serial *scb, const void *buf, size_t count) void _initialize_ser_tcp (void) { - struct serial_ops *ops; #ifdef USE_WIN32API - WSADATA wsa_data; - if (WSAStartup (MAKEWORD (1, 0), &wsa_data) != 0) - /* WinSock is unavailable. */ - return; -#endif + /* Do nothing; the TCP serial operations will be initialized in + ser-mingw.c. */ + return; +#else + struct serial_ops *ops; ops = XMALLOC (struct serial_ops); memset (ops, 0, sizeof (struct serial_ops)); ops->name = "tcp"; @@ -285,4 +291,5 @@ _initialize_ser_tcp (void) ops->read_prim = net_read_prim; ops->write_prim = net_write_prim; serial_add_interface (ops); +#endif /* USE_WIN32API */ } |