diff options
author | Michael Adam <obnox@samba.org> | 2014-05-30 14:20:40 +0200 |
---|---|---|
committer | Michael Adam <obnox@samba.org> | 2014-06-01 10:03:24 +0200 |
commit | f38c0b43d5620ab6457bf8a4fbdaf3a7bf90627c (patch) | |
tree | aa8110ee23ceb47544a7246f2b9d3033bb9e8b4f | |
parent | da04f94dd0575245424cf7853d0a9fc5b7caacee (diff) | |
download | socket_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.c | 7 |
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); |