diff options
author | Andreas Schneider <asn@cryptomilk.org> | 2013-12-05 12:14:32 +0100 |
---|---|---|
committer | Andreas Schneider <asn@cryptomilk.org> | 2013-12-05 13:43:45 +0100 |
commit | e0767c253ec920044c93b8c14cdf64e953fc8e49 (patch) | |
tree | 6bc90c8e125cef1db4dd97d7bee40ce5ef66d853 | |
parent | 8745a7f2752a747655499ecc290c91390e4caaa7 (diff) | |
download | socket_wrapper-e0767c253ec920044c93b8c14cdf64e953fc8e49.tar.gz socket_wrapper-e0767c253ec920044c93b8c14cdf64e953fc8e49.tar.xz socket_wrapper-e0767c253ec920044c93b8c14cdf64e953fc8e49.zip |
swrap: Use swrap structure for getsockopt.
-rw-r--r-- | src/socket_wrapper.c | 31 |
1 files changed, 10 insertions, 21 deletions
diff --git a/src/socket_wrapper.c b/src/socket_wrapper.c index e6962d8..1bb23ef 100644 --- a/src/socket_wrapper.c +++ b/src/socket_wrapper.c @@ -541,25 +541,6 @@ static void *libc_dlsym(const char *name) return func; } -static int (*libc_getsockopt)(int sockfd, - int level, - int optname, - void *optval, - socklen_t *optlen); - -static int real_getsockopt(int sockfd, - int level, - int optname, - void *optval, - socklen_t *optlen) -{ - if (libc_getsockopt == NULL) { - *(void **)(&libc_getsockopt) = libc_dlsym("getsockopt"); - } - - return libc_getsockopt(sockfd, level, optname, optval, optlen); -} - static int (*libc_ioctl)(int d, unsigned long int request, ...); static int real_vioctl(int d, unsigned long int request, va_list ap) { @@ -2525,11 +2506,19 @@ static int swrap_getsockopt(int s, int level, int optname, struct socket_info *si = find_socket_info(s); if (!si) { - return real_getsockopt(s, level, optname, optval, optlen); + return swrap.fns.libc_getsockopt(s, + level, + optname, + optval, + optlen); } if (level == SOL_SOCKET) { - return real_getsockopt(s, level, optname, optval, optlen); + return swrap.fns.libc_getsockopt(s, + level, + optname, + optval, + optlen); } errno = ENOPROTOOPT; |