projects
/
deliverable
/
binutils-gdb.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
sim: fix func call style (space before paren)
[deliverable/binutils-gdb.git]
/
sim
/
common
/
dv-sockser.c
diff --git
a/sim/common/dv-sockser.c
b/sim/common/dv-sockser.c
index fb457d4f0b0dcd3286159c0ed4960c9101227b82..ae65585460aaff6c2fe5eccff0dd6a93feb6eeb8 100644
(file)
--- a/
sim/common/dv-sockser.c
+++ b/
sim/common/dv-sockser.c
@@
-1,20
+1,20
@@
/* Serial port emulation using sockets.
/* Serial port emulation using sockets.
- Copyright (C) 1998 Free Software Foundation, Inc.
+ Copyright (C) 1998, 2007, 2008, 2009, 2010, 2011
+ Free Software Foundation, Inc.
Contributed by Cygnus Solutions.
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
Contributed by Cygnus Solutions.
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, or (at your option)
-any later version.
+the Free Software Foundation; either version
3 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, see <http://www.gnu.org/licenses/>. */
/* FIXME: will obviously need to evolve.
- connectionless sockets might be more appropriate. */
/* FIXME: will obviously need to evolve.
- connectionless sockets might be more appropriate. */
@@
-56,6
+56,10
@@
with this program; if not, write to the Free Software Foundation, Inc.,
#include "dv-sockser.h"
\f
#include "dv-sockser.h"
\f
+#ifndef HAVE_SOCKLEN_T
+typedef int socklen_t;
+#endif
+
/* Get definitions for both O_NONBLOCK and O_NDELAY. */
#ifndef O_NDELAY
/* Get definitions for both O_NONBLOCK and O_NDELAY. */
#ifndef O_NDELAY
@@
-74,7
+78,6
@@
with this program; if not, write to the Free Software Foundation, Inc.,
#endif /* ! defined (FNBLOCK) */
#endif /* ! defined (O_NONBLOCK) */
\f
#endif /* ! defined (FNBLOCK) */
#endif /* ! defined (O_NONBLOCK) */
\f
-#define MIN(a,b) ((a) < (b) ? (a) : (b))
/* Compromise between eating cpu and properly busy-waiting.
One could have an option to set this but for now that seems
/* Compromise between eating cpu and properly busy-waiting.
One could have an option to set this but for now that seems
@@
-102,8
+105,8
@@
static const OPTION sockser_options[] =
{
{ { "sockser-addr", required_argument, NULL, OPTION_ADDR },
'\0', "SOCKET ADDRESS", "Set serial emulation socket address",
{
{ { "sockser-addr", required_argument, NULL, OPTION_ADDR },
'\0', "SOCKET ADDRESS", "Set serial emulation socket address",
- sockser_option_handler },
- { { NULL, no_argument, NULL, 0 }, '\0', NULL, NULL, NULL }
+ sockser_option_handler
, NULL
},
+ { { NULL, no_argument, NULL, 0 }, '\0', NULL, NULL, NULL
, NULL
}
};
static SIM_RC
};
static SIM_RC
@@
-148,7
+151,9
@@
dv_sockser_init (SIM_DESC sd)
sockser_addr);
return SIM_RC_FAIL;
}
sockser_addr);
return SIM_RC_FAIL;
}
- tmp = MIN (port_str - sockser_addr, (int) sizeof hostname - 1);
+ tmp = port_str - sockser_addr;
+ if (tmp >= sizeof hostname)
+ tmp = sizeof (hostname) - 1;
strncpy (hostname, sockser_addr, tmp);
hostname[tmp] = '\000';
port = atoi (port_str + 1);
strncpy (hostname, sockser_addr, tmp);
hostname[tmp] = '\000';
port = atoi (port_str + 1);
@@
-162,7
+167,7
@@
dv_sockser_init (SIM_DESC sd)
}
sockser_listen_fd = socket (PF_INET, SOCK_STREAM, 0);
}
sockser_listen_fd = socket (PF_INET, SOCK_STREAM, 0);
- if (sockser_listen_fd
< 0
)
+ if (sockser_listen_fd
== -1
)
{
sim_io_eprintf (sd, "sockser init: unable to get socket: %s\n",
strerror (errno));
{
sim_io_eprintf (sd, "sockser init: unable to get socket: %s\n",
strerror (errno));
@@
-170,12
+175,12
@@
dv_sockser_init (SIM_DESC sd)
}
sockaddr.sin_family = PF_INET;
}
sockaddr.sin_family = PF_INET;
- sockaddr.sin_port = htons(port);
+ sockaddr.sin_port = htons
(port);
memcpy (&sockaddr.sin_addr.s_addr, hostent->h_addr,
sizeof (struct in_addr));
tmp = 1;
memcpy (&sockaddr.sin_addr.s_addr, hostent->h_addr,
sizeof (struct in_addr));
tmp = 1;
- if (setsockopt (sockser_listen_fd, SOL_SOCKET, SO_REUSEADDR, (void*)& tmp, sizeof(tmp)) < 0)
+ if (setsockopt (sockser_listen_fd, SOL_SOCKET, SO_REUSEADDR, (void*)& tmp, sizeof
(tmp)) < 0)
{
sim_io_eprintf (sd, "sockser init: unable to set SO_REUSEADDR: %s\n",
strerror (errno));
{
sim_io_eprintf (sd, "sockser init: unable to set SO_REUSEADDR: %s\n",
strerror (errno));
@@
-243,7
+248,7
@@
connected_p (SIM_DESC sd)
struct timeval tv;
fd_set readfds;
struct sockaddr sockaddr;
struct timeval tv;
fd_set readfds;
struct sockaddr sockaddr;
-
in
t addrlen;
+
socklen_
t addrlen;
if (sockser_listen_fd == -1)
return 0;
if (sockser_listen_fd == -1)
return 0;
@@
-270,7
+275,7
@@
connected_p (SIM_DESC sd)
addrlen = sizeof (sockaddr);
sockser_fd = accept (sockser_listen_fd, &sockaddr, &addrlen);
addrlen = sizeof (sockaddr);
sockser_fd = accept (sockser_listen_fd, &sockaddr, &addrlen);
- if (sockser_fd
< 0
)
+ if (sockser_fd
== -1
)
return 0;
/* Set non-blocking i/o. */
return 0;
/* Set non-blocking i/o. */
@@
-294,7
+299,8
@@
dv_sockser_status (SIM_DESC sd)
fd_set readfds,writefds;
/* status to return if the socket isn't set up, or select fails */
fd_set readfds,writefds;
/* status to return if the socket isn't set up, or select fails */
- status = DV_SOCKSER_INPUT_EMPTY | DV_SOCKSER_OUTPUT_EMPTY;
+ status = DV_SOCKSER_INPUT_EMPTY | DV_SOCKSER_OUTPUT_EMPTY |
+ DV_SOCKSER_DISCONNECTED;
if (! connected_p (sd))
return status;
if (! connected_p (sd))
return status;
@@
-341,13
+347,14
@@
dv_sockser_status (SIM_DESC sd)
}
int
}
int
-dv_sockser_write (SIM_DESC sd, unsigned char c)
+dv_sockser_write_buffer (SIM_DESC sd, const unsigned char *buffer,
+ unsigned nr_bytes)
{
int n;
if (! connected_p (sd))
return -1;
{
int n;
if (! connected_p (sd))
return -1;
- n = write (sockser_fd,
&c, 1
);
+ n = write (sockser_fd,
buffer, nr_bytes
);
if (n == -1)
{
if (errno == EPIPE)
if (n == -1)
{
if (errno == EPIPE)
@@
-357,9
+364,15
@@
dv_sockser_write (SIM_DESC sd, unsigned char c)
}
return -1;
}
}
return -1;
}
- if (n !=
1
)
+ if (n !=
nr_bytes
)
return -1;
return -1;
- return 1;
+ return nr_bytes;
+}
+
+int
+dv_sockser_write (SIM_DESC sd, unsigned char c)
+{
+ return dv_sockser_write_buffer (sd, &c, 1);
}
int
}
int
This page took
0.025116 seconds
and
4
git commands to generate.