X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/e4abd3f271729beeff499da36267bfb274dd1f6d..3f39df9e2a9e798f07a880c9a03ec8fe20dabe79:/buildtools/Cmake/MakeLib.cmake diff --git a/buildtools/Cmake/MakeLib.cmake b/buildtools/Cmake/MakeLib.cmake index 92ebff7d6f..2f46f6d2ac 100644 --- a/buildtools/Cmake/MakeLib.cmake +++ b/buildtools/Cmake/MakeLib.cmake @@ -3,11 +3,8 @@ ############################### # Declare the library content # ############################### -# If we want supernovae, rewrite the libs' content to use it -include(${CMAKE_HOME_DIRECTORY}/buildtools/Cmake/Supernovae.cmake) # Actually declare our libraries - add_library(simgrid SHARED ${simgrid_sources}) set_target_properties(simgrid PROPERTIES VERSION ${libsimgrid_version}) @@ -15,39 +12,55 @@ if(enable_lib_static) add_library(simgrid_static STATIC ${simgrid_sources}) endif() -if(enable_smpi) - add_library(smpi SHARED ${SMPI_SRC}) - set_target_properties(smpi PROPERTIES VERSION ${libsmpi_version}) - if(enable_lib_static) - add_library(smpi_static STATIC ${SMPI_SRC}) - endif() +if(enable_ust) + ADD_DEPENDENCIES(simgrid simgrid_ust) endif() -add_dependencies(simgrid maintainer_files) +if(enable_java) + include(${CMAKE_HOME_DIRECTORY}/buildtools/Cmake/MakeJava.cmake) +endif() -# if supernovaeing, we need some depends to make sure that the source gets generated -if (enable_supernovae) - add_dependencies(simgrid ${CMAKE_CURRENT_BINARY_DIR}/src/supernovae_sg.c) - if(enable_lib_static) - add_dependencies(simgrid_static ${CMAKE_CURRENT_BINARY_DIR}/src/supernovae_sg.c) - endif() +add_dependencies(simgrid maintainer_files) - if(enable_smpi) - add_dependencies(smpi ${CMAKE_CURRENT_BINARY_DIR}/src/supernovae_smpi.c) - if(enable_lib_static) - add_dependencies(smpi_static ${CMAKE_CURRENT_BINARY_DIR}/src/supernovae_smpi.c) - endif() - endif() +if(enable_model-checking) + add_executable(simgrid-mc ${MC_SIMGRID_MC_SRC}) + target_link_libraries(simgrid-mc simgrid) + set_target_properties(simgrid-mc + PROPERTIES + RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin") endif() # Compute the dependencies of SimGrid ##################################### -set(SIMGRID_DEP "-lm -lpcre") +set(SIMGRID_DEP "-lm") +if (HAVE_BOOST_CONTEXT) + set(SIMGRID_DEP "${SIMGRID_DEP} ${Boost_CONTEXT_LIBRARY}") +endif() -if(pthread) - if(${CONTEXT_THREADS}) - SET(SIMGRID_DEP "${SIMGRID_DEP} -pthread") - endif() +if(${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD" + AND NOT ${CMAKE_SYSTEM_VERSION} VERSION_LESS 10.0 + AND ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang") + # FreeBSD from 10.0 provide a internal C++ stack (unused by gcc) + # see https://wiki.freebsd.org/NewC%2B%2BStack + set(SIMGRID_DEP "${SIMGRID_DEP} -lc++") +elseif(${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD" + AND ${CMAKE_SYSTEM_VERSION} VERSION_LESS 10.0 + AND ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang") + # FreeBSD prior to 10.0 does not necessarily have a compiler + # installed that is capable of c++11! Hence, we just assume + # here that libc++ was compiled. + # FIXME: We should change this behavior; we may want to include + # an option of whether libc++ (clang++) or libstdc++ (g++) + # should be used. + include_directories( "/usr/local/include/c++/v1") + set(SIMGRID_DEP "${SIMGRID_DEP} -lc++ -L/usr/local/lib ") +else() + set(SIMGRID_DEP "${SIMGRID_DEP} -lstdc++") +endif() + +if(pthread AND ${CONTEXT_THREADS} AND NOT APPLE) + # Clang on recent Mac OS X is not happy about -pthread. + SET(SIMGRID_DEP "${SIMGRID_DEP} -pthread") endif() if(HAVE_LUA) @@ -86,6 +99,10 @@ if(HAVE_GRAPHVIZ) endif() endif() +if(HAVE_LIBSIGC++) + SET(SIMGRID_DEP "${SIMGRID_DEP} -lsigc-2.0") +endif() + if(HAVE_GTNETS) SET(SIMGRID_DEP "${SIMGRID_DEP} -lgtnets") endif() @@ -93,56 +110,63 @@ endif() if(HAVE_MC) # The availability of libunwind was checked in CompleteInFiles.cmake # (that includes FindLibunwind.cmake), so simply load it now. - + + SET(SIMGRID_DEP "${SIMGRID_DEP} -lunwind -lunwind-ptrace") + + # Same for libdw + SET(SIMGRID_DEP "${SIMGRID_DEP} -ldw") # This supposes that the host machine is either an AMD or a X86. # This is deeply wrong, and should be fixed by manually loading -lunwind-PLAT (FIXME) if(PROCESSOR_x86_64) SET(SIMGRID_DEP "${SIMGRID_DEP} -lunwind-x86_64") - else() + else() SET(SIMGRID_DEP "${SIMGRID_DEP} -lunwind-x86") endif() endif() +if(MMALLOC_WANT_OVERRIDE_LEGACY AND HAVE_GNU_LD) + SET(SIMGRID_DEP "${SIMGRID_DEP} ${DL_LIBRARY}") +endif() + if(HAVE_NS3) - if(${NS3_VERSION} EQUAL 310) - SET(SIMGRID_DEP "${SIMGRID_DEP} -lns3") - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -D_NS3_3_10") - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -D_NS3_3_10") - else() - SET(SIMGRID_DEP "${SIMGRID_DEP} -lns3-core -lns3-csma -lns3-point-to-point -lns3-internet -lns3-applications") - endif() + SET(SIMGRID_DEP "${SIMGRID_DEP} -lns${NS3_VERSION}-core -lns${NS3_VERSION}-csma -lns${NS3_VERSION}-point-to-point -lns${NS3_VERSION}-internet -lns${NS3_VERSION}-applications") endif() if(HAVE_POSIX_GETTIME) SET(SIMGRID_DEP "${SIMGRID_DEP} -lrt") endif() -target_link_libraries(simgrid ${SIMGRID_DEP}) +if(HAVE_BACKTRACE_IN_LIBEXECINFO) + SET(SIMGRID_DEP "${SIMGRID_DEP} -lexecinfo") +endif(HAVE_BACKTRACE_IN_LIBEXECINFO) + +# Dependencies from USR +################################### +if(enable_ust) + set(SIMGRID_DEP "${SIMGRID_DEP} -llttng-ust") +endif() # Compute the dependencies of SMPI ################################## -set(SMPI_DEP "") -if(APPLE) - set(SMPI_DEP "-Wl,-U -Wl,_smpi_simulated_main") -endif() -if(enable_smpi) - target_link_libraries(smpi simgrid ${SMPI_DEP}) +if(enable_smpi AND APPLE) + set(SIMGRID_DEP "${SIMGRID_DEP} -Wl,-U -Wl,_smpi_simulated_main") endif() +target_link_libraries(simgrid ${SIMGRID_DEP}) + # Pass dependencies to static libs ################################## if(enable_lib_static) target_link_libraries(simgrid_static ${SIMGRID_DEP}) add_dependencies(simgrid_static maintainer_files) set_target_properties(simgrid_static PROPERTIES OUTPUT_NAME simgrid) - if(enable_smpi) - target_link_libraries(smpi_static simgrid ${SMPI_DEP}) - set_target_properties(smpi_static PROPERTIES OUTPUT_NAME smpi) - endif() endif() # Dependencies from maintainer mode ################################### +if(enable_maintainer_mode AND PYTHON_EXE) + add_dependencies(simgrid simcalls_generated_src) +endif() if(enable_maintainer_mode AND BISON_EXE AND LEX_EXE) add_dependencies(simgrid automaton_generated_src) endif()