mirror of
https://github.com/zeromq/libzmq.git
synced 2025-01-24 02:51:39 +01:00
bfbb4ff2e9
* Background thread scheduling - add ZMQ_THREAD_AFFINITY ctx option; set all thread scheduling options from the context of the secondary thread instead of using the main process thread context! - change ZMQ_THREAD_PRIORITY to support setting NICE of the background thread when using SCHED_OTHER
302 lines
6.5 KiB
CMake
302 lines
6.5 KiB
CMake
|
|
|
|
macro(zmq_check_sock_cloexec)
|
|
message(STATUS "Checking whether SOCK_CLOEXEC is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
int s = socket(PF_INET, SOCK_STREAM | SOCK_CLOEXEC, 0);
|
|
return(s == -1);
|
|
}
|
|
"
|
|
ZMQ_HAVE_SOCK_CLOEXEC)
|
|
endmacro()
|
|
|
|
macro(zmq_check_efd_cloexec)
|
|
message(STATUS "Checking whether EFD_CLOEXEC is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <sys/eventfd.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
int s = eventfd (0, EFD_CLOEXEC);
|
|
return(s == -1);
|
|
}
|
|
"
|
|
ZMQ_HAVE_EVENTFD_CLOEXEC)
|
|
endmacro()
|
|
|
|
macro(zmq_check_o_cloexec)
|
|
message(STATUS "Checking whether O_CLOEXEC is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <sys/types.h>
|
|
#include <sys/stat.h>
|
|
#include <fcntl.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
int s = open (\"/dev/null\", O_CLOEXEC | O_RDONLY);
|
|
return (s == -1);
|
|
}
|
|
"
|
|
ZMQ_HAVE_O_CLOEXEC)
|
|
endmacro()
|
|
|
|
macro(zmq_check_so_bindtodevice)
|
|
message(STATUS "Checking whether SO_BINDTODEVICE is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <sys/socket.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
/* Actually making the setsockopt() call requires CAP_NET_RAW */
|
|
#ifndef SO_BINDTODEVICE
|
|
return 1;
|
|
#else
|
|
return 0;
|
|
#endif
|
|
}
|
|
"
|
|
ZMQ_HAVE_SO_BINDTODEVICE)
|
|
endmacro()
|
|
|
|
# TCP keep-alives Checks.
|
|
|
|
macro(zmq_check_so_keepalive)
|
|
message(STATUS "Checking whether SO_KEEPALIVE is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
int s, rc, opt = 1;
|
|
return(
|
|
((s = socket(PF_INET, SOCK_STREAM, 0)) == -1) ||
|
|
((rc = setsockopt(s, SOL_SOCKET, SO_KEEPALIVE,(char*) &opt, sizeof(int))) == -1)
|
|
);
|
|
}
|
|
"
|
|
ZMQ_HAVE_SO_KEEPALIVE)
|
|
endmacro()
|
|
|
|
macro(zmq_check_tcp_keepcnt)
|
|
message(STATUS "Checking whether TCP_KEEPCNT is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#include <netinet/tcp.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
int s, rc, opt = 1;
|
|
return(
|
|
((s = socket(PF_INET, SOCK_STREAM, 0)) == -1) ||
|
|
((rc = setsockopt(s, SOL_SOCKET, SO_KEEPALIVE,(char*) &opt, sizeof(int))) == -1) ||
|
|
((rc = setsockopt(s, IPPROTO_TCP, TCP_KEEPCNT,(char*) &opt, sizeof(int))) == -1)
|
|
);
|
|
}
|
|
"
|
|
ZMQ_HAVE_TCP_KEEPCNT)
|
|
endmacro()
|
|
|
|
macro(zmq_check_tcp_keepidle)
|
|
message(STATUS "Checking whether TCP_KEEPIDLE is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#include <netinet/tcp.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
int s, rc, opt = 1;
|
|
return(
|
|
((s = socket(PF_INET, SOCK_STREAM, 0)) == -1) ||
|
|
((rc = setsockopt(s, SOL_SOCKET, SO_KEEPALIVE,(char*) &opt, sizeof(int))) == -1) ||
|
|
((rc = setsockopt(s, IPPROTO_TCP, TCP_KEEPIDLE,(char*) &opt, sizeof(int))) == -1)
|
|
);
|
|
}
|
|
"
|
|
ZMQ_HAVE_TCP_KEEPIDLE)
|
|
endmacro()
|
|
|
|
|
|
macro(zmq_check_tcp_keepintvl)
|
|
message(STATUS "Checking whether TCP_KEEPINTVL is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#include <netinet/tcp.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
int s, rc, opt = 1;
|
|
return(
|
|
((s = socket(PF_INET, SOCK_STREAM, 0)) == -1) ||
|
|
((rc = setsockopt(s, SOL_SOCKET, SO_KEEPALIVE,(char*) &opt, sizeof(int))) == -1) ||
|
|
((rc = setsockopt(s, IPPROTO_TCP, TCP_KEEPINTVL,(char*) &opt, sizeof(int))) == -1)
|
|
);
|
|
}
|
|
|
|
"
|
|
ZMQ_HAVE_TCP_KEEPINTVL)
|
|
endmacro()
|
|
|
|
|
|
macro(zmq_check_tcp_keepalive)
|
|
message(STATUS "Checking whether TCP_KEEPALIVE is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#include <netinet/tcp.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
int s, rc, opt = 1;
|
|
return(
|
|
((s = socket(PF_INET, SOCK_STREAM, 0)) == -1) ||
|
|
((rc = setsockopt(s, SOL_SOCKET, SO_KEEPALIVE,(char*) &opt, sizeof(int))) == -1) ||
|
|
((rc = setsockopt(s, IPPROTO_TCP, TCP_KEEPALIVE,(char*) &opt, sizeof(int))) == -1)
|
|
);
|
|
}
|
|
"
|
|
ZMQ_HAVE_TCP_KEEPALIVE)
|
|
endmacro()
|
|
|
|
|
|
macro(zmq_check_tcp_tipc)
|
|
message(STATUS "Checking whether TIPC is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <fcntl.h>
|
|
#include <errno.h>
|
|
#include <sys/socket.h>
|
|
#include <linux/tipc.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
struct sockaddr_tipc topsrv;
|
|
int sd = socket(AF_TIPC, SOCK_SEQPACKET, 0);
|
|
if (sd == -EAFNOSUPPORT) {
|
|
return 1;
|
|
}
|
|
memset(&topsrv, 0, sizeof(topsrv));
|
|
topsrv.family = AF_TIPC;
|
|
topsrv.addrtype = TIPC_ADDR_NAME;
|
|
topsrv.addr.name.name.type = TIPC_TOP_SRV;
|
|
topsrv.addr.name.name.instance = TIPC_TOP_SRV;
|
|
fcntl(sd, F_SETFL, O_NONBLOCK);
|
|
if (connect(sd, (struct sockaddr *)&topsrv, sizeof(topsrv)) != 0) {
|
|
if (errno != EINPROGRESS)
|
|
return -1;
|
|
}
|
|
}
|
|
"
|
|
ZMQ_HAVE_TIPC)
|
|
endmacro()
|
|
|
|
|
|
macro(zmq_check_pthread_setname)
|
|
message(STATUS "Checking pthread_setname signature")
|
|
set(SAVE_CMAKE_REQUIRED_FLAGS ${CMAKE_REQUIRED_FLAGS})
|
|
set(CMAKE_REQUIRED_FLAGS "-D_GNU_SOURCE -Werror -pthread")
|
|
check_c_source_runs(
|
|
"
|
|
#include <pthread.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
pthread_setname_np (\"foo\");
|
|
return 0;
|
|
}
|
|
"
|
|
ZMQ_HAVE_PTHREAD_SETNAME_1)
|
|
check_c_source_runs(
|
|
"
|
|
#include <pthread.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
pthread_setname_np (pthread_self(), \"foo\");
|
|
return 0;
|
|
}
|
|
"
|
|
ZMQ_HAVE_PTHREAD_SETNAME_2)
|
|
check_c_source_runs(
|
|
"
|
|
#include <pthread.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
pthread_setname_np (pthread_self(), \"foo\", (void *)0);
|
|
return 0;
|
|
}
|
|
"
|
|
ZMQ_HAVE_PTHREAD_SETNAME_3)
|
|
check_c_source_runs(
|
|
"
|
|
#include <pthread.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
pthread_set_name_np (pthread_self(), \"foo\");
|
|
return 0;
|
|
}
|
|
"
|
|
ZMQ_HAVE_PTHREAD_SET_NAME)
|
|
set(CMAKE_REQUIRED_FLAGS ${SAVE_CMAKE_REQUIRED_FLAGS})
|
|
endmacro()
|
|
|
|
macro(zmq_check_pthread_setaffinity)
|
|
message(STATUS "Checking pthread_setaffinity signature")
|
|
set(SAVE_CMAKE_REQUIRED_FLAGS ${CMAKE_REQUIRED_FLAGS})
|
|
set(CMAKE_REQUIRED_FLAGS "-D_GNU_SOURCE -Werror -pthread")
|
|
check_c_source_runs(
|
|
"
|
|
#include <pthread.h>
|
|
|
|
int main(int argc, char *argv [])
|
|
{
|
|
cpu_set_t test;
|
|
pthread_setaffinity_np (pthread_self(), sizeof(cpu_set_t), &test);
|
|
return 0;
|
|
}
|
|
"
|
|
ZMQ_HAVE_PTHREAD_SETAFFINITY)
|
|
set(CMAKE_REQUIRED_FLAGS ${SAVE_CMAKE_REQUIRED_FLAGS})
|
|
endmacro()
|
|
|
|
|
|
macro(zmq_check_getrandom)
|
|
message(STATUS "Checking whether getrandom is supported")
|
|
check_c_source_runs(
|
|
"
|
|
#include <sys/random.h>
|
|
|
|
int main (int argc, char *argv [])
|
|
{
|
|
char buf[4];
|
|
getrandom(buf, 4, 0);
|
|
}
|
|
"
|
|
ZMQ_HAVE_GETRANDOM)
|
|
endmacro()
|