summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAndreas Schneider <asn@cryptomilk.org>2013-02-11 10:52:39 +0100
committerAndreas Schneider <asn@cryptomilk.org>2013-02-11 10:52:39 +0100
commita5875a035f03432becd9ace64ab2c2be94c4a8d7 (patch)
treebfd0e5340a34ac2c3b99cc69a7694947138984c9 /src
parentad5022072e762ac44d0fe19b872fe30808a32950 (diff)
downloadsocket_wrapper-a5875a035f03432becd9ace64ab2c2be94c4a8d7.tar.gz
socket_wrapper-a5875a035f03432becd9ace64ab2c2be94c4a8d7.tar.xz
socket_wrapper-a5875a035f03432becd9ace64ab2c2be94c4a8d7.zip
Add setsockopt() wrapper.
Diffstat (limited to 'src')
-rw-r--r--src/socket_wrapper.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/src/socket_wrapper.c b/src/socket_wrapper.c
index 75f9d34..95330d1 100644
--- a/src/socket_wrapper.c
+++ b/src/socket_wrapper.c
@@ -270,6 +270,24 @@ static int real_listen(int sockfd, int backlog)
return libc_listen(sockfd, backlog);
}
+static int (*libc_setsockopt)(int sockfd,
+ int level,
+ int optname,
+ const void *optval,
+ socklen_t optlen);
+
+static int real_setsockopt(int sockfd,
+ int level,
+ int optname,
+ const void *optval,
+ socklen_t optlen)
+{
+ if (libc_setsockopt == NULL) {
+ *(void **)(&libc_setsockopt) = libc_dlsym("setsockopt");
+ }
+
+ return libc_setsockopt(sockfd, level, optname, optval, optlen);
+}
static int (*libc_socket)(int domain, int type, int protocol);
@@ -2031,8 +2049,8 @@ int getsockopt(int s, int level, int optname, void *optval, socklen_t *optlen)
return -1;
}
-#if 0
-_PUBLIC_ int swrap_setsockopt(int s, int level, int optname, const void *optval, socklen_t optlen)
+int setsockopt(int s, int level, int optname,
+ const void *optval, socklen_t optlen)
{
struct socket_info *si = find_socket_info(s);
@@ -2057,6 +2075,7 @@ _PUBLIC_ int swrap_setsockopt(int s, int level, int optname, const void *o
}
}
+#if 0
_PUBLIC_ int swrap_ioctl(int s, int r, void *p)
{
int ret;