Based on patch from Dmitry Potapov, bug#19225.

Add asserts inside bind, connect and sendto to check input parameters. Remove excessive set_errno() calls after get_socket(), because errno is set inside of get_socket(). Move last sock_set_errno() inside lwip_close.
This commit is contained in:
fbernon 2007-03-11 16:53:37 +00:00
parent 5c65d4733b
commit 9b143dd5dc
2 changed files with 27 additions and 40 deletions

View File

@ -60,6 +60,12 @@ HISTORY
++ Bug fixes: ++ Bug fixes:
2007-03-11 Frédéric Bernon (based on patch from Dmitry Potapov)
* sockets.c: Add asserts inside bind, connect and sendto to check input
parameters. Remove excessive set_errno() calls after get_socket(), because
errno is set inside of get_socket(). Move last sock_set_errno() inside
lwip_close.
2007-03-09 Simon Goldschmidt 2007-03-09 Simon Goldschmidt
* memp.c: Fixed bug #11400: New etharp queueing introduced bug: memp_memory * memp.c: Fixed bug #11400: New etharp queueing introduced bug: memp_memory
was allocated too small. was allocated too small.

View File

@ -176,10 +176,8 @@ lwip_accept(int s, struct sockaddr *addr, socklen_t *addrlen)
LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_accept(%d)...\n", s)); LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_accept(%d)...\n", s));
sock = get_socket(s); sock = get_socket(s);
if (!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
newconn = netconn_accept(sock->conn); newconn = netconn_accept(sock->conn);
@ -228,10 +226,10 @@ lwip_bind(int s, struct sockaddr *name, socklen_t namelen)
err_t err; err_t err;
sock = get_socket(s); sock = get_socket(s);
if (!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
LWIP_ASSERT("lwip_bind: invalid address", (namelen == sizeof(struct sockaddr_in)) && ((((struct sockaddr_in *)name)->sin_family) == AF_INET));
local_addr.addr = ((struct sockaddr_in *)name)->sin_addr.s_addr; local_addr.addr = ((struct sockaddr_in *)name)->sin_addr.s_addr;
local_port = ((struct sockaddr_in *)name)->sin_port; local_port = ((struct sockaddr_in *)name)->sin_port;
@ -266,7 +264,6 @@ lwip_close(int s)
sock = get_socket(s); sock = get_socket(s);
if (!sock) { if (!sock) {
sys_sem_signal(socksem); sys_sem_signal(socksem);
set_errno(EBADF);
return -1; return -1;
} }
@ -277,8 +274,8 @@ lwip_close(int s)
sock->lastdata = NULL; sock->lastdata = NULL;
sock->lastoffset = 0; sock->lastoffset = 0;
sock->conn = NULL; sock->conn = NULL;
sys_sem_signal(socksem);
sock_set_errno(sock, 0); sock_set_errno(sock, 0);
sys_sem_signal(socksem);
return 0; return 0;
} }
@ -289,10 +286,10 @@ lwip_connect(int s, struct sockaddr *name, socklen_t namelen)
err_t err; err_t err;
sock = get_socket(s); sock = get_socket(s);
if (!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
LWIP_ASSERT("lwip_connect: invalid address", (namelen == sizeof(struct sockaddr_in)) && ((((struct sockaddr_in *)name)->sin_family) == AF_INET));
if (((struct sockaddr_in *)name)->sin_family == AF_UNSPEC) { if (((struct sockaddr_in *)name)->sin_family == AF_UNSPEC) {
LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_connect(%d, AF_UNSPEC)\n", s)); LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_connect(%d, AF_UNSPEC)\n", s));
@ -330,10 +327,8 @@ lwip_listen(int s, int backlog)
LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_listen(%d, backlog=%d)\n", s, backlog)); LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_listen(%d, backlog=%d)\n", s, backlog));
sock = get_socket(s); sock = get_socket(s);
if (!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
err = netconn_listen(sock->conn); err = netconn_listen(sock->conn);
@ -360,10 +355,8 @@ lwip_recvfrom(int s, void *mem, int len, unsigned int flags,
LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_recvfrom(%d, %p, %d, 0x%x, ..)\n", s, mem, len, flags)); LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_recvfrom(%d, %p, %d, 0x%x, ..)\n", s, mem, len, flags));
sock = get_socket(s); sock = get_socket(s);
if (!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
/* Check if there is data left from the last recv operation. */ /* Check if there is data left from the last recv operation. */
if (sock->lastdata) { if (sock->lastdata) {
@ -475,10 +468,8 @@ lwip_send(int s, void *data, int size, unsigned int flags)
LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_send(%d, data=%p, size=%d, flags=0x%x)\n", s, data, size, flags)); LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_send(%d, data=%p, size=%d, flags=0x%x)\n", s, data, size, flags));
sock = get_socket(s); sock = get_socket(s);
if (!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
switch (netconn_type(sock->conn)) { switch (netconn_type(sock->conn)) {
case NETCONN_RAW: case NETCONN_RAW:
@ -532,10 +523,10 @@ lwip_sendto(int s, void *data, int size, unsigned int flags,
int err,connected; int err,connected;
sock = get_socket(s); sock = get_socket(s);
if (!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
LWIP_ASSERT("lwip_sendto: invalid address", (tolen == sizeof(struct sockaddr_in)) && ((((struct sockaddr_in *)to)->sin_family) == AF_INET));
/* get the peer if currently connected */ /* get the peer if currently connected */
connected = (netconn_peer(sock->conn, &addr, &port) == ERR_OK); connected = (netconn_peer(sock->conn, &addr, &port) == ERR_OK);
@ -907,10 +898,8 @@ int lwip_getpeername (int s, struct sockaddr *name, socklen_t *namelen)
struct ip_addr naddr; struct ip_addr naddr;
sock = get_socket(s); sock = get_socket(s);
if (!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
memset(&sin, 0, sizeof(sin)); memset(&sin, 0, sizeof(sin));
sin.sin_len = sizeof(sin); sin.sin_len = sizeof(sin);
@ -941,10 +930,8 @@ int lwip_getsockname (int s, struct sockaddr *name, socklen_t *namelen)
struct ip_addr *naddr; struct ip_addr *naddr;
sock = get_socket(s); sock = get_socket(s);
if (!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
memset(&sin, 0, sizeof(sin)); memset(&sin, 0, sizeof(sin));
sin.sin_len = sizeof(sin); sin.sin_len = sizeof(sin);
@ -973,10 +960,8 @@ int lwip_getsockopt (int s, int level, int optname, void *optval, socklen_t *opt
int err = 0; int err = 0;
struct lwip_socket *sock = get_socket(s); struct lwip_socket *sock = get_socket(s);
if(!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
if( NULL == optval || NULL == optlen ) { if( NULL == optval || NULL == optlen ) {
sock_set_errno( sock, EFAULT ); sock_set_errno( sock, EFAULT );
@ -1195,10 +1180,8 @@ int lwip_setsockopt (int s, int level, int optname, const void *optval, socklen_
struct lwip_socket *sock = get_socket(s); struct lwip_socket *sock = get_socket(s);
int err = 0; int err = 0;
if(!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
if( NULL == optval ) { if( NULL == optval ) {
sock_set_errno( sock, EFAULT ); sock_set_errno( sock, EFAULT );
@ -1391,10 +1374,8 @@ int lwip_ioctl(int s, long cmd, void *argp)
{ {
struct lwip_socket *sock = get_socket(s); struct lwip_socket *sock = get_socket(s);
if(!sock) { if (!sock)
set_errno(EBADF);
return -1; return -1;
}
switch (cmd) { switch (cmd) {
case FIONREAD: case FIONREAD: