X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/81c571783673c794dfd12682a5b9db490cff2a99..adf98c6a0e238415244f5abad4a16710baa44a13:/tools/cmake/MakeLib.cmake diff --git a/tools/cmake/MakeLib.cmake b/tools/cmake/MakeLib.cmake index ce355d31dd..debbe95c7b 100644 --- a/tools/cmake/MakeLib.cmake +++ b/tools/cmake/MakeLib.cmake @@ -10,7 +10,7 @@ if(APPLE) # add the current location of libsimgrid-java.dynlib as a location for libsimgrid.dynlib # (useful when unpacking the native libraries from the jarfile) - set(CMAKE_INSTALL_RPATH "${CMAKE_INSTALL_PREFIX}/lib") + set(CMAKE_INSTALL_RPATH "${CMAKE_INSTALL_FULL_LIBDIR}") endif() ############################### @@ -34,24 +34,33 @@ if(enable_model-checking) set_property(TARGET simgrid-mc APPEND PROPERTY INCLUDE_DIRECTORIES "${INTERNAL_INCLUDES}") install(TARGETS simgrid-mc # install that binary without breaking the rpath on Mac - RUNTIME DESTINATION bin/) + RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}/) + add_dependencies(tests simgrid-mc) endif() # Compute the dependencies of SimGrid ##################################### # search for dlopen -if("${CMAKE_SYSTEM_NAME}" MATCHES "kFreeBSD|Linux") +if("${CMAKE_SYSTEM_NAME}" MATCHES "kFreeBSD|Linux|SunOS") find_library(DL_LIBRARY dl) endif() mark_as_advanced(DL_LIBRARY) if (HAVE_BOOST_CONTEXTS) - set(SIMGRID_DEP "${SIMGRID_DEP} ${Boost_CONTEXT_LIBRARY}") + target_link_libraries(simgrid ${Boost_CONTEXT_LIBRARY}) +endif() + +if (HAVE_BOOST_STACKTRACE_BACKTRACE) + target_link_libraries(simgrid ${Boost_STACKTRACE_BACKTRACE_LIBRARY}) +endif() + +if (HAVE_BOOST_ADDR2LINE_BACKTRACE) + target_link_libraries(simgrid ${Boost_STACKTRACE_ADDR2LINE_LIBRARY}) endif() if(CMAKE_USE_PTHREADS_INIT) - set(SIMGRID_DEP "${SIMGRID_DEP} ${CMAKE_THREAD_LIBS_INIT}") + target_link_libraries(simgrid ${CMAKE_THREAD_LIBS_INIT}) endif() if(SIMGRID_HAVE_LUA) @@ -100,16 +109,16 @@ if(enable_smpi) set_target_properties(smpimain PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib/simgrid) install(TARGETS smpimain # install that binary without breaking the rpath on Mac - RUNTIME DESTINATION lib/simgrid) + RUNTIME DESTINATION ${CMAKE_INSTALL_LIBDIR}/simgrid) add_dependencies(tests smpimain) add_executable(smpireplaymain src/smpi/smpi_replay_main.cpp) target_compile_options(smpireplaymain PRIVATE -fpic) - target_link_libraries(smpireplaymain simgrid -shared) + target_link_libraries(smpireplaymain simgrid -fpic -shared) set_target_properties(smpireplaymain PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib/simgrid) install(TARGETS smpireplaymain # install that binary without breaking the rpath on Mac - RUNTIME DESTINATION lib/simgrid) + RUNTIME DESTINATION ${CMAKE_INSTALL_LIBDIR}/simgrid) add_dependencies(tests smpireplaymain) if(SMPI_FORTRAN) @@ -121,9 +130,12 @@ if(enable_smpi) SET(SIMGRID_DEP "${SIMGRID_DEP} -lflang") if("${CMAKE_SYSTEM}" MATCHES "FreeBSD") set(SIMGRID_DEP "${SIMGRID_DEP} -lexecinfo") - if ("${CMAKE_SYSTEM_VERSION}" MATCHES "12") + if ("${CMAKE_SYSTEM_VERSION}" STRGREATER_EQUAL "12") set(SIMGRID_DEP "${SIMGRID_DEP} -lpgmath") endif() + if ("${CMAKE_SYSTEM_VERSION}" MATCHES "12\.1") + set(SIMGRID_DEP "${SIMGRID_DEP} -lomp") + endif() endif() endif() endif() @@ -156,7 +168,7 @@ endif() mark_as_advanced(GCCLIBATOMIC_LIBRARY) if(enable_model-checking AND (NOT LINKER_VERSION VERSION_LESS "2.30")) - set(SIMGRID_DEP "${SIMGRID_DEP} -Wl,-znoseparate-code") + set(SIMGRID_DEP "${SIMGRID_DEP} -Wl,-znorelro -Wl,-znoseparate-code") endif() target_link_libraries(simgrid ${SIMGRID_DEP})