Makefile.am 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383
  1. # StarPU --- Runtime system for heterogeneous multicore architectures.
  2. #
  3. # Copyright (C) 2009-2017,2019 Université de Bordeaux
  4. # Copyright (C) 2011,2012,2016,2017 Inria
  5. # Copyright (C) 2017 Erwan Leria
  6. # Copyright (C) 2013 Joris Pablo
  7. # Copyright (C) 2010-2018 CNRS
  8. # Copyright (C) 2013 Thibaut Lambert
  9. #
  10. # StarPU is free software; you can redistribute it and/or modify
  11. # it under the terms of the GNU Lesser General Public License as published by
  12. # the Free Software Foundation; either version 2.1 of the License, or (at
  13. # your option) any later version.
  14. #
  15. # StarPU is distributed in the hope that it will be useful, but
  16. # WITHOUT ANY WARRANTY; without even the implied warranty of
  17. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  18. #
  19. # See the GNU Lesser General Public License in COPYING.LGPL for more details.
  20. #
  21. include $(top_srcdir)/starpu.mk
  22. if STARPU_SIMGRID
  23. STARPU_PERF_MODEL_DIR=$(abs_top_srcdir)/tools/perfmodels/sampling
  24. STARPU_HOSTNAME=mirage
  25. MALLOC_PERTURB_=0
  26. export STARPU_PERF_MODEL_DIR
  27. export STARPU_HOSTNAME
  28. export MALLOC_PERTURB_
  29. endif
  30. SUBDIRS =
  31. AM_CFLAGS = $(HWLOC_CFLAGS) $(STARPU_CUDA_CPPFLAGS) $(STARPU_OPENCL_CPPFLAGS) $(STARPU_COI_CPPFLAGS) $(GLOBAL_AM_CFLAGS)
  32. LIBS = $(top_builddir)/src/@LIBSTARPU_LINK@ @LIBS@ $(FXT_LIBS)
  33. AM_CPPFLAGS = -I$(top_srcdir)/include/ -I$(top_srcdir)/tools/ -I$(top_srcdir)/mpi/ -I$(top_builddir)/src -I$(top_srcdir)/src
  34. AM_LDFLAGS = @STARPU_EXPORT_DYNAMIC@ $(STARPU_COI_LDFLAGS) $(STARPU_SCIF_LDFLAGS)
  35. bin_PROGRAMS =
  36. dist_bin_SCRIPTS =
  37. dist_pkgdata_DATA = gdbinit
  38. pkgdata_perfmodels_sampling_busdir = $(datarootdir)/starpu/perfmodels/sampling/bus
  39. pkgdata_perfmodels_sampling_codeletsdir = $(datarootdir)/starpu/perfmodels/sampling/codelets/45
  40. dist_pkgdata_perfmodels_sampling_bus_DATA = \
  41. perfmodels/sampling/bus/attila.affinity \
  42. perfmodels/sampling/bus/attila.bandwidth \
  43. perfmodels/sampling/bus/attila.config \
  44. perfmodels/sampling/bus/attila.latency \
  45. perfmodels/sampling/bus/attila.platform.xml \
  46. perfmodels/sampling/bus/attila.platform.v4.xml \
  47. perfmodels/sampling/bus/idgraf.affinity \
  48. perfmodels/sampling/bus/idgraf.bandwidth \
  49. perfmodels/sampling/bus/idgraf.config \
  50. perfmodels/sampling/bus/idgraf.latency \
  51. perfmodels/sampling/bus/idgraf.platform.xml \
  52. perfmodels/sampling/bus/idgraf.platform.v4.xml \
  53. perfmodels/sampling/bus/mirage.affinity \
  54. perfmodels/sampling/bus/mirage.bandwidth \
  55. perfmodels/sampling/bus/mirage.config \
  56. perfmodels/sampling/bus/mirage.latency \
  57. perfmodels/sampling/bus/mirage.platform.xml \
  58. perfmodels/sampling/bus/mirage.platform.v4.xml \
  59. perfmodels/sampling/bus/sirocco.affinity \
  60. perfmodels/sampling/bus/sirocco.bandwidth \
  61. perfmodels/sampling/bus/sirocco.config \
  62. perfmodels/sampling/bus/sirocco.latency \
  63. perfmodels/sampling/bus/sirocco.platform.xml \
  64. perfmodels/sampling/bus/sirocco.platform.v4.xml
  65. dist_pkgdata_perfmodels_sampling_codelets_DATA = \
  66. perfmodels/sampling/codelets/45/chol_model_11.attila \
  67. perfmodels/sampling/codelets/45/chol_model_21.attila \
  68. perfmodels/sampling/codelets/45/chol_model_22.attila \
  69. perfmodels/sampling/codelets/45/cl_update.attila \
  70. perfmodels/sampling/codelets/45/save_cl_bottom.attila \
  71. perfmodels/sampling/codelets/45/save_cl_top.attila \
  72. perfmodels/sampling/codelets/45/starpu_sgemm_gemm.attila \
  73. perfmodels/sampling/codelets/45/starpu_dgemm_gemm.attila \
  74. perfmodels/sampling/codelets/45/starpu_slu_lu_model_11.attila \
  75. perfmodels/sampling/codelets/45/starpu_slu_lu_model_12.attila \
  76. perfmodels/sampling/codelets/45/starpu_slu_lu_model_21.attila \
  77. perfmodels/sampling/codelets/45/starpu_slu_lu_model_22.attila \
  78. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_11.attila \
  79. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_12.attila \
  80. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_21.attila \
  81. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_22.attila \
  82. perfmodels/sampling/codelets/45/overlap_sleep_1024_24.attila \
  83. perfmodels/sampling/codelets/45/chol_model_11.idgraf \
  84. perfmodels/sampling/codelets/45/chol_model_21.idgraf \
  85. perfmodels/sampling/codelets/45/chol_model_22.idgraf \
  86. perfmodels/sampling/codelets/45/cl_update.idgraf \
  87. perfmodels/sampling/codelets/45/save_cl_bottom.idgraf \
  88. perfmodels/sampling/codelets/45/save_cl_top.idgraf \
  89. perfmodels/sampling/codelets/45/starpu_sgemm_gemm.idgraf \
  90. perfmodels/sampling/codelets/45/starpu_dgemm_gemm.idgraf \
  91. perfmodels/sampling/codelets/45/starpu_slu_lu_model_11.idgraf \
  92. perfmodels/sampling/codelets/45/starpu_slu_lu_model_12.idgraf \
  93. perfmodels/sampling/codelets/45/starpu_slu_lu_model_21.idgraf \
  94. perfmodels/sampling/codelets/45/starpu_slu_lu_model_22.idgraf \
  95. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_11.idgraf \
  96. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_12.idgraf \
  97. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_21.idgraf \
  98. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_22.idgraf \
  99. perfmodels/sampling/codelets/45/chol_model_11.mirage \
  100. perfmodels/sampling/codelets/45/chol_model_21.mirage \
  101. perfmodels/sampling/codelets/45/chol_model_22.mirage \
  102. perfmodels/sampling/codelets/45/cl_update.mirage \
  103. perfmodels/sampling/codelets/45/save_cl_bottom.mirage \
  104. perfmodels/sampling/codelets/45/save_cl_top.mirage \
  105. perfmodels/sampling/codelets/45/starpu_sgemm_gemm.mirage \
  106. perfmodels/sampling/codelets/45/starpu_dgemm_gemm.mirage \
  107. perfmodels/sampling/codelets/45/starpu_slu_lu_model_11.mirage \
  108. perfmodels/sampling/codelets/45/starpu_slu_lu_model_12.mirage \
  109. perfmodels/sampling/codelets/45/starpu_slu_lu_model_21.mirage \
  110. perfmodels/sampling/codelets/45/starpu_slu_lu_model_22.mirage \
  111. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_11.mirage \
  112. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_12.mirage \
  113. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_21.mirage \
  114. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_22.mirage \
  115. perfmodels/sampling/codelets/45/overlap_sleep_1024_24.mirage \
  116. perfmodels/sampling/codelets/45/chol_model_11.sirocco \
  117. perfmodels/sampling/codelets/45/chol_model_21.sirocco \
  118. perfmodels/sampling/codelets/45/chol_model_22.sirocco \
  119. perfmodels/sampling/codelets/45/cl_update.sirocco \
  120. perfmodels/sampling/codelets/45/save_cl_bottom.sirocco \
  121. perfmodels/sampling/codelets/45/save_cl_top.sirocco \
  122. perfmodels/sampling/codelets/45/starpu_sgemm_gemm.sirocco \
  123. perfmodels/sampling/codelets/45/starpu_dgemm_gemm.sirocco \
  124. perfmodels/sampling/codelets/45/starpu_slu_lu_model_11.sirocco \
  125. perfmodels/sampling/codelets/45/starpu_slu_lu_model_12.sirocco \
  126. perfmodels/sampling/codelets/45/starpu_slu_lu_model_21.sirocco \
  127. perfmodels/sampling/codelets/45/starpu_slu_lu_model_22.sirocco \
  128. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_11.sirocco \
  129. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_12.sirocco \
  130. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_21.sirocco \
  131. perfmodels/sampling/codelets/45/starpu_dlu_lu_model_22.sirocco \
  132. perfmodels/sampling/codelets/45/overlap_sleep_1024_24.sirocco
  133. EXTRA_DIST = \
  134. dev/checker/rename.sed \
  135. dev/checker/rename.sh \
  136. dev/cppcheck/suppressions.txt \
  137. dev/valgrind/bash.suppr \
  138. dev/valgrind/fxt.suppr \
  139. dev/valgrind/hdf5.suppr \
  140. dev/valgrind/hwloc.suppr \
  141. dev/valgrind/libc.suppr \
  142. dev/valgrind/libgomp.suppr \
  143. dev/valgrind/libnuma.suppr \
  144. dev/valgrind/madmpi.suppr \
  145. dev/valgrind/opencl.suppr \
  146. dev/valgrind/openmpi.suppr \
  147. dev/valgrind/openmp.suppr \
  148. dev/valgrind/padico.suppr \
  149. dev/valgrind/pthread.suppr \
  150. dev/valgrind/starpu.suppr \
  151. dev/valgrind/valgrind.suppr \
  152. dev/valgrind/valgrind.sh \
  153. dev/valgrind/valgrind_xml.sh \
  154. dev/valgrind/helgrind.sh \
  155. dev/tsan/starpu.suppr \
  156. dev/lsan/suppressions \
  157. perfmodels/README \
  158. perfmodels/cluster.xml \
  159. perfmodels/hostfile \
  160. perfmodels/sampling/codelets/tmp/mlr_init.out \
  161. msvc/starpu_clean.bat \
  162. msvc/starpu_open.bat \
  163. msvc/starpu_exec.bat \
  164. msvc/starpu_var.bat \
  165. msvc/starpu.sln \
  166. msvc/starpu/starpu.vcxproj
  167. CLEANFILES = *.gcno *.gcda *.linkinfo starpu_idle_microsec.log figure/* mlr_*
  168. #####################################
  169. # What to install and what to check #
  170. #####################################
  171. STARPU_TOOLS =
  172. TESTS = $(STARPU_TOOLS)
  173. if STARPU_HAVE_WINDOWS
  174. check_PROGRAMS = $(STARPU_TOOLS)
  175. else
  176. check_PROGRAMS = $(LOADER) $(STARPU_TOOLS)
  177. endif
  178. if !STARPU_HAVE_WINDOWS
  179. ## test loader program
  180. if !STARPU_CROSS_COMPILING
  181. LOADER = loader
  182. loader_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS) -I$(top_builddir)/src/
  183. LOADER_BIN = $(abs_top_builddir)/tools/$(LOADER)
  184. loader_SOURCES = ../tests/loader.c
  185. else
  186. LOADER =
  187. LOADER_BIN = $(top_builddir)/tests/loader-cross.sh
  188. endif
  189. if STARPU_USE_MPI_MASTER_SLAVE
  190. LOADER_BIN2 = $(MPI_LAUNCHER) $(LOADER_BIN)
  191. else
  192. LOADER_BIN2 = $(LOADER_BIN)
  193. endif
  194. if STARPU_HAVE_AM111
  195. TESTS_ENVIRONMENT = $(MPI_RUN_ARGS) top_builddir="$(abs_top_builddir)" top_srcdir="$(abs_top_srcdir)"
  196. LOG_COMPILER = $(LOADER_BIN2)
  197. else
  198. TESTS_ENVIRONMENT = $(MPI_RUN_ARGS) top_builddir="$(abs_top_builddir)" top_srcdir="$(abs_top_srcdir)" $(LOADER_BIN2)
  199. endif
  200. endif
  201. if STARPU_USE_FXT
  202. bin_PROGRAMS += \
  203. starpu_fxt_tool \
  204. starpu_fxt_stats \
  205. starpu_fxt_data_trace
  206. STARPU_TOOLS += \
  207. starpu_fxt_tool \
  208. starpu_fxt_stats \
  209. starpu_fxt_data_trace
  210. starpu_fxt_tool_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS) $(FXT_CFLAGS)
  211. starpu_fxt_tool_LDADD = $(FXT_LIBS)
  212. starpu_fxt_tool_LDFLAGS = $(FXT_LDFLAGS)
  213. starpu_fxt_stats_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS) $(FXT_CFLAGS)
  214. starpu_fxt_stats_LDADD = $(FXT_LIBS)
  215. starpu_fxt_stats_LDFLAGS = $(FXT_LDFLAGS)
  216. starpu_fxt_data_trace_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS) $(FXT_CFLAGS)
  217. starpu_fxt_data_trace_LDADD = $(FXT_LIBS)
  218. starpu_fxt_data_trace_LDFLAGS = $(FXT_LDFLAGS)
  219. endif
  220. bin_PROGRAMS += \
  221. starpu_perfmodel_display \
  222. starpu_perfmodel_plot \
  223. starpu_calibrate_bus \
  224. starpu_machine_display \
  225. starpu_sched_display \
  226. starpu_tasks_rec_complete \
  227. starpu_lp2paje \
  228. starpu_perfmodel_recdump
  229. if STARPU_SIMGRID
  230. bin_PROGRAMS += \
  231. starpu_replay
  232. starpu_replay_SOURCES = \
  233. starpu_replay.c \
  234. starpu_replay_sched.c
  235. endif
  236. starpu_perfmodel_plot_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS) $(FXT_CFLAGS)
  237. if STARPU_LONG_CHECK
  238. STARPU_TOOLS += \
  239. starpu_calibrate_bus
  240. endif
  241. STARPU_TOOLS += \
  242. starpu_machine_display \
  243. starpu_sched_display
  244. if !STARPU_HAVE_WINDOWS
  245. STARPU_TOOLS += \
  246. starpu_perfmodel_display \
  247. starpu_perfmodel_plot
  248. endif
  249. dist_bin_SCRIPTS += \
  250. starpu_workers_activity \
  251. starpu_codelet_histo_profile \
  252. starpu_codelet_profile \
  253. starpu_mpi_comm_matrix.py \
  254. starpu_paje_draw_histogram \
  255. starpu_paje_draw_histogram.R \
  256. starpu_paje_summary \
  257. starpu_paje_summary.Rmd \
  258. starpu_mlr_analysis \
  259. starpu_mlr_analysis.Rmd \
  260. starpu_paje_state_stats \
  261. starpu_trace_state_stats.py
  262. if STARPU_USE_AYUDAME2
  263. dist_bin_SCRIPTS += \
  264. starpu_temanejo2.sh
  265. dist_pkgdata_DATA += \
  266. ayudame.cfg
  267. endif
  268. if STARPU_HAVE_WINDOWS
  269. STARPU_MSVC_dir = $(bindir)
  270. nobase_STARPU_MSVC__DATA = \
  271. msvc/starpu_clean.bat \
  272. msvc/starpu_open.bat \
  273. msvc/starpu_exec.bat \
  274. msvc/starpu_var.bat \
  275. msvc/starpu.sln \
  276. msvc/starpu/starpu.vcxproj
  277. endif
  278. if STARPU_HAVE_HELP2MAN
  279. starpu_calibrate_bus.1: starpu_calibrate_bus$(EXEEXT)
  280. help2man --no-discard-stderr -N --output=$@ ./$<
  281. starpu_machine_display.1: starpu_machine_display$(EXEEXT)
  282. help2man --no-discard-stderr -N --output=$@ ./$<
  283. starpu_perfmodel_display.1: starpu_perfmodel_display$(EXEEXT)
  284. help2man --no-discard-stderr -N --output=$@ ./$<
  285. starpu_perfmodel_plot.1: starpu_perfmodel_plot$(EXEEXT)
  286. help2man --no-discard-stderr -N --output=$@ ./$<
  287. starpu_tasks_rec_complete.1: starpu_tasks_rec_complete$(EXEEXT)
  288. help2man --no-discard-stderr -N --output=$@ ./$<
  289. starpu_lp2paje.1: starpu_lp2paje$(EXEEXT)
  290. help2man --no-discard-stderr -N --output=$@ ./$<
  291. starpu_workers_activity.1: starpu_workers_activity
  292. chmod +x $<
  293. help2man --no-discard-stderr -N --output=$@ ./$<
  294. starpu_codelet_profile.1: starpu_codelet_profile
  295. chmod +x $<
  296. help2man --no-discard-stderr -N --output=$@ ./$<
  297. starpu_codelet_histo_profile.1: starpu_codelet_histo_profile
  298. chmod +x $<
  299. help2man --no-discard-stderr -N --output=$@ ./$<
  300. starpu_mpi_comm_matrix.1: starpu_mpi_comm_matrix.py
  301. chmod +x $<
  302. help2man --no-discard-stderr -N --output=$@ ./$<
  303. starpu_paje_draw_histogram.1: starpu_paje_draw_histogram
  304. chmod +x $<
  305. help2man --no-discard-stderr -N --output=$@ ./$<
  306. starpu_paje_state_stats.1: starpu_paje_state_stats
  307. chmod +x $<
  308. help2man --no-discard-stderr -N --output=$@ ./$<
  309. if STARPU_USE_FXT
  310. starpu_fxt_tool.1: starpu_fxt_tool$(EXEEXT)
  311. help2man --no-discard-stderr -N --output=$@ ./$<
  312. starpu_fxt_stats.1: starpu_fxt_stats$(EXEEXT)
  313. help2man --no-discard-stderr -N --output=$@ ./$<
  314. starpu_fxt_data_trace.1: starpu_fxt_data_trace$(EXEEXT)
  315. help2man --no-discard-stderr -N --output=$@ ./$<
  316. endif
  317. dist_man1_MANS =\
  318. starpu_calibrate_bus.1 \
  319. starpu_machine_display.1 \
  320. starpu_perfmodel_display.1 \
  321. starpu_perfmodel_plot.1 \
  322. starpu_tasks_rec_complete.1 \
  323. starpu_lp2paje.1 \
  324. starpu_workers_activity.1 \
  325. starpu_codelet_profile.1 \
  326. starpu_codelet_histo_profile.1 \
  327. starpu_mpi_comm_matrix.1 \
  328. starpu_paje_draw_histogram.1 \
  329. starpu_paje_state_stats.1
  330. if STARPU_USE_FXT
  331. dist_man1_MANS +=\
  332. starpu_fxt_tool.1 \
  333. starpu_fxt_stats.1 \
  334. starpu_fxt_data_trace.1
  335. endif
  336. clean-local:
  337. $(RM) $(dist_man1_MANS)
  338. endif
  339. if STARPU_SIMGRID
  340. dist_pkgdata_DATA += starpu_smpi.xslt
  341. dist_bin_SCRIPTS += starpu_smpirun
  342. endif