annotate src/parallel_execution/CMakeLists.txt @ 401:408b4aab7610

Supported par goto iterate statement for perl script
author Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
date Tue, 29 Aug 2017 21:50:57 +0900
parents b81492c74d2b
children e958a409943c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
86
e06e1a9e569e create worker
Shohei KOKUBO <e105744@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 cmake_minimum_required(VERSION 2.8)
e06e1a9e569e create worker
Shohei KOKUBO <e105744@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
3 set(USE_CUDA,0)
101
8987cf13d5bb Add Allocate macro
innparusu
parents: 98
diff changeset
4 # -DUSE_CUDA
138
04a2f486a30d insert works but is not balanced
kono
parents: 137
diff changeset
5 # add_definitions("-Wall -g -O")
86
e06e1a9e569e create worker
Shohei KOKUBO <e105744@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6
131
a4507906938c Fix compile error but not work
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents: 117
diff changeset
7 set(CMAKE_C_COMPILER $ENV{CBC_COMPILER})
312
7dd5a7d52a67 USE_CUDAWorker flag only for CUDAtwice
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 308
diff changeset
8 add_definitions("-Wall -g")
7dd5a7d52a67 USE_CUDAWorker flag only for CUDAtwice
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 308
diff changeset
9
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
10
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
11 if (${USE_CUDA})
312
7dd5a7d52a67 USE_CUDAWorker flag only for CUDAtwice
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 308
diff changeset
12 include_directories("/usr/local/cuda/include")
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
13 set(NVCCFLAG "-std=c++11" "-g" "-O0" )
374
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
14 set(CUDA_LINK_FLAGS "-framework CUDA -lc++ -Wl,-search_paths_first -Wl,-headerpad_max_install_names /Developer/NVIDIA/CUDA-8.0/lib/libcudart_static.a -Wl,-rpath,/usr/local/cuda/lib")
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
15 find_package(CUDA REQUIRED)
305
ec0a5b4fba05 CUDAWorker
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 304
diff changeset
16 SET( CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${CUDA_LINK_FLAGS}" )
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
17 endif()
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
18
302
8e7926f3e271 fix CUDAWorker
ikkun
parents: 301
diff changeset
19
198
4051c012dec3 cmake macro
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 188
diff changeset
20 macro( GearsCommand )
4051c012dec3 cmake macro
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 188
diff changeset
21 set( _OPTIONS_ARGS )
4051c012dec3 cmake macro
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 188
diff changeset
22 set( _ONE_VALUE_ARGS TARGET )
4051c012dec3 cmake macro
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 188
diff changeset
23 set( _MULTI_VALUE_ARGS SOURCES )
4051c012dec3 cmake macro
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 188
diff changeset
24 cmake_parse_arguments( _Gears "${_OPTIONS_ARGS}" "${_ONE_VALUE_ARGS}" "${_MULTI_VALUE_ARGS}" ${ARGN} )
374
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
25
256
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
26 set (_Gears_CSOURCES)
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
27 foreach(i ${_Gears_SOURCES})
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
28 if (${i} MATCHES "\\.cbc")
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
29 string(REGEX REPLACE "(.*).cbc" "c/\\1.c" j ${i})
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
30 add_custom_command (
374
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
31 OUTPUT ${j}
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
32 DEPENDS ${i}
256
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
33 COMMAND "perl" "generate_stub.pl" "-o" ${j} ${i}
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
34 )
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
35 elseif (${i} MATCHES "\\.cu")
302
8e7926f3e271 fix CUDAWorker
ikkun
parents: 301
diff changeset
36 string(REGEX REPLACE "(.*).cu" "c/\\1.ptx" j ${i})
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
37 add_custom_command (
374
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
38 OUTPUT ${j}
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
39 DEPENDS ${i}
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
40 COMMAND nvcc ${NVCCFLAG} -c -ptx -o ${j} ${i}
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
41 )
270
b6ed4b2a5d9d fix CMakeList
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 265
diff changeset
42 else()
256
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
43 set(j ${i})
270
b6ed4b2a5d9d fix CMakeList
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 265
diff changeset
44 endif()
256
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
45 list(APPEND _Gears_CSOURCES ${j})
374
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
46 endforeach(i)
256
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
47
210
ba56dab79dc4 separate code init for each executable
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 208
diff changeset
48 add_custom_command (
374
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
49 OUTPUT c/${_Gears_TARGET}-context.c
256
d2f5d6fc56fa fix cmake file
mir3636
parents: 255
diff changeset
50 DEPENDS ${_Gears_CSOURCES}
255
79bbe2c63fb0 cmake generate c from cbc
mir3636
parents: 218
diff changeset
51 COMMAND "perl" "generate_context.pl" "-o" ${_Gears_TARGET} ${_Gears_CSOURCES}
210
ba56dab79dc4 separate code init for each executable
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 208
diff changeset
52 )
255
79bbe2c63fb0 cmake generate c from cbc
mir3636
parents: 218
diff changeset
53 add_executable(${_Gears_TARGET} ${_Gears_CSOURCES} c/${_Gears_TARGET}-context.c)
379
2744cb933ebc Fix compile error for bitonicSort but not work
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 377
diff changeset
54 target_link_libraries(${_Gears_TARGET} m pthread)
198
4051c012dec3 cmake macro
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 188
diff changeset
55 endmacro()
4051c012dec3 cmake macro
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 188
diff changeset
56
210
ba56dab79dc4 separate code init for each executable
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 208
diff changeset
57
198
4051c012dec3 cmake macro
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 188
diff changeset
58 GearsCommand(
4051c012dec3 cmake macro
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 188
diff changeset
59 TARGET
4051c012dec3 cmake macro
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 188
diff changeset
60 twice
374
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
61 SOURCES
381
b81492c74d2b Create examples directory
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 379
diff changeset
62 examples/twice/twice.cbc CPUWorker.cbc twice.cbc TaskManagerImpl.cbc SingleLinkedQueue.cbc SynchronizedQueue.cbc TimeImpl.cbc
278
23767f714f4a fix generate_stub
mir3636
parents: 270
diff changeset
63 )
23767f714f4a fix generate_stub
mir3636
parents: 270
diff changeset
64
326
f23f6d0aa4e9 Add examples/calc.cbc and build but not work
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents: 325
diff changeset
65 GearsCommand(
f23f6d0aa4e9 Add examples/calc.cbc and build but not work
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents: 325
diff changeset
66 TARGET
f23f6d0aa4e9 Add examples/calc.cbc and build but not work
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents: 325
diff changeset
67 calc
374
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
68 SOURCES
381
b81492c74d2b Create examples directory
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 379
diff changeset
69 examples/calc/calc.cbc examples/calc/add.cbc examples/calc/mult.cbc examples/calc/initIntegerDataGears.cbc CPUWorker.cbc TaskManagerImpl.cbc SingleLinkedQueue.cbc SynchronizedQueue.cbc
374
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
70 )
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
71
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
72 GearsCommand(
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
73 TARGET
379
2744cb933ebc Fix compile error for bitonicSort but not work
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 377
diff changeset
74 bitonicSort
374
fb50cf8aa615 Add Iterator Interface
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 364
diff changeset
75 SOURCES
381
b81492c74d2b Create examples directory
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 379
diff changeset
76 examples/bitonicSort/bitonicSort.cbc examples/bitonicSort/swap.cbc CPUWorker.cbc TaskManagerImpl.cbc SingleLinkedQueue.cbc SynchronizedQueue.cbc OneDimIterator.cbc TimeImpl.cbc
326
f23f6d0aa4e9 Add examples/calc.cbc and build but not work
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents: 325
diff changeset
77 )
f23f6d0aa4e9 Add examples/calc.cbc and build but not work
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents: 325
diff changeset
78
308
aeddca686007 CUDAtwice
ikkun
parents: 307
diff changeset
79 if (${USE_CUDA})
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
80 GearsCommand(
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
81 TARGET
302
8e7926f3e271 fix CUDAWorker
ikkun
parents: 301
diff changeset
82 CUDAtwice
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
83 SOURCES
381
b81492c74d2b Create examples directory
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 379
diff changeset
84 main.cbc RedBlackTree.cbc compare.c SingleLinkedStack.cbc CPUWorker.cbc time.cbc twice.cbc TaskManagerImpl.cbc SingleLinkedQueue.cbc SynchronizedQueue.cbc SemaphoreImpl.cbc CUDAWorker.cbc examples/twice/CUDAtwice.cbc examples/twice/CUDAtwice.cu cuda.c
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
85 )
319
a15511b1a6e0 separate cuda.c, and USE_CUDA_MAIN_THREAD flag
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 312
diff changeset
86 set_target_properties(CUDAtwice PROPERTIES COMPILE_FLAGS "-Wall -g -DUSE_CUDAWorker=1 -DUSE_CUDA_MAIN_THREAD")
301
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
87 endif()
609bf62768b9 add -DUSE_CUDA=1 flag to cmake
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 286
diff changeset
88
278
23767f714f4a fix generate_stub
mir3636
parents: 270
diff changeset
89 GearsCommand(
23767f714f4a fix generate_stub
mir3636
parents: 270
diff changeset
90 TARGET
23767f714f4a fix generate_stub
mir3636
parents: 270
diff changeset
91 queue_test
23767f714f4a fix generate_stub
mir3636
parents: 270
diff changeset
92 SOURCES
322
366baa247572 Use generate_stub for queue_test
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents: 319
diff changeset
93 test/queue_test.cbc SingleLinkedQueue.cbc
86
e06e1a9e569e create worker
Shohei KOKUBO <e105744@ie.u-ryukyu.ac.jp>
parents:
diff changeset
94 )
e06e1a9e569e create worker
Shohei KOKUBO <e105744@ie.u-ryukyu.ac.jp>
parents:
diff changeset
95
202
42dbe54332a0 add test
mir3636
parents: 199
diff changeset
96 GearsCommand(
42dbe54332a0 add test
mir3636
parents: 199
diff changeset
97 TARGET
210
ba56dab79dc4 separate code init for each executable
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 208
diff changeset
98 stack_test
202
42dbe54332a0 add test
mir3636
parents: 199
diff changeset
99 SOURCES
323
131a04a70dd8 Use generate_stub for stack_test
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents: 322
diff changeset
100 test/stack_test.cbc SingleLinkedStack.cbc
202
42dbe54332a0 add test
mir3636
parents: 199
diff changeset
101 )
42dbe54332a0 add test
mir3636
parents: 199
diff changeset
102
358
98c6e13d8ec7 add sort.cbc
Nozomi Teruya <e125769@ie.u-ryukyu.ac.jp>
parents: 347
diff changeset
103 GearsCommand(
98c6e13d8ec7 add sort.cbc
Nozomi Teruya <e125769@ie.u-ryukyu.ac.jp>
parents: 347
diff changeset
104 TARGET
376
b46f38645587 Run oneDimIterator_test
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 375
diff changeset
105 oneDimIterator_test
b46f38645587 Run oneDimIterator_test
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 375
diff changeset
106 SOURCES
401
408b4aab7610 Supported par goto iterate statement for perl script
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 381
diff changeset
107 test/oneDimIterator_test.cbc test/printIterator.cbc CPUWorker.cbc TaskManagerImpl.cbc SingleLinkedQueue.cbc SynchronizedQueue.cbc OneDimIterator.cbc TimeImpl.cbc
376
b46f38645587 Run oneDimIterator_test
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 375
diff changeset
108 )
b46f38645587 Run oneDimIterator_test
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 375
diff changeset
109
b46f38645587 Run oneDimIterator_test
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 375
diff changeset
110 GearsCommand(
b46f38645587 Run oneDimIterator_test
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 375
diff changeset
111 TARGET
358
98c6e13d8ec7 add sort.cbc
Nozomi Teruya <e125769@ie.u-ryukyu.ac.jp>
parents: 347
diff changeset
112 sort
98c6e13d8ec7 add sort.cbc
Nozomi Teruya <e125769@ie.u-ryukyu.ac.jp>
parents: 347
diff changeset
113 SOURCES
381
b81492c74d2b Create examples directory
Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp>
parents: 379
diff changeset
114 examples/bitonicSort/sort.cbc
358
98c6e13d8ec7 add sort.cbc
Nozomi Teruya <e125769@ie.u-ryukyu.ac.jp>
parents: 347
diff changeset
115 )