Logo AND Algorithmique Numérique Distribuée

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