diff options
author | Andreas Schneider <asn@cryptomilk.org> | 2013-12-09 19:36:02 +0100 |
---|---|---|
committer | Andreas Schneider <asn@cryptomilk.org> | 2013-12-09 19:36:02 +0100 |
commit | 7af4d587f80f4f981fdd45404a7e1ac725647c75 (patch) | |
tree | 4fe5797506c6b89147e5cf1888b33bbb9f4ade70 | |
parent | 9dd5276ce25f10278aca8342adfc5bcf332cbeb7 (diff) | |
download | socket_wrapper-7af4d587f80f4f981fdd45404a7e1ac725647c75.tar.gz socket_wrapper-7af4d587f80f4f981fdd45404a7e1ac725647c75.tar.xz socket_wrapper-7af4d587f80f4f981fdd45404a7e1ac725647c75.zip |
swrap: Add libc_getsockopt().
-rw-r--r-- | src/socket_wrapper.c | 31 |
1 files changed, 21 insertions, 10 deletions
diff --git a/src/socket_wrapper.c b/src/socket_wrapper.c index ca07550..b32af81 100644 --- a/src/socket_wrapper.c +++ b/src/socket_wrapper.c @@ -648,6 +648,17 @@ static int libc_getsockname(int sockfd, return swrap.fns.libc_getsockname(sockfd, addr, addrlen); } +static int libc_getsockopt(int sockfd, + int level, + int optname, + void *optval, + socklen_t *optlen) +{ + swrap_load_lib_function(SWRAP_LIBSOCKET, getsockopt); + + return swrap.fns.libc_getsockopt(sockfd, level, optname, optval, optlen); +} + static int libc_vioctl(int d, unsigned long int request, va_list ap) { long int args[4]; @@ -2482,19 +2493,19 @@ static int swrap_getsockopt(int s, int level, int optname, struct socket_info *si = find_socket_info(s); if (!si) { - return swrap.fns.libc_getsockopt(s, - level, - optname, - optval, - optlen); + return libc_getsockopt(s, + level, + optname, + optval, + optlen); } if (level == SOL_SOCKET) { - return swrap.fns.libc_getsockopt(s, - level, - optname, - optval, - optlen); + return libc_getsockopt(s, + level, + optname, + optval, + optlen); } errno = ENOPROTOOPT; |