diff options
| author | Andreas Schneider <asn@samba.org> | 2014-01-28 13:10:01 +0100 |
|---|---|---|
| committer | Andreas Schneider <asn@samba.org> | 2014-01-28 13:25:14 +0100 |
| commit | 0627527da3abbafdb6f171dbdbc3b719a96a2b62 (patch) | |
| tree | 4c8860f8fb6662798b8f59936de5c8139367d327 /src | |
| parent | 5acfcfea50ce2dd1b0388c33c849ce19007cf77b (diff) | |
| download | socket_wrapper-0627527da3abbafdb6f171dbdbc3b719a96a2b62.tar.gz socket_wrapper-0627527da3abbafdb6f171dbdbc3b719a96a2b62.tar.xz socket_wrapper-0627527da3abbafdb6f171dbdbc3b719a96a2b62.zip | |
src: Check for stale fds in swrap_accept().
Reviewed-by: Stefan Metzmacher <metze@samba.org>
Diffstat (limited to 'src')
| -rw-r--r-- | src/socket_wrapper.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/socket_wrapper.c b/src/socket_wrapper.c index d7525f8..d352291 100644 --- a/src/socket_wrapper.c +++ b/src/socket_wrapper.c @@ -2109,6 +2109,10 @@ static int swrap_accept(int s, struct sockaddr *addr, socklen_t *addrlen) ret = libc_accept(s, (struct sockaddr *)(void *)&un_addr, &un_addrlen); if (ret == -1) { + if (errno == ENOTSOCK) { + /* Remove stale fds */ + swrap_remove_stale(s); + } free(my_addr); return ret; } |
