summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAndreas Schneider <asn@samba.org>2014-01-28 11:30:20 +0100
committerAndreas Schneider <asn@samba.org>2014-01-28 13:24:06 +0100
commit3ab00f5deaefa2dbdac9ba71841e178a78988dd2 (patch)
tree2a3a854e2d03034c9a487cb8b089c2f9be08ccf1 /src
parentde94be7e4b83283f3b46320706fef19b8203b52c (diff)
downloadsocket_wrapper-3ab00f5deaefa2dbdac9ba71841e178a78988dd2.tar.gz
socket_wrapper-3ab00f5deaefa2dbdac9ba71841e178a78988dd2.tar.xz
socket_wrapper-3ab00f5deaefa2dbdac9ba71841e178a78988dd2.zip
src: Handle stale fds in swrap_sendmsg_after().
Reviewed-by: Stefan Metzmacher <metze@samba.org>
Diffstat (limited to 'src')
-rw-r--r--src/socket_wrapper.c20
1 files changed, 13 insertions, 7 deletions
diff --git a/src/socket_wrapper.c b/src/socket_wrapper.c
index 0bfa838..c238559 100644
--- a/src/socket_wrapper.c
+++ b/src/socket_wrapper.c
@@ -2814,7 +2814,8 @@ static ssize_t swrap_sendmsg_before(int fd,
return 0;
}
-static void swrap_sendmsg_after(struct socket_info *si,
+static void swrap_sendmsg_after(int fd,
+ struct socket_info *si,
struct msghdr *msg,
const struct sockaddr *to,
ssize_t ret)
@@ -2827,8 +2828,13 @@ static void swrap_sendmsg_after(struct socket_info *si,
size_t remain;
/* to give better errors */
- if (ret == -1 && saved_errno == ENOENT) {
- saved_errno = EHOSTUNREACH;
+ if (ret == -1) {
+ if (saved_errno == ENOENT) {
+ saved_errno = EHOSTUNREACH;
+ } else if (saved_errno == ENOTSOCK) {
+ /* If the fd is not a socket, remove it */
+ swrap_remove_stale(fd);
+ }
}
for (i = 0; i < (size_t)msg->msg_iovlen; i++) {
@@ -3229,7 +3235,7 @@ static ssize_t swrap_sendto(int s, const void *buf, size_t len, int flags,
(struct sockaddr *)msg.msg_name,
msg.msg_namelen);
- swrap_sendmsg_after(si, &msg, to, ret);
+ swrap_sendmsg_after(s, si, &msg, to, ret);
return ret;
}
@@ -3396,7 +3402,7 @@ static ssize_t swrap_send(int s, const void *buf, size_t len, int flags)
ret = libc_send(s, buf, len, flags);
- swrap_sendmsg_after(si, &msg, NULL, ret);
+ swrap_sendmsg_after(s, si, &msg, NULL, ret);
return ret;
}
@@ -3556,7 +3562,7 @@ static ssize_t swrap_sendmsg(int s, const struct msghdr *omsg, int flags)
ret = libc_sendmsg(s, &msg, flags);
- swrap_sendmsg_after(si, &msg, to, ret);
+ swrap_sendmsg_after(s, si, &msg, to, ret);
return ret;
}
@@ -3663,7 +3669,7 @@ static ssize_t swrap_writev(int s, const struct iovec *vector, int count)
ret = libc_writev(s, msg.msg_iov, msg.msg_iovlen);
- swrap_sendmsg_after(si, &msg, NULL, ret);
+ swrap_sendmsg_after(s, si, &msg, NULL, ret);
return ret;
}