Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Add test for LUA and more.
[simgrid.git] / buildtools / CPACK / CMakeCompleteInFiles.txt
index c511dec..65e8bcb 100644 (file)
@@ -1,4 +1,3 @@
-cmake_minimum_required(VERSION 2.6)
 include(CheckFunctionExists)
 include(CheckIncludeFile)
 include(CheckIncludeFiles)
@@ -12,6 +11,9 @@ if(disable_java)
 else(disable_java)
        include(FindJava)
        include(FindJNI)
+       if(JAVA_INCLUDE_PATH)
+               set(HAVE_JNI_H 1)
+       endif(JAVA_INCLUDE_PATH)
        find_path(JAR   NAMES jar       PATHS NO_DEFAULT_PATHS  )       
        if(JAVA_RUNTIME AND JAVA_COMPILE AND JAR AND JAVA_INCLUDE_PATH)
                SET(HAVE_JAVA 1)
@@ -28,74 +30,40 @@ if(disable_gtnets)
 else(disable_gtnets)
        set(GTNETS_LDFLAGS "-lgtnets -L${gtnets_path}/lib")
        set(GTNETS_CPPFLAGS "-I${gtnets_path}/include -I${gtnets_path}/include/gtnets")
-       try_compile(COMPILE_GTNETS_VAR
-               ${PROJECT_DIRECTORY}
-               ${PROJECT_DIRECTORY}/CPACK/tmp/prog_gtnets.c
-               CMAKE_FLAGS ${GTNETS_CPPFLAGS}
-               COMPILE_DEFINITIONS ${GTNETS_LDFLAGS}
-               OUTPUT_VARIABLE GETLINE_OUTPUT
-       )
-       if(COMPILE_GTNETS_VAR MATCHES "FALSE")
+       exec_program("${CMAKE_CXX_COMPILER} ${GTNETS_CPPFLAGS} ${GTNETS_LDFLAGS} ${PROJECT_DIRECTORY}/CPACK/tmp/prog_gtnets.cpp" OUTPUT_VARIABLE COMPILE_GTNETS_VAR)    
+       if(COMPILE_GTNETS_VAR)
                SET(HAVE_GTNETS 0)
-       else(COMPILE_GTNETS_VAR MATCHES "FALSE")
+       else(COMPILE_GTNETS_VAR)
                SET(HAVE_GTNETS 1)
                set(INCLUDES
                        ${INCLUDES}
                        ${GTNETS_CPPFLAGS}
                )
                add_definitions(${GTNETS_LDFLAGS})
-       endif(COMPILE_GTNETS_VAR MATCHES "FALSE")
+       endif(COMPILE_GTNETS_VAR)
 endif(disable_gtnets)
 message("HAVE_GTNETS ${HAVE_GTNETS}")
 
 #--------------------------------------------------------------------------------------------------
 ### Initialize of CONTEXT THREADS
-if(disable_threads)
-       SET(CONTEXT_THREADS 0)
-else(disable_threads)
-       SET(CONTEXT_THREADS 1)
-endif(disable_threads)
-message("CONTEXT_THREADS ${CONTEXT_THREADS}")
-
-message("______END_CONTEXT______")
-
-###############
-## SVN version check
-##
-message("\n__________SVN__________")
-if(IS_DIRECTORY ${PROJECT_DIRECTORY}/.svn)
-       find_file(SVN ".svn" ${PROJECT_DIRECTORY})
-       exec_program("svnversion ${PROJECT_DIRECTORY}" OUTPUT_VARIABLE "SVN_VERSION")
-       message("SVN_VERSION ${SVN_VERSION}")
-endif(IS_DIRECTORY ${PROJECT_DIRECTORY}/.svn)
-
-if(IS_DIRECTORY ${PROJECT_DIRECTORY}/.git)
-       find_file(GIT ".git" ${PROJECT_DIRECTORY})
-       exec_program("git --git-dir=${PROJECT_DIRECTORY} log --oneline -1 | sed 's| .*||'" OUTPUT_VARIABLE "GIT_VERSION")
-       message("GIT_VERSION ${GIT_VERSION}")
-endif(IS_DIRECTORY ${PROJECT_DIRECTORY}/.git)
-message("________END_SVN________")
-
-message("\n_____GRAS_&_SIMGRID____")
-###################################
-## SimGrid and GRAS specific checks
-##
 
 CHECK_INCLUDE_FILE(pthread.h HAVE_PTHREAD_H)
