From 73b1002eda17451db1f58431b42c25203f1d3097 Mon Sep 17 00:00:00 2001 From: Khem Raj Date: Sun, 9 Sep 2018 17:38:10 -0700 Subject: [PATCH] connect has a different signature on musl On linux when not using glibc and using musl for C library, connect API has a different signature, this patch fixes this so it can compile on musl, the functionality should remain same as it is immediately typcasted to struct sockaddr_in* type inside the function before use Upstream-Status: Pending Signed-off-by: Khem Raj --- validate/plugins/fault_injection/socket_interposer.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/validate/plugins/fault_injection/socket_interposer.c b/validate/plugins/fault_injection/socket_interposer.c index 53c1ebb..ad7adf8 100644 --- a/validate/plugins/fault_injection/socket_interposer.c +++ b/validate/plugins/fault_injection/socket_interposer.c @@ -100,10 +100,15 @@ socket_interposer_set_callback (struct sockaddr_in *addrin, } int -connect (int socket, const struct sockaddr_in *addrin, socklen_t address_len) +#if defined(__linux__) && !defined(__GLIBC__) +connect (int socket, const struct sockaddr *addr, socklen_t address_len) +#else +connect (int socket, const struct sockaddr_in *addr, socklen_t address_len) +#endif { size_t i; int override_errno = 0; + struct sockaddr_in* addrin = (struct sockaddr_in*)addr; typedef ssize_t (*real_connect_fn) (int, const struct sockaddr_in *, socklen_t); static real_connect_fn real_connect = 0;