From 85851d312771f043263257bcf972bd11cadec50a Mon Sep 17 00:00:00 2001 From: Ghislain Putois Date: Mon, 15 Aug 2011 19:39:21 +0200 Subject: Preliminary Android support Some small changes to prepare a cross-compilation for the Android platform Signed-off-by: Ghislain Putois Signed-off-by: Martin Sustrik --- AUTHORS | 1 + src/ip.cpp | 7 ++++--- src/thread.cpp | 6 +++--- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/AUTHORS b/AUTHORS index e9c6a74..589a160 100644 --- a/AUTHORS +++ b/AUTHORS @@ -27,6 +27,7 @@ Fabien Ninoles Frank Denis George Neill Gerard Toonstra +Ghislain Putois Gonzalo Diethelm Guido Goldstein Ilja Golshtein diff --git a/src/ip.cpp b/src/ip.cpp index 4bacff3..953640d 100644 --- a/src/ip.cpp +++ b/src/ip.cpp @@ -106,7 +106,7 @@ static int resolve_nic_name (struct sockaddr* addr_, char const *interface_, return 0; } -#elif defined ZMQ_HAVE_AIX || ZMQ_HAVE_HPUX +#elif defined ZMQ_HAVE_AIX || ZMQ_HAVE_HPUX || ZMQ_HAVE_ANDROID #include #include @@ -139,8 +139,9 @@ static int resolve_nic_name (struct sockaddr* addr_, char const *interface_, return -1; } - struct sockaddr *sa = (struct sockaddr *) &ifr.ifr_addr; - *addr_ = ((sockaddr_in*)sa)->sin_addr; + memcpy (&((sockaddr_in*) addr_)->sin_addr, + &((sockaddr_in*) &ifr.ifr_addr)->sin_addr, sizeof (in_addr)); + return 0; } diff --git a/src/thread.cpp b/src/thread.cpp index 06a47fc..d1c6729 100644 --- a/src/thread.cpp +++ b/src/thread.cpp @@ -59,15 +59,15 @@ extern "C" { static void *thread_routine (void *arg_) { - #if !defined ZMQ_HAVE_OPENVMS - // Following code will guarantee more predictable latecnies as it'll +#if !defined ZMQ_HAVE_OPENVMS && !defined ZMQ_HAVE_ANDROID + // Following code will guarantee more predictable latencies as it'll // disallow any signal handling in the I/O thread. sigset_t signal_set; int rc = sigfillset (&signal_set); errno_assert (rc == 0); rc = pthread_sigmask (SIG_BLOCK, &signal_set, NULL); posix_assert (rc); - #endif +#endif zmq::thread_t *self = (zmq::thread_t*) arg_; self->tfn (self->arg); -- cgit v1.2.3