-CHECK_LIBRARY_EXISTS(pthread pthread_create NO_DEFAULT_PATHS HAVE_pthread_create)
-
-if(HAVE_pthread_create)
+CHECK_LIBRARY_EXISTS(pthread pthread_create NO_DEFAULT_PATHS pthread)
+if(pthread)
+set(pthread "yes")
+elseif(pthread)
+set(pthread "no")
+endif(pthread)
+
+if(pthread MATCHES "yes")
        ### HAVE_SEM_INIT
        CHECK_LIBRARY_EXISTS(pthread sem_init NO_DEFAULT_PATHS HAVE_SEM_INIT_LIB)
        if(HAVE_SEM_INIT_LIB)
-               try_compile(HAVE_SEM_INIT_run
-               ${PROJECT_DIRECTORY}
-               ${PROJECT_DIRECTORY}/CPACK/tmp/prog_sem_init.c
-               )
+               exec_program("${CMAKE_C_COMPILER} -lpthread ${PROJECT_DIRECTORY}/CPACK/tmp/prog_sem_init.c" OUTPUT_VARIABLE HAVE_SEM_INIT_run)
                if(HAVE_SEM_INIT_run)
-                       set(HAVE_SEM_INIT 1)
-               else(HAVE_SEM_INIT_run)
                        set(HAVE_SEM_INIT 0)
+               else(HAVE_SEM_INIT_run)
+                       set(HAVE_SEM_INIT 1)
                endif(HAVE_SEM_INIT_run)
                message("HAVE_SEM_INIT ${HAVE_SEM_INIT}")
        endif(HAVE_SEM_INIT_LIB)
@@ -103,14 +71,11 @@ if(HAVE_pthread_create)
        ### HAVE_SEM_TIMEDWAIT
        CHECK_LIBRARY_EXISTS(pthread sem_timedwait NO_DEFAULT_PATHS HAVE_SEM_TIMEDWAIT_LIB)
        if(HAVE_SEM_TIMEDWAIT_LIB)
-               try_compile(HAVE_SEM_TIMEDWAIT_run
-               ${PROJECT_DIRECTORY}
-               ${PROJECT_DIRECTORY}/CPACK/tmp/prog_sem_timedwait.c
-               )
+               exec_program("${CMAKE_C_COMPILER} -lpthread ${PROJECT_DIRECTORY}/CPACK/tmp/prog_sem_timedwait.c" OUTPUT_VARIABLE HAVE_SEM_TIMEDWAIT_run)
                if(HAVE_SEM_TIMEDWAIT_run)
-                       set(HAVE_SEM_TIMEDWAIT 1)
-               else(HAVE_SEM_TIMEDWAIT_run)
                        set(HAVE_SEM_TIMEDWAIT 0)
+               else(HAVE_SEM_TIMEDWAIT_run)
+                       set(HAVE_SEM_TIMEDWAIT 1)
                endif(HAVE_SEM_TIMEDWAIT_run)
                message("HAVE_SEM_TIMEDWAIT ${HAVE_SEM_TIMEDWAIT}")
        endif(HAVE_SEM_TIMEDWAIT_LIB)
@@ -118,26 +83,233 @@ if(HAVE_pthread_create)
        ### HAVE_MUTEX_TIMEDLOCK
        CHECK_LIBRARY_EXISTS(pthread pthread_mutex_timedlock NO_DEFAULT_PATHS HAVE_MUTEX_TIMEDLOCK_LIB)
        if(HAVE_MUTEX_TIMEDLOCK_LIB)
-               try_compile(HAVE_MUTEX_TIMEDLOCK_run
-               ${PROJECT_DIRECTORY}
-               ${PROJECT_DIRECTORY}/CPACK/tmp/prog_mutex_timedlock.c
-               )
+               exec_program("${CMAKE_C_COMPILER} -lpthread ${PROJECT_DIRECTORY}/CPACK/tmp/prog_mutex_timedlock.c" OUTPUT_VARIABLE HAVE_SEM_TIMEDWAIT_run)
                if(HAVE_MUTEX_TIMEDLOCK_run)
-                       set(HAVE_MUTEX_TIMEDLOCK 1)
-               else(HAVE_MUTEX_TIMEDLOCK_run)
                        set(HAVE_MUTEX_TIMEDLOCK 0)
+               else(HAVE_MUTEX_TIMEDLOCK_run)
+                       set(HAVE_MUTEX_TIMEDLOCK 1)
                endif(HAVE_MUTEX_TIMEDLOCK_run)
                message("HAVE_MUTEX_TIMEDLOCK ${HAVE_MUTEX_TIMEDLOCK}")
        endif(HAVE_MUTEX_TIMEDLOCK_LIB)
