Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Add new entry in Release_Notes.
[simgrid.git] / examples / smpi / CMakeLists.txt
1 # These tests are cpp (by default, we assume C code)
2 set(_replay_sources    ${CMAKE_CURRENT_SOURCE_DIR}/replay/replay.cpp)
3 set(_ampi_test_sources ${CMAKE_CURRENT_SOURCE_DIR}/ampi_test/ampi_test.cpp)
4
5 # These tests are only used when MC is actived
6 set(MC_tests bugged1 bugged2 only_send_deterministic mutual_exclusion sendsend)
7 foreach(x ${MC_tests})
8   if(NOT SIMGRID_HAVE_MC)
9     set(_${x}_disable 1)
10   endif()
11   set(_${x}_sources ${CMAKE_CURRENT_SOURCE_DIR}/mc/${x}.c)
12   set(_${x}_outdir  ${CMAKE_CURRENT_BINARY_DIR}/mc)
13 endforeach()
14
15 # Compute the default for all configurations, and add all source files to the archive
16 foreach(x ampi_test trace trace_simple trace_call_location energy gemm simple-execute replay ${MC_tests})
17   if(NOT DEFINED _${x}_sources)
18     set(_${x}_sources ${CMAKE_CURRENT_SOURCE_DIR}/${x}/${x}.c)
19   endif()
20   if(NOT DEFINED _${x}_outdir)
21     set(_${x}_outdir  ${CMAKE_CURRENT_BINARY_DIR}/${x})
22   endif()
23
24   set(examples_src  ${examples_src}  ${_${x}_sources})
25 endforeach()
26 set(examples_src  ${examples_src}  PARENT_SCOPE)
27
28 # Compile the binaries, but only when everything is activated
29 if(enable_smpi)
30   set(CMAKE_C_COMPILER "${CMAKE_BINARY_DIR}/smpi_script/bin/smpicc")
31   set(CMAKE_CXX_COMPILER "${CMAKE_BINARY_DIR}/smpi_script/bin/smpicxx")
32   include_directories(BEFORE "${CMAKE_HOME_DIRECTORY}/include/smpi")
33
34   file(MAKE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/mc/")
35
36   foreach(x ampi_test trace trace_simple trace_call_location energy gemm simple-execute replay ${MC_tests})
37
38     if(NOT DEFINED _${x}_disable)
39       add_executable       (smpi_${x} EXCLUDE_FROM_ALL ${_${x}_sources})
40       target_link_libraries(smpi_${x} simgrid)
41       set_target_properties(smpi_${x} PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${_${x}_outdir})
42       add_dependencies(tests smpi_${x})
43     endif()
44   endforeach()
45
46   set_target_properties(smpi_trace_call_location PROPERTIES COMPILE_FLAGS "-trace-call-location")
47 endif()
48
49 unset(_${x}_sources)
50 unset(_${x}_disable)
51 unset(_${x}_outdir)
52
53 set(tesh_files    ${tesh_files}    ${CMAKE_CURRENT_SOURCE_DIR}/energy/energy.tesh
54                                    ${CMAKE_CURRENT_SOURCE_DIR}/trace/trace.tesh
55                                    ${CMAKE_CURRENT_SOURCE_DIR}/simple-execute/simple-execute.tesh
56                                    ${CMAKE_CURRENT_SOURCE_DIR}/simple-execute/simple-execute-cpp-platf.tesh
57                                    ${CMAKE_CURRENT_SOURCE_DIR}/gemm/gemm.tesh
58                                    ${CMAKE_CURRENT_SOURCE_DIR}/trace_simple/trace_simple.tesh
59                                    ${CMAKE_CURRENT_SOURCE_DIR}/trace_call_location/trace_call_location.tesh
60                                    ${CMAKE_CURRENT_SOURCE_DIR}/ampi_test/ampi_test.tesh
61                                    ${CMAKE_CURRENT_SOURCE_DIR}/mc/only_send_deterministic.tesh
62                                    ${CMAKE_CURRENT_SOURCE_DIR}/mc/sendsend.tesh
63                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/replay-override-replayer.tesh
64                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/replay.tesh                          PARENT_SCOPE)
65 set(bin_files     ${bin_files}     ${CMAKE_CURRENT_SOURCE_DIR}/hostfile
66                                    ${CMAKE_CURRENT_SOURCE_DIR}/energy/hostfile
67                                    ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_bugged1
68                                    ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_bugged2
69                                    ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_only_send_deterministic
70                                    ${CMAKE_CURRENT_SOURCE_DIR}/mc/hostfile_mutual_exclusion
71                                    ${CMAKE_CURRENT_SOURCE_DIR}/simple-execute/hostfile_griffon             PARENT_SCOPE)
72 set(txt_files     ${txt_files}     ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions0.txt
73                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions1.txt
74                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_allreduce.txt
75                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_allgatherv.txt
76                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_alltoall.txt
77                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_alltoallv.txt
78                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_barrier.txt
79                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_bcast.txt
80                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_bcast_reduce_datatypes.txt
81                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_gather.txt
82                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_reducescatter.txt
83                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_waitall.txt
84                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/actions_with_isend.txt
85                                    ${CMAKE_CURRENT_SOURCE_DIR}/replay/split_traces
86                                    ${CMAKE_CURRENT_SOURCE_DIR}/trace_call_location/adjust                  PARENT_SCOPE)
87
88 if(enable_smpi)
89   # MC is currently broken with threads (deadlock => timeout)
90   if(SIMGRID_HAVE_MC)
91     add_dependencies(tests-mc smpimain)
92     add_dependencies(tests-mc smpi_only_send_deterministic)
93     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)
94     add_dependencies(tests-mc smpi_sendsend)
95     ADD_TESH_FACTORIES(smpi-mc-sendsend "^thread" --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)
96   endif()
97
98   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)
99   if(enable_debug)
100     ADD_TESH(smpi-simple-execute       --setenv bindir=${CMAKE_BINARY_DIR}/examples/smpi/simple-execute --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi/simple-execute --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/examples/smpi/simple-execute ${CMAKE_HOME_DIRECTORY}/examples/smpi/simple-execute/simple-execute.tesh)
101     ADD_TESH(smpi-simple-execute-cpp-platf       --setenv bindir=${CMAKE_BINARY_DIR}/examples/smpi/simple-execute --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/smpi/simple-execute --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --setenv libdir=${CMAKE_BINARY_DIR}/lib --cd ${CMAKE_BINARY_DIR}/examples/smpi/simple-execute ${CMAKE_HOME_DIRECTORY}/examples/smpi/simple-execute/simple-execute-cpp-platf.tesh)
102   else()
103     message("-- Examples smpi-simple-execute disabled (built without debug).")
104   endif()
105   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)
106   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)
107   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)
108   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)
109   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)
110   ADD_TESH_FACTORIES(smpi-energy "*" --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)
111
112   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)
113 endif()