-cmake_minimum_required(VERSION 2.6)
-
if(enable_smpi)
- if(WIN32)
- set(CMAKE_C_FLAGS "-include ${CMAKE_HOME_DIRECTORY}/include/smpi/smpi_main.h")
- else()
- set(CMAKE_C_COMPILER "${CMAKE_BINARY_DIR}/smpi_script/bin/smpicc")
- endif()
-
- set(EXECUTABLE_OUTPUT_PATH "${CMAKE_CURRENT_BINARY_DIR}")
+ set(CMAKE_C_COMPILER "${CMAKE_BINARY_DIR}/smpi_script/bin/smpicc")
+ set(CMAKE_CXX_COMPILER "${CMAKE_BINARY_DIR}/smpi_script/bin/smpicxx")
+ include_directories(BEFORE "${CMAKE_HOME_DIRECTORY}/include/smpi")
- include_directories("${CMAKE_HOME_DIRECTORY}/include/smpi")
file(MAKE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/mc/")
+ foreach(x replay ampi_test trace trace_simple trace_call_location energy gemm)
+ add_executable (smpi_${x} EXCLUDE_FROM_ALL ${CMAKE_CURRENT_SOURCE_DIR}/${x}/${x})
+ target_link_libraries(smpi_${x} simgrid)
+ set_target_properties(smpi_${x} PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${x})
+ add_dependencies(tests smpi_${x})
+ endforeach()
- add_executable(bcbench bcbench.c)
- add_executable(mvmul mvmul.c)
- add_executable(smpi_traced tracing/smpi_traced.c)
- add_executable(smpi_traced_simple tracing/smpi_traced_simple.c)
- add_executable(smpi_replay replay/replay.c)
+ set_target_properties(smpi_trace_call_location PROPERTIES COMPILE_FLAGS "-trace-call-location")
+
+ foreach(x bugged1 bugged2 bugged1_liveness only_send_deterministic mutual_exclusion non_termination1
+ non_termination2 non_termination3 non_termination4 sendsend)
+ if(SIMGRID_HAVE_MC)
+ add_executable (smpi_${x} EXCLUDE_FROM_ALL ${CMAKE_CURRENT_SOURCE_DIR}/mc/${x}.c)
+ target_link_libraries(smpi_${x} simgrid)
+ set_target_properties(smpi_${x} PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/mc)
+ add_dependencies(tests smpi_${x})
+ endif()
+ endforeach()
+endif()
- target_link_libraries(bcbench simgrid)
- target_link_libraries(mvmul simgrid)
- target_link_libraries(smpi_traced simgrid)
- target_link_libraries(smpi_traced_simple simgrid)
- target_link_libraries(smpi_replay simgrid)
+foreach(x ampi_test replay)
+ set(examples_src ${examples_src} ${CMAKE_CURRENT_SOURCE_DIR}/${x}/${x}.cpp)
+endforeach()
+foreach(x trace trace_simple trace_call_location energy gemm)
+ set(examples_src ${examples_src} ${CMAKE_CURRENT_SOURCE_DIR}/${x}/${x}.c)
+endforeach()
+foreach(x bugged1 bugged2 bugged1_liveness only_send_deterministic mutual_exclusion non_termination1
+ non_termination2 non_termination3 non_termination4 sendsend)
+ set(examples_src ${examples_src} ${CMAKE_CURRENT_SOURCE_DIR}/mc/${x}.c)
+endforeach()
- if(HAVE_MC)
- add_executable(smpi_bugged1 mc/bugged1.c)
- add_executable(smpi_bugged2 mc/bugged2.c)
- add_executable(smpi_bugged1_liveness mc/bugged1_liveness.c)
- add_executable(smpi_send_deterministic mc/send_deterministic.c)
- add_executable(smpi_non_deterministic mc/non_deterministic.c)
- add_executable(smpi_mutual_exclusion mc/mutual_exclusion.c)
+set(examples_src ${examples_src} PARENT_SCOPE)
+set(tesh_files ${tesh_files} ${CMAKE_CURRENT_SOURCE_DIR}/energy/energy.tesh
+ ${CMAKE_CURRENT_SOURCE_DIR}/trace/trace.tesh
+ ${CMAKE_CURRENT_SOURCE_DIR}/gemm/gemm.tesh
+ ${CMAKE_CURRENT_SOURCE_DIR}/trace_simple/trace_simple.tesh
+ ${CMAKE_CURRENT_SOURCE_DIR}/trace_call_location/trace_call_location.tesh
+ ${CMAKE_CURRENT_SOURCE_DIR}/ampi_test/ampi_test.tesh
+ ${CMAKE_CURRENT_SOURCE_DIR}/mc/sendsend.tesh
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/replay-override-replayer.tesh
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/replay.tesh PARENT_SCOPE)
+set(bin_files ${bin_files} ${CMAKE_CURRENT_SOURCE_DIR}/hostfile
+ ${CMAKE_CURRENT_SOURCE_DIR}/energy/hostfile
+ ${CMAKE_CURRENT_SOURCE_DIR}/mc/promela_bugged1_liveness
+ ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_bugged1_liveness
+ ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_bugged1
+ ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_bugged2
+ ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_only_send_deterministic
+ ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_mutual_exclusion
+ ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_non_termination PARENT_SCOPE)
+set(txt_files ${txt_files} ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions0.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions1.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_allreduce.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_allgatherv.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_alltoall.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_alltoallv.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_barrier.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_bcast.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_bcast_reduce_datatypes.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_gather.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_reducescatter.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_waitall.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_with_isend.txt
+ ${CMAKE_CURRENT_SOURCE_DIR}/replay/split_traces
+ ${CMAKE_CURRENT_SOURCE_DIR}/trace_call_location/adjust PARENT_SCOPE)
- target_link_libraries(smpi_bugged1 simgrid)
- target_link_libraries(smpi_bugged2 simgrid)
- target_link_libraries(smpi_bugged1_liveness simgrid)
- target_link_libraries(smpi_send_deterministic simgrid)
- target_link_libraries(smpi_non_deterministic simgrid)
- target_link_libraries(smpi_mutual_exclusion simgrid)
-
- set_target_properties(smpi_bugged1 PROPERTIES RUNTIME_OUTPUT_DIRECTORY "./mc")
- set_target_properties(smpi_bugged2 PROPERTIES RUNTIME_OUTPUT_DIRECTORY "./mc")
- set_target_properties(smpi_bugged1_liveness PROPERTIES RUNTIME_OUTPUT_DIRECTORY "./mc")
- set_target_properties(smpi_send_deterministic PROPERTIES RUNTIME_OUTPUT_DIRECTORY "./mc")
- set_target_properties(smpi_non_deterministic PROPERTIES RUNTIME_OUTPUT_DIRECTORY "./mc")
- set_target_properties(smpi_mutual_exclusion PROPERTIES RUNTIME_OUTPUT_DIRECTORY "./mc")
-
+if(enable_smpi)
+ # MC is currently broken with threads (deadlock => timeout)
+ if(SIMGRID_HAVE_MC)
+ ADD_TESH(smpi-mc-only-send-determinism --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi/mc --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/examples/smpi/mc ${CMAKE_HOME_DIRECTORY}/examples/smpi/mc/only_send_deterministic.tesh)
+ ADD_TESH_FACTORIES(smpi-mc-sendsend "ucontext;raw;boost" --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi/mc --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/examples/smpi/mc ${CMAKE_HOME_DIRECTORY}/examples/smpi/mc/sendsend.tesh)
endif()
-
-endif()
-set(tesh_files
- ${tesh_files}
- ${CMAKE_CURRENT_SOURCE_DIR}/tracing/smpi_traced.tesh
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/smpi_replay.tesh
- PARENT_SCOPE
- )
-set(xml_files
- ${xml_files}
- PARENT_SCOPE
- )
-set(examples_src
- ${examples_src}
- ${CMAKE_CURRENT_SOURCE_DIR}/mvmul.c
- ${CMAKE_CURRENT_SOURCE_DIR}/bcbench.c
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/replay.c
- ${CMAKE_CURRENT_SOURCE_DIR}/tracing/smpi_traced.c
- ${CMAKE_CURRENT_SOURCE_DIR}/tracing/smpi_traced_simple.c
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/bugged2.c
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/bugged1.c
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/bugged1_liveness.c
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/send_deterministic.c
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/non_deterministic.c
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/mutual_exclusion.c
- PARENT_SCOPE
- )
-set(bin_files
- ${bin_files}
- ${CMAKE_CURRENT_SOURCE_DIR}/hostfile
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/promela_bugged1_liveness
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_bugged1_liveness
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_bugged1
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_bugged2
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_send_deterministic
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_non_deterministic
- ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_mutual_exclusion
- PARENT_SCOPE
- )
-set(txt_files
- ${txt_files}
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions0.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions1.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_allReduce.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_allgatherv.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_alltoall.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_alltoallv.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_barrier.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_bcast.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_bcast_reduce_datatypes.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_gather.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_reducescatter.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_waitall.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_with_isend.txt
- ${CMAKE_CURRENT_SOURCE_DIR}/replay/split_traces
- PARENT_SCOPE
- )
+ ADD_TESH(smpi-tracing --setenv bindir=${CMAKE_BINARY_DIR}/examples/smpi/trace --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi/trace --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/examples/smpi/trace ${CMAKE_HOME_DIRECTORY}/examples/smpi/trace/trace.tesh)
+ ADD_TESH(smpi-tracing-simple --setenv bindir=${CMAKE_BINARY_DIR}/examples/smpi/trace_simple --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi/trace_simple --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/examples/smpi/trace_simple ${CMAKE_HOME_DIRECTORY}/examples/smpi/trace_simple/trace_simple.tesh)
+ ADD_TESH(smpi-tracing-call-location --setenv bindir=${CMAKE_BINARY_DIR}/examples/smpi/trace_call_location --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/examples/smpi/trace_call_location ${CMAKE_HOME_DIRECTORY}/examples/smpi/trace_call_location/trace_call_location.tesh)
+ ADD_TESH(smpi-replay --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/examples/smpi ${CMAKE_HOME_DIRECTORY}/examples/smpi/replay/replay.tesh)
+ ADD_TESH(smpi-replay-override-replayer --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/examples/smpi ${CMAKE_HOME_DIRECTORY}/examples/smpi/replay/replay-override-replayer.tesh)
+ ADD_TESH(smpi-gemm --setenv bindir=${CMAKE_BINARY_DIR}/examples/smpi/gemm --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi/gemm --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/examples/smpi/gemm ${CMAKE_HOME_DIRECTORY}/examples/smpi/gemm/gemm.tesh)
+ ADD_TESH_FACTORIES(smpi-energy "thread;ucontext;raw;boost" --setenv bindir=${CMAKE_BINARY_DIR}/examples/smpi/energy --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi/energy --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --setenv bindir=${CMAKE_BINARY_DIR}/bin --cd ${CMAKE_BINARY_DIR}/examples/smpi/energy ${CMAKE_HOME_DIRECTORY}/examples/smpi/energy/energy.tesh)
+
+ ADD_TESH(smpi-ampi --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/examples/smpi ${CMAKE_HOME_DIRECTORY}/examples/smpi/ampi_test/ampi_test.tesh)
+endif()