+endif(pthread MATCHES "yes")
+
+# AC_CHECK_MCSC(mcsc=yes, mcsc=no) 
+try_run(RUN_mcsc_VAR COMPILE_mcsc_VAR
+       ${PROJECT_DIRECTORY}
+       ${PROJECT_DIRECTORY}/CPACK/tmp/prog_AC_CHECK_MCSC.c
+       )
+
+file(READ "${PROJECT_DIRECTORY}/CPACK/conftestval" mcsc)
+if(mcsc MATCHES "yes")
+       set(mcsc "yes")
+elseif(mcsc MATCHES "yes")
+       set(mcsc "no")
+endif(mcsc MATCHES "yes")
+
+if(mcsc MATCHES "no" AND pthread MATCHES "no")
+       CHECK_INCLUDE_FILE(windows.h HAVE_WINDOWS_H)
+       if(HAVE_WINDOWS_H)
+               set(windows_context "yes")
+               set(IS_WINDOWS 1)
+       elseif(HAVE_WINDOWS_H)
+               message("no appropriate backend found")
+       endif(HAVE_WINDOWS_H)
+endif(mcsc MATCHES "no" AND pthread MATCHES "no")
+
+if(NOT disable_context AND with_context MATCHES "ucontext" AND mcsc MATCHES "no")
+       message(FATAL_ERROR "-Dwith-context=ucontext specified but ucontext unusable.")
+endif(NOT disable_context AND with_context MATCHES "ucontext" AND mcsc MATCHES "no")
+
+if(NOT disable_context)
+       set(with_context_ok 0)
+       if(with_context MATCHES "windows")
+               set(with_context_ok 1)
+       endif(with_context MATCHES "windows")
+
+       if(with_context MATCHES "pthreads")
+               set(with_context_ok 1)
+               set(with_context "pthread")
+       endif(with_context MATCHES "pthreads")
+
+       if(with_context MATCHES "auto")
+               set(with_context_ok 1)
+               set(with_context "ucontext")
+               message("with_context auto change to ucontext")
+       endif(with_context MATCHES "auto")
+
+       if(with_context MATCHES "ucontext")
+               set(with_context_ok 1)
+               if(mcsc MATCHES "yes")
+                       set(CONTEXT_UCONTEXT 1)
+                       CHECK_INCLUDE_FILE(valgrind/valgrind.h HAVE_VALGRIND_VALGRIND_H)
+               else(mcsc MATCHES "yes")
+                       if(windows_context MATCHES "yes")
+                               set(with_context "windows")
+                       else(windows_context MATCHES "yes")
+                               set(with_context "pthread")
+                       endif(windows_context MATCHES "yes")
+               endif(mcsc MATCHES "yes")
+       endif(with_context MATCHES "ucontext")
+
+       if(with_context MATCHES "pthread")
+               set(with_context_ok 1)
+               if(pthread MATCHES "no")
+                       message(FATAL_ERROR "Cannot find pthreads (try -Dwith_context=ucontext if you haven't already tried).")
+               endif(pthread MATCHES "no")
+               SET(CONTEXT_THREADS 1)
+       endif(with_context MATCHES "pthread")
+
+       if(with_context MATCHES "ucontext")
+               SET(CONTEXT_THREADS 0)
+       endif(with_context MATCHES "ucontext")
+       
+       if(NOT with_context_ok)
+               message(FATAL_ERROR "-Dwith-context must be either ucontext or pthread")
+       endif(NOT with_context_ok)
+endif(NOT disable_context)
+
+
+message("CONTEXT_THREADS ${CONTEXT_THREADS}")
+message("CONTEXT_UCONTEXT ${CONTEXT_UCONTEXT}")
+
+if(NOT disable_lua)
+       CHECK_INCLUDE_FILE(lua5.1/lualib.h HAVE_LUA5_1_LUALIB_H)
+       message("HAVE_LUA5_1_LUALIB_H ${HAVE_LUA5_1_LUALIB_H}")
+       if(HAVE_LUA5_1_LUALIB_H)
+               set(HAVE_LUA 1)
+       endif(HAVE_LUA5_1_LUALIB_H)
+endif(NOT disable_lua)
+message("HAVE_LUA ${HAVE_LUA}")
+
+message("______END_CONTEXT______")
+
+###############
+## SVN version check
+##
+message("\n__________SVN__________")
+if(IS_DIRECTORY ${PROJECT_DIRECTORY}/.svn)
+       find_file(SVN ".svn" ${PROJECT_DIRECTORY})
+       exec_program("svnversion ${PROJECT_DIRECTORY}" OUTPUT_VARIABLE "SVN_VERSION")
+       message("SVN_VERSION ${SVN_VERSION}")
+endif(IS_DIRECTORY ${PROJECT_DIRECTORY}/.svn)
+
+if(IS_DIRECTORY ${PROJECT_DIRECTORY}/.git)
+       find_file(GIT ".git" ${PROJECT_DIRECTORY})
+       exec_program("git --git-dir=${PROJECT_DIRECTORY} log --oneline -1 | sed 's| .*||'" OUTPUT_VARIABLE "GIT_VERSION")
+       message("GIT_VERSION ${GIT_VERSION}")
+endif(IS_DIRECTORY ${PROJECT_DIRECTORY}/.git)
+message("________END_SVN________")
+
+message("\n_____GRAS_&_SIMGRID____")
+###################################
+## SimGrid and GRAS specific checks
+##
+include(TestBigEndian)
+TEST_BIG_ENDIAN(BIGENDIAN)
+# Check architecture signature begin
+try_run(RUN_GRAS_VAR COMPILE_GRAS_VAR
+       ${PROJECT_DIRECTORY}
+       ${PROJECT_DIRECTORY}/CPACK/tmp/prog_GRAS_ARCH.c
+       RUN_OUTPUT_VARIABLE var1
+       )
+if(BIGENDIAN)
+set(val_big "B${var1}")
+set(GRAS_BIGENDIAN 1)
+else(BIGENDIAN)
+set(val_big "l${var1}")
+set(GRAS_BIGENDIAN 0)
+endif(BIGENDIAN)
+message("GRAS_BIGENDIAN ${GRAS_BIGENDIAN}")
+message("${val_big}")
+
+if(val_big MATCHES "l_C:1/1:_I:2/1:4/1:4/1:8/1:_P:4/1:4/1:_D:4/1:8/1:")
+       message("gras_arch=0; gras_size=32; gras_arch_name=little32_1;")
+       SET(GRAS_ARCH_32_BITS 1)
+       SET(GRAS_THISARCH 0)
+endif(val_big MATCHES "l_C:1/1:_I:2/1:4/1:4/1:8/1:_P:4/1:4/1:_D:4/1:8/1:")
+if(val_big MATCHES "l_C:1/1:_I:2/2:4/2:4/2:8/2:_P:4/2:4/2:_D:4/2:8/2:")
+       message("gras_arch=1; gras_size=32; gras_arch_name=little32_2;")
+       SET(GRAS_ARCH_32_BITS 1)
+       SET(GRAS_THISARCH 1)
+endif(val_big MATCHES "l_C:1/1:_I:2/2:4/2:4/2:8/2:_P:4/2:4/2:_D:4/2:8/2:")
+if(val_big MATCHES "l_C:1/1:_I:2/2:4/4:4/4:8/4:_P:4/4:4/4:_D:4/4:8/4:") 
+       message("gras_arch=2; gras_size=32; gras_arch_name=little32_4;")
+       SET(GRAS_ARCH_32_BITS 1)
+       SET(GRAS_THISARCH 2)
+endif(val_big MATCHES "l_C:1/1:_I:2/2:4/4:4/4:8/4:_P:4/4:4/4:_D:4/4:8/4:")
+if(val_big MATCHES "l_C:1/1:_I:2/2:4/4:4/4:8/8:_P:4/4:4/4:_D:4/4:8/8:") 
+       message("gras_arch=3; gras_size=32; gras_arch_name=little32_8;")
+       SET(GRAS_ARCH_32_BITS 1)
+       SET(GRAS_THISARCH 3)
+endif(val_big MATCHES "l_C:1/1:_I:2/2:4/4:4/4:8/8:_P:4/4:4/4:_D:4/4:8/8:") 
+if(val_big MATCHES "l_C:1/1:_I:2/2:4/4:8/8:8/8:_P:8/8:8/8:_D:4/4:8/8:") 
+       message("gras_arch=4; gras_size=64; gras_arch_name=little64;")
+       SET(GRAS_ARCH_32_BITS 0)
+       SET(GRAS_THISARCH 4)
+endif(val_big MATCHES "l_C:1/1:_I:2/2:4/4:8/8:8/8:_P:8/8:8/8:_D:4/4:8/8:")
+
+if(val_big MATCHES "B_C:1/1:_I:2/2:4/4:4/4:8/8:_P:4/4:4/4:_D:4/4:8/8:") 
+       message("gras_arch=5; gras_size=32; gras_arch_name=big32;")
+       SET(GRAS_ARCH_32_BITS 1)
+       SET(GRAS_THISARCH 5)
+endif(val_big MATCHES "B_C:1/1:_I:2/2:4/4:4/4:8/8:_P:4/4:4/4:_D:4/4:8/8:")
+if(val_big MATCHES "B_C:1/1:_I:2/2:4/4:4/4:8/8:_P:4/4:4/4:_D:4/4:8/4:") 
+       message("gras_arch=6; gras_size=32; gras_arch_name=big32_8_4;")
+       SET(GRAS_ARCH_32_BITS 1)
+       SET(GRAS_THISARCH 6)
+endif(val_big MATCHES "B_C:1/1:_I:2/2:4/4:4/4:8/8:_P:4/4:4/4:_D:4/4:8/4:")
+if(val_big MATCHES "B_C:1/1:_I:2/2:4/4:4/4:8/4:_P:4/4:4/4:_D:4/4:8/4:") 
+       message("gras_arch=7; gras_size=32; gras_arch_name=big32_4;")
+       SET(GRAS_ARCH_32_BITS 1)
+       SET(GRAS_THISARCH 7)
+endif(val_big MATCHES "B_C:1/1:_I:2/2:4/4:4/4:8/4:_P:4/4:4/4:_D:4/4:8/4:")
+if(val_big MATCHES "B_C:1/1:_I:2/2:4/2:4/2:8/2:_P:4/2:4/2:_D:4/2:8/2:") 
+       message("gras_arch=8; gras_size=32; gras_arch_name=big32_2;")
+       SET(GRAS_ARCH_32_BITS 1)
+       SET(GRAS_THISARCH 8)
+endif(val_big MATCHES "B_C:1/1:_I:2/2:4/2:4/2:8/2:_P:4/2:4/2:_D:4/2:8/2:") 
+if(val_big MATCHES "B_C:1/1:_I:2/2:4/4:8/8:8/8:_P:8/8:8/8:_D:4/4:8/8:") 
+       message("gras_arch=9; gras_size=64; gras_arch_name=big64;")
+       SET(GRAS_ARCH_32_BITS 0)
+       SET(GRAS_THISARCH 9)
+endif(val_big MATCHES "B_C:1/1:_I:2/2:4/4:8/8:8/8:_P:8/8:8/8:_D:4/4:8/8:")
+if(val_big MATCHES "B_C:1/1:_I:2/2:4/4:8/8:8/8:_P:8/8:8/8:_D:4/4:8/4:") 
+       message("gras_arch=10;gras_size=64; gras_arch_name=big64_8_4;")
+       SET(GRAS_ARCH_32_BITS 0)
+       SET(GRAS_THISARCH 10)
+endif(val_big MATCHES "B_C:1/1:_I:2/2:4/4:8/8:8/8:_P:8/8:8/8:_D:4/4:8/4:") 
+       message("GRAS_ARCH_32_BITS ${GRAS_ARCH_32_BITS}")
+
+
+# Check architecture signature end
+try_run(RUN_GRAS_VAR COMPILE_GRAS_VAR
+       ${PROJECT_DIRECTORY}
+       ${PROJECT_DIRECTORY}/CPACK/tmp/prog_GRAS_CHECK_STRUCT_COMPACTION.c
+       RUN_OUTPUT_VARIABLE var2
+       )
+separate_arguments(var2)
+foreach(var_tmp ${var2})
+       set(${var_tmp} 1)
+       message("${var_tmp} ${${var_tmp}}")
+endforeach(var_tmp ${var2})
+
+# Check for [SIZEOF_MAX]
+try_run(RUN_SM_VAR COMPILE_SM_VAR
+       ${PROJECT_DIRECTORY}
+       ${PROJECT_DIRECTORY}/CPACK/tmp/prog_max_size.c
+       RUN_OUTPUT_VARIABLE var3
+       )
+SET(SIZEOF_MAX ${var3})
+message("SIZEOF_MAX ${SIZEOF_MAX}")
 
