Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
convert (and simplify a bit) dht-kademlia example
[simgrid.git] / examples / c / CMakeLists.txt
1 # Regular examples: with only one source and tested with all factories
2 ######################################################################
3
4 foreach(x
5         actor-create actor-daemon actor-exiting actor-join actor-kill actor-lifetime actor-migrate actor-stacksize
6         actor-suspend actor-yield
7         app-masterworker app-pingpong app-token-ring 
8         async-wait async-waitall async-waitany
9         cloud-capping cloud-masterworker cloud-migration cloud-simple
10         exec-async exec-basic exec-dvfs exec-remote exec-waitany
11         energy-exec energy-exec-ptask energy-vm
12         io-disk-raw io-file-remote
13         platform-failures platform-properties
14         plugin-hostload)
15   add_executable       (${x}-c EXCLUDE_FROM_ALL ${x}/${x}.c)
16   target_link_libraries(${x}-c simgrid)
17   set_target_properties(${x}-c PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${x})
18   add_dependencies(tests ${x}-c)
19
20   set(tesh_files    ${tesh_files}    ${CMAKE_CURRENT_SOURCE_DIR}/${x}/${x}.tesh)
21   set(teshsuite_src ${teshsuite_src} ${CMAKE_CURRENT_SOURCE_DIR}/${x}/${x}.c)
22 endforeach()
23
24 # Multi-files examples
25 ######################
26 # Chainsend example
27
28 add_executable       (app-chainsend-c EXCLUDE_FROM_ALL app-chainsend/chainsend.c app-chainsend/broadcaster.c 
29                       app-chainsend/peer.c)
30 target_link_libraries(app-chainsend-c simgrid)
31 set_target_properties(app-chainsend-c PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/app-chainsend)
32 add_dependencies(tests app-chainsend-c)
33
34 foreach (file chainsend broadcaster peer)
35   set(teshsuite_src  ${teshsuite_src}  ${CMAKE_CURRENT_SOURCE_DIR}/app-chainsend/${file}.c)
36 endforeach()
37 set(teshsuite_src ${teshsuite_src} ${CMAKE_CURRENT_SOURCE_DIR}/app-chainsend/chainsend.h)
38
39 #DHT-Kademlia
40 add_executable       (dht-kademlia-c EXCLUDE_FROM_ALL dht-kademlia/dht-kademlia.c dht-kademlia/node.c dht-kademlia/routing_table.c dht-kademlia/message.c dht-kademlia/answer.c)
41 target_link_libraries(dht-kademlia-c simgrid)
42 set_target_properties(dht-kademlia-c PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/dht-kademlia)
43 add_dependencies(tests dht-kademlia-c)
44
45 foreach (file answer node routing_table message)
46   set(examples_src  ${examples_src}  ${CMAKE_CURRENT_SOURCE_DIR}/dht-kademlia/${file}.c  ${CMAKE_CURRENT_SOURCE_DIR}/dht-kademlia/${file}.h)
47 endforeach()
48
49 # Add all extra files to the archive
50 ####################################
51
52 set(teshsuite_src ${teshsuite_src}  PARENT_SCOPE)
53 set(tesh_files    ${tesh_files} ${CMAKE_CURRENT_SOURCE_DIR}/app-chainsend/app-chainsend.tesh
54                                 ${CMAKE_CURRENT_SOURCE_DIR}/app-masterworker/app-masterworker-multicore.tesh
55                                 ${CMAKE_CURRENT_SOURCE_DIR}/app-masterworker/app-masterworker-vivaldi.tesh
56                                 ${CMAKE_CURRENT_SOURCE_DIR}/dht-kademlia/dht-kademlia.tesh
57                                 PARENT_SCOPE)
58 set(bin_files     ${bin_files} ${CMAKE_CURRENT_SOURCE_DIR}/dht-kademlia/generate.py                        PARENT_SCOPE)
59 set(examples_src  ${examples_src} ${CMAKE_CURRENT_SOURCE_DIR}/dht-kademlia/common.h
60                                   ${CMAKE_CURRENT_SOURCE_DIR}/dht-kademlia/dht-kademlia.c                  PARENT_SCOPE)
61 set(xml_files     ${xml_files} ${CMAKE_CURRENT_SOURCE_DIR}/actor-create/actor-create_d.xml
62                                ${CMAKE_CURRENT_SOURCE_DIR}/actor-lifetime/actor-lifetime_d.xml
63                                ${CMAKE_CURRENT_SOURCE_DIR}/actor-yield/actor-yield_d.xml
64                                ${CMAKE_CURRENT_SOURCE_DIR}/app-chainsend/app-chainsend_d.xml
65                                ${CMAKE_CURRENT_SOURCE_DIR}/app-masterworker/app-masterworker_d.xml
66                                ${CMAKE_CURRENT_SOURCE_DIR}/app-masterworker/app-masterworker-multicore_d.xml
67                                ${CMAKE_CURRENT_SOURCE_DIR}/app-masterworker/app-masterworker-vivaldi_d.xml
68                                ${CMAKE_CURRENT_SOURCE_DIR}/app-pingpong/app-pingpong_d.xml
69                                ${CMAKE_CURRENT_SOURCE_DIR}/async-wait/async-wait_d.xml
70                                ${CMAKE_CURRENT_SOURCE_DIR}/async-wait/async-wait2_d.xml
71                                ${CMAKE_CURRENT_SOURCE_DIR}/async-wait/async-wait3_d.xml
72                                ${CMAKE_CURRENT_SOURCE_DIR}/async-wait/async-wait4_d.xml
73                                ${CMAKE_CURRENT_SOURCE_DIR}/async-waitall/async-waitall_d.xml
74                                ${CMAKE_CURRENT_SOURCE_DIR}/async-waitany/async-waitany_d.xml
75                                ${CMAKE_CURRENT_SOURCE_DIR}/dht-kademlia/dht-kademlia_d.xml
76                                ${CMAKE_CURRENT_SOURCE_DIR}/io-file-remote/io-file-remote_d.xml
77                                ${CMAKE_CURRENT_SOURCE_DIR}/platform-properties/platform-properties_d.xml
78                                PARENT_SCOPE)
79
80 foreach(x
81         actor-create actor-daemon actor-exiting actor-join actor-kill actor-lifetime actor-migrate actor-stacksize
82         actor-suspend actor-yield
83         app-chainsend app-masterworker app-pingpong app-token-ring
84         async-wait async-waitall async-waitany
85         cloud-capping  cloud-masterworker cloud-migration cloud-simple
86         exec-async exec-basic exec-dvfs exec-remote exec-waitany
87         energy-exec energy-exec-ptask energy-vm
88         io-disk-raw io-file-remote
89         platform-failures platform-properties
90         plugin-hostload)
91   ADD_TESH(c-${x} --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms
92                   --setenv bindir=${CMAKE_BINARY_DIR}/examples/c/${x}
93                   --cd ${CMAKE_HOME_DIRECTORY}/examples/c/${x}
94                   ${CMAKE_HOME_DIRECTORY}/examples/c/${x}/${x}.tesh)
95 endforeach()
96
97 ADD_TESH_FACTORIES(app-masterworker-multicore   "thread;ucontext;raw;boost" 
98                                                 --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/c/app-masterworker 
99                                                 --setenv bindir=${CMAKE_BINARY_DIR}/examples/c/app-masterworker
100                                                 --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms
101                                                ${CMAKE_HOME_DIRECTORY}/examples/c/app-masterworker/app-masterworker-multicore.tesh)
102 ADD_TESH_FACTORIES(app-masterworker-vivaldi     "thread;ucontext;raw;boost" 
103                                                 --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/c/app-masterworker 
104                                                 --setenv bindir=${CMAKE_BINARY_DIR}/examples/c/app-masterworker
105                                                 --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms
106                                                 ${CMAKE_HOME_DIRECTORY}/examples/c/app-masterworker/app-masterworker-vivaldi.tesh)
107 ADD_TESH_FACTORIES(c-dht-kademlia "thread;ucontext;raw;boost" 
108                                   --setenv bindir=${CMAKE_BINARY_DIR}/examples/c/dht-kademlia
109                                   --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/c/dht-kademlia 
110                                   --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms 
111                                   ${CMAKE_HOME_DIRECTORY}/examples/c/dht-kademlia/dht-kademlia.tesh)
112
113 if(CMAKE_SYSTEM_NAME STREQUAL "SunOS" AND CMAKE_SYSTEM_PROCESSOR STREQUAL "i386" AND CMAKE_SIZEOF_VOID_P EQUAL 8)
114     # Thread-local storage (TLS) is needed for parallel execution, but it doesn't
115     # play well with Ucontexts on 64bit SunOS (at least on x86_64).
116     set(parallel-factories "thread;raw;boost")
117 else()
118     set(parallel-factories "thread;ucontext;raw;boost")
119 endif()
120
121 ADD_TESH_FACTORIES(c-dht-kademlia-parallel "${parallel-factories}" --cfg contexts/nthreads:4 ${CONTEXTS_SYNCHRO}
122                                            --setenv bindir=${CMAKE_BINARY_DIR}/examples/c/dht-kademlia
123                                            --setenv srcdir=${CMAKE_HOME_DIRECTORY}/examples/c/dht-kademlia
124                                            --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms
125                                            ${CMAKE_HOME_DIRECTORY}/examples/c/dht-kademlia/dht-kademlia.tesh)