X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/674cedc307ed0fa88dd8480a07d03945d8ecd1fd..b7242b68db364ebb1e2b011d27528767384bdd85:/tools/cmake/MakeLib.cmake diff --git a/tools/cmake/MakeLib.cmake b/tools/cmake/MakeLib.cmake index 14bb922434..f937e5ac42 100644 --- a/tools/cmake/MakeLib.cmake +++ b/tools/cmake/MakeLib.cmake @@ -1,12 +1,12 @@ ### Make Libs -# On Mac OSX, specify that rpath is useful to look for the dependencies +# On macOS, specify that rpath is useful to look for the dependencies # See https://gitlab.kitware.com/cmake/community/wikis/doc/cmake/RPATH-handling and Java.cmake set(CMAKE_MACOSX_RPATH TRUE) if(APPLE) SET(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE) # When installed, use system path - set(CMAKE_SKIP_BUILD_RPATH FALSE) # When executing from build tree, take the lib from the build path if exists - set(CMAKE_BUILD_WITH_INSTALL_RPATH FALSE) # When executing from build tree, take the lib from the system path if exists + set(CMAKE_SKIP_BUILD_RPATH FALSE) # When executing from build tree, take the lib from the build path if exists + set(CMAKE_BUILD_WITH_INSTALL_RPATH FALSE) # When executing from build tree, take the lib from the system path if exists # add the current location of libsimgrid-java.dynlib as a location for libsimgrid.dynlib # (useful when unpacking the native libraries from the jarfile) @@ -34,7 +34,7 @@ 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 bin/) endif() @@ -77,7 +77,7 @@ if(HAVE_POSIX_GETTIME) SET(SIMGRID_DEP "${SIMGRID_DEP} -lrt") endif() -if("${CMAKE_SYSTEM}" MATCHES "FreeBSD") +if("${CMAKE_SYSTEM_NAME}" STREQUAL "FreeBSD") set(SIMGRID_DEP "${SIMGRID_DEP} -lprocstat") endif() @@ -88,12 +88,38 @@ if(enable_smpi) if(NOT ${DL_LIBRARY} STREQUAL "") set(SIMGRID_DEP "${SIMGRID_DEP} ${DL_LIBRARY}") # for privatization endif() + add_executable(smpimain src/smpi/smpi_main.c) target_link_libraries(smpimain simgrid) set_target_properties(smpimain - PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin) + PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib/simgrid) install(TARGETS smpimain # install that binary without breaking the rpath on Mac - RUNTIME DESTINATION bin/) + RUNTIME DESTINATION lib/simgrid) + + add_executable(smpireplaymain src/smpi/smpi_replay_main.cpp) + target_compile_options(smpireplaymain PRIVATE -fpic) + target_link_libraries(smpireplaymain simgrid -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) + + if(SMPI_FORTRAN) + if(CMAKE_Fortran_COMPILER_ID MATCHES "GNU") + SET(SIMGRID_DEP "${SIMGRID_DEP} -lgfortran") + elseif(CMAKE_Fortran_COMPILER_ID MATCHES "Intel") + SET(SIMGRID_DEP "${SIMGRID_DEP} -lifcore") + elseif(CMAKE_Fortran_COMPILER_ID MATCHES "PGI|Flang") + SET(SIMGRID_DEP "${SIMGRID_DEP} -lflang") + if("${CMAKE_SYSTEM}" MATCHES "FreeBSD") + set(SIMGRID_DEP "${SIMGRID_DEP} -lexecinfo") + if ("${CMAKE_SYSTEM_VERSION}" MATCHES "12") + set(SIMGRID_DEP "${SIMGRID_DEP} -lpgmath") + endif() + endif() + endif() + endif() + endif() if(enable_smpi AND APPLE) @@ -120,7 +146,7 @@ if(CMAKE_COMPILER_IS_GNUCC AND GCCLIBATOMIC_LIBRARY) set(SIMGRID_DEP "${SIMGRID_DEP} -Wl,--as-needed -latomic -Wl,--no-as-needed") endif() -if(enable_model-checking AND CMAKE_COMPILER_IS_GNUCC AND (NOT LINKER_VERSION VERSION_LESS "2.30")) +if(enable_model-checking AND (NOT LINKER_VERSION VERSION_LESS "2.30")) set(SIMGRID_DEP "${SIMGRID_DEP} -Wl,-znoseparate-code") endif()