-endif(HAVE_pthread_create)
 
 #--------------------------------------------------------------------------------------------------
 
-CHECK_FUNCTION_EXISTS(makecontext HAVE_FCT_makecontext)
-message("HAVE_FCT_makecontext ${HAVE_FCT_makecontext}")
 
-if(HAVE_FCT_makecontext)
+CHECK_FUNCTION_EXISTS(makecontext HAVE_MAKECONTEXT)
+message("HAVE_MAKECONTEXT ${HAVE_MAKECONTEXT}")
+
+if(HAVE_MAKECONTEXT)
        set(makecontext_CPPFLAGS "-DTEST_makecontext")
        try_run(RUN_makecontext_VAR COMPILE_makecontext_VAR
                ${PROJECT_DIRECTORY}
@@ -159,12 +331,26 @@ if(HAVE_FCT_makecontext)
        set(pth_skaddr_makecontext "#define pth_skaddr_makecontext(skaddr,sksize) (${makecontext_addr})")
        set(pth_sksize_makecontext "#define pth_sksize_makecontext(skaddr,sksize) (${makecontext_size})")
 
-endif(HAVE_FCT_makecontext)
-
-configure_file(${PROJECT_DIRECTORY}/src/context_sysv_config.h.in ${PROJECT_DIRECTORY}/src/context_sysv_config.h)
+endif(HAVE_MAKECONTEXT)
 
 #--------------------------------------------------------------------------------------------------
 
+### check for stackgrowth
+
+       try_run(RUN_makecontext_VAR COMPILE_makecontext_VAR
+               ${PROJECT_DIRECTORY}
+               ${PROJECT_DIRECTORY}/CPACK/tmp/prog_stackgrowth.c
+               )
+file(READ "${PROJECT_DIRECTORY}/CPACK/conftestval" stack)
+if(stack MATCHES "down")
+       set(PTH_STACKGROWTH "-1")
+endif(stack MATCHES "down")
+if(stack MATCHES "up")
+       set(PTH_STACKGROWTH "1")
+endif(stack MATCHES "up")
+message("PTH_STACKGROWTH ${PTH_STACKGROWTH}")
+
+
 ###############
 ## System checks
 ##
@@ -191,6 +377,107 @@ message("PRINTF_NULL_WORKING ${PRINTF_NULL_WORKING}")
 
 #AC_CHECK_VA_COPY
 
+set(diff_va "va_copy((d),(s))"
+"VA_COPY((d),(s))"
+"__va_copy((d),(s))"
+"__builtin_va_copy((d),(s))"
+"do { (d) = (s)\; } while (0)"
+"do { *(d) = *(s)\; } while (0)"
+"memcpy((void *)&(d), (void *)&(s)), sizeof((s))"
+"memcpy((void *)(d), (void *)(s)), sizeof(*(s))"
+)
+
+foreach(fct ${diff_va})
+       write_file("${PROJECT_DIRECTORY}/CPACK/tmp/prog_va_copy.c" "#include <stdlib.h>
+       #include <stdarg.h>
+       #include <string.h>
+       #define DO_VA_COPY(d,s) ${fct}
+       void test(char *str, ...)
+       {
+           va_list ap, ap2;
+           int i;
+           va_start(ap, str);
+           DO_VA_COPY(ap2, ap);
+           for (i = 1; i <= 9; i++) {
+               int k = (int)va_arg(ap, int);
+               if (k != i)
+                   abort();
+           }
+           DO_VA_COPY(ap, ap2);
+           for (i = 1; i <= 9; i++) {
+               int k = (int)va_arg(ap, int);
+               if (k != i)
+                   abort();
+           }
+           va_end(ap);
+       }
+       int main(int argc, char *argv[])
+       {
+           test("test", 1, 2, 3, 4, 5, 6, 7, 8, 9);
+           exit(0);
+       }"
+       )
+       try_run(RUN_VA_NULL_VAR COMPILE_VA_NULL_VAR
+       ${PROJECT_DIRECTORY}
+       ${PROJECT_DIRECTORY}/CPACK/tmp/prog_va_copy.c
+       )
+       if(RUN_VA_NULL_VAR MATCHES "FAILED_TO_RUN")
+       else(RUN_VA_NULL_VAR MATCHES "FAILED_TO_RUN")   
+
+               string(REGEX REPLACE "\;" "" fctbis ${fct})
+
+               if(${fctbis} STREQUAL "va_copy((d),(s))")
+                       set(HAVE_VA_COPY 1)
+                       message("HAVE_VA_COPY ${HAVE_VA_COPY}")
+                       set(ac_cv_va_copy "C99")
+                       set(__VA_COPY_USE_C99 "va_copy((d),(s))")       
+               endif(${fctbis} STREQUAL "va_copy((d),(s))")
+
+               if(${fctbis} STREQUAL "VA_COPY((d),(s))")
+                       set(ac_cv_va_copy "GCM")
+                       set(__VA_COPY_USE_GCM "VA_COPY((d),(s))")
+               endif(${fctbis} STREQUAL "VA_COPY((d),(s))")
+
+               if(${fctbis} STREQUAL "__va_copy((d),(s))")
+                       set(ac_cv_va_copy "GCH")
+                       set(__VA_COPY_USE_GCH "__va_copy((d),(s))")
+               endif(${fctbis} STREQUAL "__va_copy((d),(s))")
+
+               if(${fctbis} STREQUAL "__builtin_va_copy((d),(s))")
+                       set(ac_cv_va_copy "GCB")
+                       set(__VA_COPY_USE_GCB "__builtin_va_copy((d),(s))")
+               endif(${fctbis} STREQUAL "__builtin_va_copy((d),(s))")
+
+               if(${fctbis} STREQUAL "do { (d) = (s) } while (0)")
+                       set(ac_cv_va_copy "ASS")
+                       set(__VA_COPY_USE_ASS "do { (d) = (s)\; } while (0)")
+               endif(${fctbis} STREQUAL "do { (d) = (s) } while (0)")
+
+               if(${fctbis} STREQUAL "do { *(d) = *(s) } while (0)")
+                       set(ac_cv_va_copy "ASP")
+                       set(__VA_COPY_USE_ASP "do { *(d) = *(s)\; } while (0)")
+               endif(${fctbis} STREQUAL "do { *(d) = *(s) } while (0)")
+
+               if(${fctbis} STREQUAL "memcpy((void *)&(d), (void *)&(s)), sizeof((s))")
+                       set(ac_cv_va_copy "CPS")
+                       set(__VA_COPY_USE_CPS "memcpy((void *)&(d), (void *)&(s)), sizeof((s))")
+               endif(${fctbis} STREQUAL "memcpy((void *)&(d), (void *)&(s)), sizeof((s))")
+
+               if(${fctbis} STREQUAL "memcpy((void *)(d), (void *)(s)), sizeof(*(s))")
+                       set(ac_cv_va_copy "CPP")
+                       set(__VA_COPY_USE_CPP "memcpy((void *)(d), (void *)(s)), sizeof(*(s))")
+               endif(${fctbis} STREQUAL "memcpy((void *)(d), (void *)(s)), sizeof(*(s))")
+                               
+               if(NOT STATUS_OK)
+               set(__VA_COPY_USE "__VA_COPY_USE_${ac_cv_va_copy}")
+               message("__VA_COPY_USE VA_COPY_USE_${ac_cv_va_copy}")
+               endif(NOT STATUS_OK)
+               message("__VA_COPY_USE_${ac_cv_va_copy} ${fctbis}")
+               set(STATUS_OK "1")
+
+       endif(RUN_VA_NULL_VAR MATCHES "FAILED_TO_RUN")
+endforeach(fct ${diff_va})
+
 # Checks for header files.
 
 CHECK_INCLUDE_FILES("stdlib.h;stdarg.h;string.h;float.h" STDC_HEADERS)
@@ -198,9 +485,9 @@ message("STDC_HEADERS ${STDC_HEADERS}")
 CHECK_INCLUDE_FILES("time.h;sys/time.h" TIME_WITH_SYS_TIME)
 message("TIME_WITH_SYS_TIME ${TIME_WITH_SYS_TIME}")
 
-CHECK_INCLUDE_FILE(sys/socket.h HAVE_SOCKET_H)
+CHECK_INCLUDE_FILE(sys/socket.h HAVE_SYS_SOCKET_H)
 message("HAVE_SOCKET_H ${HAVE_SOCKET_H}")
-CHECK_INCLUDE_FILE(sys/stat.h HAVE_STAT_H)
+CHECK_INCLUDE_FILE(sys/stat.h HAVE_SYS_STAT_H)
 message("HAVE_STAT_H ${HAVE_STAT_H}")
 CHECK_INCLUDE_FILE(windows.h HAVE_WINDOWS_H)
 message("HAVE_WINDOWS_H ${HAVE_WINDOWS_H}")
@@ -208,7 +495,7 @@ CHECK_INCLUDE_FILE(winsock.h HAVE_WINSOCK_H)
 message("HAVE_WINSOCK_H ${HAVE_WINSOCK_H}")
 CHECK_INCLUDE_FILE(winsock2.h HAVE_WINSOCK2_H)
 message("HAVE_WINSOCK2_H ${HAVE_WINSOCK2_H}")
-CHECK_INCLUDE_FILE(sys/time.h HAVE_TIME_H)
+CHECK_INCLUDE_FILE(sys/time.h HAVE_SYS_TIME_H)
 message("HAVE_TIME_H ${HAVE_TIME_H}")
 CHECK_INCLUDE_FILE(errno.h HAVE_ERRNO_H)
 message("HAVE_ERRNO_H ${HAVE_ERRNO_H}")
@@ -249,9 +536,9 @@ SET(need_getline "#define SIMGRID_NEED_GETLINE 1")
 endif(RUN_RESULT_VAR MATCHES "FAILED_TO_RUN")
 
 ### check for a working snprintf
-CHECK_FUNCTION_EXISTS(snprintf SNPRINTF_FUNC)
-CHECK_FUNCTION_EXISTS(vsnprintf VSNPRINTF_FUNC)
-if(SNPRINTF_FUNC AND VSNPRINTF_FUNC)
+CHECK_FUNCTION_EXISTS(snprintf HAVE_SNPRINTF)
+CHECK_FUNCTION_EXISTS(vsnprintf HAVE_VSNPRINTF)
+if(HAVE_SNPRINTF AND HAVE_VSNPRINTF)
 
        try_run(RUN_SNPRINTF_FUNC_VAR COMPILE_SNPRINTF_FUNC_VAR
                ${PROJECT_DIRECTORY}
@@ -277,21 +564,45 @@ if(SNPRINTF_FUNC AND VSNPRINTF_FUNC)
                set(PREFER_PORTABLE_SNPRINTF 1)
        endif(RUN_VSNPRINTF_FUNC_VAR MATCHES "FAILED_TO_RUN" OR RUN_SNPRINTF_FUNC_VAR MATCHES "FAILED_TO_RUN")
        message("PREFER_PORTABLE_SNPRINTF ${PREFER_PORTABLE_SNPRINTF}")
-endif(SNPRINTF_FUNC AND VSNPRINTF_FUNC)
+endif(HAVE_SNPRINTF AND HAVE_VSNPRINTF)
 
 ### check for asprintf function familly
-CHECK_FUNCTION_EXISTS(asprintf ASPRINTF_FUNC)
-if(ASPRINTF_FUNC)
+CHECK_FUNCTION_EXISTS(asprintf HAVE_ASPRINTF)
+if(HAVE_ASPRINTF)
        SET(need_asprintf "")
-else(ASPRINTF_FUNC)
+else(HAVE_ASPRINTF)
        SET(need_asprintf "#define SIMGRID_NEED_ASPRINTF 1")
-endif(ASPRINTF_FUNC)
-CHECK_FUNCTION_EXISTS(vasprintf VASPRINTF_FUNC)
-if(VASPRINTF_FUNC)
+endif(HAVE_ASPRINTF)
+CHECK_FUNCTION_EXISTS(vasprintf HAVE_VASPRINTF)
+if(HAVE_VASPRINTF)
        SET(need_vasprintf "")
-else(VASPRINTF_FUNC)
+else(HAVE_VASPRINTF)
        SET(need_vasprintf "#define SIMGRID_NEED_VASPRINTF 1")
-endif(VASPRINTF_FUNC)
+endif(HAVE_VASPRINTF)
+
+### check for addr2line
 
+find_path(ADDR2LINE NAMES addr2line    PATHS NO_DEFAULT_PATHS  )
+if(ADDR2LINE)
+set(ADDR2LINE "${ADDR2LINE}/addr2line")
+endif(ADDR2LINE)
+find_program(ADDR2LINE NAMES addr2line)
+
+### check for include files and fct
+CHECK_INCLUDE_FILE(dlfcn.h HAVE_DLFCN_H)
+CHECK_INCLUDE_FILE(inttypes.h HAVE_INTTYPES_H)
+CHECK_INCLUDE_FILE(memory.h HAVE_MEMORY_H)
+CHECK_INCLUDE_FILE(stdlib.h HAVE_STDLIB_H)
+CHECK_INCLUDE_FILE(strings.h HAVE_STRINGS_H)
+CHECK_INCLUDE_FILE(string.h HAVE_STRING_H)
+
+### File to create
+
+configure_file(${PROJECT_DIRECTORY}/src/context_sysv_config.h.in ${PROJECT_DIRECTORY}/src/context_sysv_config.h)
+
+SET( CMAKEDEFINE "#cmakedefine" )
+configure_file("${PROJECT_DIRECTORY}/CPACK/tmp/test_gras_config.h.in" "${PROJECT_DIRECTORY}/CPACK/tmp/test_gras_config_tmp.h.in" @ONLY IMMEDIATE)
+configure_file("${PROJECT_DIRECTORY}/CPACK/tmp/test_gras_config_tmp.h.in" "${PROJECT_DIRECTORY}/src/test_gras_config.h" @ONLY IMMEDIATE)
 configure_file(${PROJECT_DIRECTORY}/include/simgrid_config.h.in ${PROJECT_DIRECTORY}/include/simgrid_config.h)
+
 message("__END_GRAS_&_SIMGRID____\n")