summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Adam <obnox@samba.org>2014-05-30 14:20:40 +0200
committerMichael Adam <obnox@samba.org>2014-06-01 10:03:24 +0200
commitf38c0b43d5620ab6457bf8a4fbdaf3a7bf90627c (patch)
treeaa8110ee23ceb47544a7246f2b9d3033bb9e8b4f
parentda04f94dd0575245424cf7853d0a9fc5b7caacee (diff)
downloadsocket_wrapper-f38c0b43d5620ab6457bf8a4fbdaf3a7bf90627c.tar.gz
socket_wrapper-f38c0b43d5620ab6457bf8a4fbdaf3a7bf90627c.tar.xz
socket_wrapper-f38c0b43d5620ab6457bf8a4fbdaf3a7bf90627c.zip
swrap: check whether an address:port is already in use in swrap_bind()
Signed-off-by: Michael Adam <obnox@samba.org> Reviewed-by: Andreas Schneider <asn@samba.org>
-rw-r--r--src/socket_wrapper.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/socket_wrapper.c b/src/socket_wrapper.c
index 477f115..f6adc95 100644
--- a/src/socket_wrapper.c
+++ b/src/socket_wrapper.c
@@ -2829,6 +2829,7 @@ static int swrap_bind(int s, const struct sockaddr *myaddr, socklen_t addrlen)
struct sockaddr_un un_addr;
struct socket_info *si = find_socket_info(s);
int bind_error = 0;
+ bool in_use;
if (!si) {
return libc_bind(s, myaddr, addrlen);
@@ -2884,6 +2885,12 @@ static int swrap_bind(int s, const struct sockaddr *myaddr, socklen_t addrlen)
return -1;
}
+ in_use = check_addr_port_in_use(myaddr, addrlen);
+ if (in_use) {
+ errno = EADDRINUSE;
+ return -1;
+ }
+
free(si->myname);
si->myname_len = addrlen;
si->myname = sockaddr_dup(myaddr, addrlen);