ENH: Do better test for pthreads
This commit is contained in:
parent
cb4e99f712
commit
ff5f0312de
30
Modules/CheckForPthreads.c
Normal file
30
Modules/CheckForPthreads.c
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <pthread.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
void* runner(void*);
|
||||||
|
|
||||||
|
int res = 0;
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
pthread_t tid[2];
|
||||||
|
pthread_create(&tid[0], 0, runner, (void*)1);
|
||||||
|
pthread_create(&tid[1], 0, runner, (void*)2);
|
||||||
|
|
||||||
|
usleep(1); // for strange behavior on single-processor sun
|
||||||
|
pthread_join(tid[0], 0);
|
||||||
|
pthread_join(tid[1], 0);
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* runner(void* args)
|
||||||
|
{
|
||||||
|
int cc;
|
||||||
|
for ( cc = 0; cc < 10; cc ++ )
|
||||||
|
{
|
||||||
|
printf("%d CC: %d\n", (int)args, cc);
|
||||||
|
}
|
||||||
|
res ++;
|
||||||
|
return 0;
|
||||||
|
}
|
@ -16,20 +16,45 @@ ENDIF(CMAKE_SYSTEM MATCHES IRIX)
|
|||||||
CHECK_INCLUDE_FILE("pthread.h" CMAKE_HAVE_PTHREAD_H)
|
CHECK_INCLUDE_FILE("pthread.h" CMAKE_HAVE_PTHREAD_H)
|
||||||
IF(CMAKE_HAVE_PTHREAD_H)
|
IF(CMAKE_HAVE_PTHREAD_H)
|
||||||
IF(NOT CMAKE_HAVE_SPROC_H)
|
IF(NOT CMAKE_HAVE_SPROC_H)
|
||||||
CHECK_LIBRARY_EXISTS(pthreads pthread_create "" CMAKE_HAVE_PTHREADS_CREATE)
|
IF("THREADS_HAVE_PTHREAD_ARG" MATCHES "^THREADS_HAVE_PTHREAD_ARG")
|
||||||
IF(CMAKE_HAVE_PTHREADS_CREATE)
|
MESSAGE(STATUS "Check if compiler accepts -pthread")
|
||||||
SET(CMAKE_THREAD_LIBS_INIT "-lpthreads")
|
TRY_RUN(THREADS_PTHREAD_ARG THREADS_HAVE_PTHREAD_ARG
|
||||||
ENDIF(CMAKE_HAVE_PTHREADS_CREATE)
|
${CMAKE_BINARY_DIR}
|
||||||
CHECK_LIBRARY_EXISTS(pthread pthread_create "" CMAKE_HAVE_PTHREAD_CREATE)
|
${CMAKE_ROOT}/Modules/CheckForPthreads.c
|
||||||
IF(CMAKE_HAVE_PTHREAD_CREATE)
|
CMAKE_FLAGS -DLINK_LIBRARIES:STRING=-pthread
|
||||||
SET(CMAKE_THREAD_LIBS_INIT "-lpthread")
|
OUTPUT_VARIABLE OUTPUT)
|
||||||
ENDIF(CMAKE_HAVE_PTHREAD_CREATE)
|
IF(THREADS_HAVE_PTHREAD_ARG)
|
||||||
IF(CMAKE_SYSTEM MATCHES "SunOS.*")
|
IF(THREADS_PTHREAD_ARG MATCHES "^2$")
|
||||||
CHECK_LIBRARY_EXISTS(thread thr_create "" CMAKE_HAVE_THR_CREATE)
|
MESSAGE(STATUS "Check if compiler accepts -pthread - yes")
|
||||||
IF(CMAKE_HAVE_THR_CREATE)
|
ELSE(THREADS_PTHREAD_ARG MATCHES "^2$")
|
||||||
SET(CMAKE_THREAD_LIBS_INIT "-lthread")
|
MESSAGE(STATUS "Check if compiler accepts -pthread - no")
|
||||||
ENDIF(CMAKE_HAVE_THR_CREATE)
|
FILE(APPEND ${CMAKE_BINARY_DIR}/CMakeError.log
|
||||||
ENDIF(CMAKE_SYSTEM MATCHES "SunOS.*")
|
"Determining if compiler accepts -pthread returned ${THREADS_PTHREAD_ARG} instead of 2. The compiler had the following output:\n${OUTPUT}\n\n")
|
||||||
|
ENDIF(THREADS_PTHREAD_ARG MATCHES "^2$")
|
||||||
|
ELSE(THREADS_HAVE_PTHREAD_ARG)
|
||||||
|
MESSAGE(STATUS "Check if compiler accepts -pthread - no")
|
||||||
|
FILE(APPEND ${CMAKE_BINARY_DIR}/CMakeError.log
|
||||||
|
"Determining if compiler accepts -pthread failed with the following output:\n${OUTPUT}\n\n")
|
||||||
|
ENDIF(THREADS_HAVE_PTHREAD_ARG)
|
||||||
|
ENDIF("THREADS_HAVE_PTHREAD_ARG" MATCHES "^THREADS_HAVE_PTHREAD_ARG")
|
||||||
|
IF(THREADS_HAVE_PTHREAD_ARG)
|
||||||
|
SET(CMAKE_THREAD_LIBS_INIT "-pthread")
|
||||||
|
ELSE(THREADS_HAVE_PTHREAD_ARG)
|
||||||
|
CHECK_LIBRARY_EXISTS(pthreads pthread_create "" CMAKE_HAVE_PTHREADS_CREATE)
|
||||||
|
IF(CMAKE_HAVE_PTHREADS_CREATE)
|
||||||
|
SET(CMAKE_THREAD_LIBS_INIT "-lpthreads")
|
||||||
|
ENDIF(CMAKE_HAVE_PTHREADS_CREATE)
|
||||||
|
CHECK_LIBRARY_EXISTS(pthread pthread_create "" CMAKE_HAVE_PTHREAD_CREATE)
|
||||||
|
IF(CMAKE_HAVE_PTHREAD_CREATE)
|
||||||
|
SET(CMAKE_THREAD_LIBS_INIT "-lpthread")
|
||||||
|
ENDIF(CMAKE_HAVE_PTHREAD_CREATE)
|
||||||
|
IF(CMAKE_SYSTEM MATCHES "SunOS.*")
|
||||||
|
CHECK_LIBRARY_EXISTS(thread thr_create "" CMAKE_HAVE_THR_CREATE)
|
||||||
|
IF(CMAKE_HAVE_THR_CREATE)
|
||||||
|
SET(CMAKE_THREAD_LIBS_INIT "-lthread")
|
||||||
|
ENDIF(CMAKE_HAVE_THR_CREATE)
|
||||||
|
ENDIF(CMAKE_SYSTEM MATCHES "SunOS.*")
|
||||||
|
ENDIF(THREADS_HAVE_PTHREAD_ARG)
|
||||||
ENDIF(NOT CMAKE_HAVE_SPROC_H)
|
ENDIF(NOT CMAKE_HAVE_SPROC_H)
|
||||||
ENDIF(CMAKE_HAVE_PTHREAD_H)
|
ENDIF(CMAKE_HAVE_PTHREAD_H)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user