configure.ac 48 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438
  1. # StarPU --- Runtime system for heterogeneous multicore architectures.
  2. #
  3. # Copyright (C) 2009, 2010, 2011 Université de Bordeaux 1
  4. # Copyright (C) 2010, 2011 Centre National de la Recherche Scientifique
  5. #
  6. # StarPU is free software; you can redistribute it and/or modify
  7. # it under the terms of the GNU Lesser General Public License as published by
  8. # the Free Software Foundation; either version 2.1 of the License, or (at
  9. # your option) any later version.
  10. #
  11. # StarPU is distributed in the hope that it will be useful, but
  12. # WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  14. #
  15. # See the GNU Lesser General Public License in COPYING.LGPL for more details.
  16. AC_INIT([StarPU],0.9.2, [starpu-bugs@lists.gforge.inria.fr], starpu)
  17. AC_CONFIG_SRCDIR(include/starpu.h)
  18. AC_CONFIG_AUX_DIR([build-aux])
  19. AC_CANONICAL_SYSTEM
  20. dnl Automake 1.11 introduced `silent-rules' and `color-tests'. Use them
  21. dnl when they're available.
  22. m4_ifdef([AM_SILENT_RULES],
  23. [AM_INIT_AUTOMAKE([1.11 -Wall -Werror foreign silent-rules color-tests])],
  24. [AM_INIT_AUTOMAKE([1.10 -Wall -Werror foreign])])
  25. AC_PREREQ(2.60)
  26. AC_PROG_CC
  27. AC_PROG_CPP
  28. AC_PROG_SED
  29. AC_PROG_LN_S
  30. AC_PROG_F77
  31. LT_PREREQ([2.2])
  32. LT_INIT([win32-dll])
  33. AC_PROG_INSTALL
  34. AC_PROG_MKDIR_P
  35. AC_PROG_LN_S
  36. AC_HEADER_STDC
  37. AC_C_RESTRICT
  38. AC_PATH_PROGS([STARPU_MS_LIB], [lib])
  39. AC_ARG_VAR([STARPU_MS_LIB], [Path to Microsoft's Visual Studio `lib' tool])
  40. AM_CONDITIONAL([STARPU_HAVE_MS_LIB], [test "x$STARPU_MS_LIB" != "x"])
  41. case "$target" in
  42. *-*-mingw*|*-*-cygwin*)
  43. starpu_windows=yes
  44. libext=a
  45. AC_DEFINE(STARPU_HAVE_WINDOWS, [], [Define this on windows.])
  46. ;;
  47. esac
  48. AM_CONDITIONAL([STARPU_HAVE_WINDOWS], [test "x$starpu_windows" = "xyes"])
  49. # on Darwin, GCC targets i386 by default, so we don't have atomic ops
  50. AC_CHECK_SIZEOF([void *])
  51. SIZEOF_VOID_P=$ac_cv_sizeof_void_p
  52. if test x$SIZEOF_VOID_P = x4; then
  53. case "$target" in
  54. i386-*darwin*) CFLAGS+=" -march=i686 " ;;
  55. esac
  56. fi
  57. # This will be useful for program which use CUDA (and .cubin files) which need
  58. # some path to the CUDA code at runtime.
  59. AC_DEFINE_UNQUOTED(STARPU_BUILD_DIR, "$PWD", [location of StarPU build directory])
  60. AC_SUBST(STARPU_BUILD_DIR, $PWD)
  61. case "${srcdir}" in
  62. /*) AC_DEFINE_UNQUOTED(STARPU_SRC_DIR, "$(eval echo ${srcdir})", [location of StarPU sources])
  63. AC_SUBST(STARPU_SRC_DIR, "$(eval echo ${srcdir})") ;;
  64. *) AC_DEFINE_UNQUOTED(STARPU_SRC_DIR, "$(eval echo $PWD/${srcdir})", [location of StarPU sources])
  65. AC_SUBST(STARPU_SRC_DIR, "$(eval echo $PWD/${srcdir})") ;;
  66. esac
  67. AC_CHECK_LIB([pthread], [pthread_create])
  68. AC_COMPILE_IFELSE(
  69. AC_LANG_PROGRAM([[
  70. #include <pthread.h>
  71. ]], [[ pthread_t t; pthread_create(&t, NULL, NULL, NULL); ]]),,
  72. AC_MSG_ERROR([pthread_create unavailable]))
  73. AC_SEARCH_LIBS([sqrt],[m],,AC_MSG_ERROR([math library unavailable]))
  74. AC_HAVE_LIBRARY([ws2_32])
  75. AC_CHECK_FUNCS([sysconf])
  76. AC_CHECK_FUNC([pthread_spin_lock], have_pthread_spin_lock=yes, have_pthread_spin_lock=no)
  77. if test x$have_pthread_spin_lock = xyes; then
  78. AC_DEFINE(HAVE_PTHREAD_SPIN_LOCK,[],[pthread_spin_lock is available])
  79. fi
  80. # yes, that's non portable, but it's still better than sched_setaffinity
  81. AC_CHECK_FUNCS(pthread_setaffinity_np)
  82. # There is no posix_memalign on Mac OS X, only memalign
  83. AC_CHECK_FUNCS([posix_memalign], [AC_DEFINE([STARPU_HAVE_POSIX_MEMALIGN], [1], [Define to 1 if you have the `posix_memalign' function.])])
  84. AC_CHECK_FUNCS([memalign], [AC_DEFINE([STARPU_HAVE_MEMALIGN], [1], [Define to 1 if you have the `memalign' function.])])
  85. # Some systems don't have drand48
  86. AC_CHECK_FUNC([drand48], have_drand48=yes, have_drand48=no)
  87. # Maybe the user still does not want to use the provided drand48
  88. AC_ARG_ENABLE(default-drand48, [AS_HELP_STRING([--disable-default-drand48],
  89. [Do not use the default version of drand48])],
  90. enable_default_drand48=$enableval, enable_default_drand48=yes)
  91. if test x$have_drand48 = xyes -a x$enable_default_drand48 = xyes ; then
  92. AC_DEFINE([starpu_srand48(seed)],[srand48(seed)],[srand48 equivalent function])
  93. AC_DEFINE([starpu_drand48()],[drand48()],[drand48 equivalent function])
  94. AC_DEFINE([starpu_erand48(xsubi)],[erand48(xsubi)],[erand48 equivalent function])
  95. AC_DEFINE([starpu_srand48_r(seed, buffer)],[srand48_r(seed, buffer)],[srand48_r equivalent function])
  96. AC_DEFINE([starpu_erand48_r(xsubi, buffer, result)],[erand48_r(xsubi, buffer, result)],[erand48_r equivalent function])
  97. else
  98. AC_DEFINE([starpu_srand48(seed)],[srand(seed)],[srand48 equivalent function])
  99. AC_DEFINE([starpu_drand48()],[((double)(rand()) / RAND_MAX)],[drand48 equivalent function])
  100. AC_DEFINE([starpu_erand48(xsubi)],[starpu_drand48()],[erand48 equivalent function])
  101. AC_DEFINE([starpu_srand48_r(seed, buffer)],[srand((unsigned int)seed)],[srand48_r equivalent function])
  102. AC_DEFINE([starpu_erand48_r(xsubi, buffer, result)],[do {*(result) = ((double)(rand()) / RAND_MAX);} while (0);],[erand48_r equivalent function])
  103. fi
  104. # Define slow machine
  105. AC_ARG_ENABLE(slow-machine, [AS_HELP_STRING([--disable-slow-machine],
  106. [Lower default values for the testcases run by make check])],
  107. enable_slow_machine=$enableval, enable_slow_machine=false)
  108. if test x$enable_slow_machine = xyes; then
  109. AC_DEFINE(STARPU_SLOW_MACHINE, [1], [enable slow machine])
  110. fi
  111. AC_CHECK_HEADERS([malloc.h], [AC_DEFINE([STARPU_HAVE_MALLOC_H], [1], [Define to 1 if you have the <malloc.h> header file.])])
  112. # This defines HAVE_SYNC_VAL_COMPARE_AND_SWAP
  113. STARPU_CHECK_SYNC_VAL_COMPARE_AND_SWAP
  114. # This defines HAVE_SYNC_BOOL_COMPARE_AND_SWAP
  115. STARPU_CHECK_SYNC_BOOL_COMPARE_AND_SWAP
  116. # This defines HAVE_SYNC_FETCH_AND_ADD
  117. STARPU_CHECK_SYNC_FETCH_AND_ADD
  118. # This defines HAVE_SYNC_FETCH_AND_OR
  119. STARPU_CHECK_SYNC_FETCH_AND_OR
  120. # This defines HAVE_SYNC_LOCK_TEST_AND_SET
  121. STARPU_CHECK_SYNC_LOCK_TEST_AND_SET
  122. # This defines HAVE_SYNC_SYNCHRONIZE
  123. STARPU_CHECK_SYNC_SYNCHRONIZE
  124. CPPFLAGS="${CPPFLAGS} -D_GNU_SOURCE "
  125. STARPU_SEARCH_LIBS([LIBNUMA],[set_mempolicy],[numa],[enable_libnuma=yes],[enable_libnuma=no])
  126. AC_MSG_CHECKING(whether libnuma is available)
  127. AC_MSG_RESULT($enable_libnuma)
  128. if test x$enable_libnuma = xyes; then
  129. AC_DEFINE(STARPU_HAVE_LIBNUMA,[],[libnuma is available])
  130. fi
  131. ###############################################################################
  132. # #
  133. # CPUs settings #
  134. # #
  135. ###############################################################################
  136. AC_MSG_CHECKING(maximum number of CPUs)
  137. AC_ARG_ENABLE(maxcpus, [AS_HELP_STRING([--enable-maxcpus=<number>],
  138. [maximum number of CPUs])],
  139. maxcpus=$enableval, maxcpus=16)
  140. AC_MSG_RESULT($maxcpus)
  141. AC_DEFINE_UNQUOTED(STARPU_MAXCPUS, [$maxcpus], [Maximum number of CPUs supported])
  142. AC_MSG_CHECKING(whether CPUs should be used)
  143. AC_ARG_ENABLE(cpu, [AS_HELP_STRING([--disable-cpu],
  144. [do not use the CPU(s)])],
  145. enable_cpu=$enableval, enable_cpu=yes)
  146. AC_MSG_RESULT($enable_cpu)
  147. AC_SUBST(STARPU_USE_CPU, $enable_cpu)
  148. AM_CONDITIONAL(STARPU_USE_CPU, test x$enable_cpu = xyes)
  149. if test x$enable_cpu = xyes; then
  150. AC_DEFINE(STARPU_USE_CPU, [1], [CPU driver is activated])
  151. fi
  152. # How many parallel worker can we support ?
  153. nmaxcombinedworkers=`expr 2 \* $maxcpus`
  154. AC_DEFINE_UNQUOTED(STARPU_NMAX_COMBINEDWORKERS,
  155. [$nmaxcombinedworkers], [Maximum number of worker combinations])
  156. ###############################################################################
  157. # #
  158. # CUDA settings #
  159. # #
  160. ###############################################################################
  161. AC_MSG_CHECKING(maximum number of CUDA devices)
  162. AC_ARG_ENABLE(maxcudadev, [AS_HELP_STRING([--enable-maxcudadev=<number>],
  163. [maximum number of CUDA devices])],
  164. nmaxcudadev=$enableval, nmaxcudadev=4)
  165. AC_MSG_RESULT($nmaxcudadev)
  166. AC_DEFINE_UNQUOTED(STARPU_MAXCUDADEVS, [$nmaxcudadev],
  167. [maximum number of CUDA devices])
  168. AC_ARG_ENABLE(cuda, [AS_HELP_STRING([--disable-cuda],
  169. [do not use CUDA device(s)])],, [enable_cuda=maybe])
  170. #AC_MSG_CHECKING(whether CUDA is available)
  171. AC_ARG_WITH(cuda-dir,
  172. [AS_HELP_STRING([--with-cuda-dir=<path>],
  173. [specify CUDA installation directory])],
  174. [
  175. cuda_dir="$withval"
  176. # in case this was not explicit yet
  177. enable_cuda=yes
  178. ], cuda_dir=no)
  179. AC_ARG_WITH(cuda-include-dir,
  180. [AS_HELP_STRING([--with-cuda-include-dir=<path>],
  181. [specify where CUDA headers are installed])],
  182. [
  183. cuda_include_dir="$withval"
  184. # in case this was not explicit yet
  185. enable_cuda=yes
  186. ], [cuda_include_dir=no])
  187. AC_ARG_WITH(cuda-lib-dir,
  188. [AS_HELP_STRING([--with-cuda-lib-dir=<path>],
  189. [specify where CUDA libraries are installed])],
  190. [
  191. cuda_lib_dir="$withval"
  192. # in case this was not explicit yet
  193. enable_cuda=yes
  194. ], [cuda_lib_dir=no])
  195. AC_DEFUN([STARPU_CHECK_CUDA],
  196. [
  197. __cuda_dir=$1
  198. __cuda_lib_dir=$2
  199. if test "$__cuda_dir" != "no" ; then
  200. AC_MSG_CHECKING(whether CUDA is available in $__cuda_dir)
  201. else
  202. AC_MSG_CHECKING(whether CUDA is available)
  203. fi
  204. AC_MSG_RESULT()
  205. if test "$__cuda_lib_dir" = "no" -a "$__cuda_dir" != "no" ; then
  206. __cuda_lib_dir="$__cuda_dir/lib"
  207. fi
  208. SAVED_LDFLAGS="${LDFLAGS}"
  209. if test "$__cuda_dir" != "no" ; then
  210. STARPU_CUDA_LDFLAGS="-L${__cuda_lib_dir}"
  211. LDFLAGS="${SAVED_LDFLAGS} -L${__cuda_lib_dir}"
  212. fi
  213. AC_HAVE_LIBRARY([cuda],[have_valid_cuda=yes],[have_valid_cuda=no])
  214. unset ac_cv_lib_cuda_main
  215. if test "$have_valid_cuda" = "no" ; then
  216. if test "$__cuda_dir" != "no" ; then
  217. STARPU_CUDA_LDFLAGS="-L${__cuda_dir}/lib64"
  218. LDFLAGS="${SAVED_LDFLAGS} -L${__cuda_dir}/lib64"
  219. AC_HAVE_LIBRARY([cuda],[have_valid_cuda=yes],[have_valid_cuda=no])
  220. unset ac_cv_lib_cuda_main
  221. fi
  222. fi
  223. if test "$have_valid_cuda" = "no" ; then
  224. LDFLAGS="${SAVED_LDFLAGS}"
  225. unset STARPU_CUDA_LDFLAGS
  226. fi
  227. ])
  228. AC_DEFUN([STARPU_CHECK_CUDA_RUNTIME],
  229. [
  230. __cuda_dir=$1
  231. __cuda_include_dir=$2
  232. __cuda_lib_dir=$3
  233. if test "$__cuda_dir" != "no" ; then
  234. AC_MSG_CHECKING(whether CUDA RT is available in $__cuda_dir)
  235. else
  236. AC_MSG_CHECKING(whether CUDA RT is available)
  237. fi
  238. AC_MSG_RESULT()
  239. if test "$__cuda_include_dir" = "no" -a "$__cuda_dir" != "no" ; then
  240. __cuda_include_dir="$__cuda_dir/include"
  241. fi
  242. if test "$__cuda_lib_dir" = "no" -a "$__cuda_dir" != "no" ; then
  243. __cuda_lib_dir="$__cuda_dir/lib"
  244. fi
  245. SAVED_CPPFLAGS="$CPPFLAGS"
  246. SAVED_LDFLAGS="${LDFLAGS}"
  247. SAVED_STARPU_CUDA_LDFLAGS=${STARPU_CUDA_LDFLAGS}
  248. if test "$__cuda_lib_dir" != "no" ; then
  249. STARPU_CUDA_LDFLAGS="${SAVED_STARPU_CUDA_LDFLAGS} -L$__cuda_lib_dir"
  250. fi
  251. if test "$__cuda_include_dir" != "no" ; then
  252. CPPFLAGS="${CPPFLAGS} -I$__cuda_include_dir"
  253. fi
  254. AC_CHECK_HEADER([cuda.h],[have_valid_cuda=yes],[have_valid_cuda=no])
  255. unset ac_cv_header_cuda_h
  256. if test "$have_valid_cuda" = "yes" ; then
  257. if test "$__cuda_lib_dir" != "no"; then
  258. LDFLAGS="${SAVED_LDFLAGS} -L$__cuda_lib_dir"
  259. fi
  260. AC_HAVE_LIBRARY([cudart],[have_valid_cuda=yes],[have_valid_cuda=no])
  261. unset ac_cv_lib_cudart_main
  262. if test "$have_valid_cuda" = "no" ; then
  263. if test "$3" = "no" -a "$__cuda_dir" != "no" ; then
  264. __cuda_lib_dir="$__cuda_dir/lib64"
  265. STARPU_CUDA_LDFLAGS="${SAVED_STARPU_CUDA_LDFLAGS} -L$__cuda_lib_dir"
  266. LDFLAGS="${SAVED_LDFLAGS} -L$__cuda_lib_dir"
  267. AC_HAVE_LIBRARY([cudart],[have_valid_cuda=yes],[have_valid_cuda=no])
  268. unset ac_cv_lib_cudart_main
  269. fi
  270. fi
  271. fi
  272. if test "$have_valid_cuda" = "yes" ; then
  273. STARPU_CUDA_LDFLAGS="$STARPU_CUDA_LDFLAGS -lcudart"
  274. # we also check that CUBLAS is available
  275. AC_HAVE_LIBRARY([cublas],[have_valid_cuda=yes],[have_valid_cuda=no])
  276. unset ac_cv_lib_cublas_main
  277. if test "$have_valid_cuda" = "yes" ; then
  278. STARPU_CUDA_LDFLAGS="$STARPU_CUDA_LDFLAGS -lcublas"
  279. fi
  280. fi
  281. CPPFLAGS="${SAVED_CPPFLAGS}"
  282. LDFLAGS="${SAVED_LDFLAGS}"
  283. if test "$have_valid_cuda" = "yes" -a "$__cuda_include_dir" != "no"; then
  284. STARPU_CUDA_CPPFLAGS="-I$__cuda_include_dir"
  285. NVCCFLAGS="${NVCCFLAGS} -I$__cuda_include_dir"
  286. fi
  287. ])
  288. if test x$enable_cuda = xyes -o x$enable_cuda = xmaybe; then
  289. STARPU_CHECK_CUDA($cuda_dir, $cuda_lib_dir)
  290. if test "$have_valid_cuda" = "no" ; then
  291. for f in "/usr/local/cuda" "/c/cuda" "/cygdrive/c/cuda" "/opt/cuda" "$CUDA_INC_PATH" "$CUDA_INSTALL_PATH"; do
  292. STARPU_CHECK_CUDA($f, "no")
  293. if test "$have_valid_cuda" = "yes" ; then
  294. break
  295. fi
  296. done
  297. fi
  298. if test "$have_valid_cuda" = "yes" ; then
  299. STARPU_CHECK_CUDA_RUNTIME($cuda_dir, $cuda_include_dir, $cuda_lib_dir)
  300. if test "$have_valid_cuda" = "no" ; then
  301. for f in "/usr/local/cuda" "/c/cuda" "/cygdrive/c/cuda" "/opt/cuda" "$CUDA_INC_PATH" "$CUDA_INSTALL_PATH"; do
  302. STARPU_CHECK_CUDA_RUNTIME($f, "no", "no")
  303. if test "$have_valid_cuda" = "yes" ; then
  304. break
  305. fi
  306. done
  307. fi
  308. fi
  309. # in case CUDA was explicitely required, but is not available, this is an error
  310. if test x$enable_cuda = xyes -a x$have_valid_cuda = no; then
  311. AC_MSG_ERROR([cannot find CUDA])
  312. fi
  313. # now we enable CUDA if and only if a proper setup is available
  314. enable_cuda=$have_valid_cuda
  315. fi
  316. if test x$enable_cuda = xyes; then
  317. AC_PATH_PROG([NVCC], [nvcc], [not-found],
  318. [$cuda_dir/bin:$PATH:/usr/local/cuda/bin:/usr/bin:/bin])
  319. if test "x$NVCC" = "xnot-found"; then
  320. AC_MSG_WARN(['nvcc' not found, disabling CUDA])
  321. enable_cuda=no
  322. fi
  323. fi
  324. AC_MSG_CHECKING(whether CUDA should be used)
  325. AC_MSG_RESULT($enable_cuda)
  326. AC_SUBST(STARPU_USE_CUDA, $enable_cuda)
  327. AM_CONDITIONAL(STARPU_USE_CUDA, test x$enable_cuda = xyes)
  328. if test x$enable_cuda = xyes; then
  329. AC_DEFINE(STARPU_USE_CUDA, [1], [CUDA support is activated])
  330. # On Darwin, the libstdc++ dependency is not automatically added by nvcc
  331. # case "$target" in
  332. # *-*darwin*) AC_HAVE_LIBRARY([stdc++], []) ;;
  333. # #*-*darwin*) AC_HAVE_LIBRARY([stdc++], [STARPU_CUDA_LDFLAGS="$STARPU_CUDA_LDFLAGS -lstdc++"]) ;;
  334. # esac
  335. STARPU_CUDA_LDFLAGS="$STARPU_CUDA_LDFLAGS -lcuda"
  336. STARPU_CUFFT_LDFLAGS="-lcufft"
  337. if test "$F77" = "gfortran" ; then
  338. STARPU_CUDA_FORTRAN_LDFLAGS="-lgfortran"
  339. AC_SUBST(STARPU_CUDA_FORTRAN_LDFLAGS)
  340. fi
  341. #in case this is a 64bit setup, we tell nvcc to use a -m64 flag
  342. if test x$SIZEOF_VOID_P = x8; then
  343. NVCCFLAGS="${NVCCFLAGS} -m64"
  344. AC_SUBST(NVCCFLAGS)
  345. fi
  346. fi
  347. have_magma=no
  348. if test x$enable_cuda = xyes; then
  349. PKG_CHECK_MODULES([MAGMA], [magma], [
  350. AC_DEFINE([STARPU_HAVE_MAGMA], [1], [Define to 1 if you have the MAGMA library.])
  351. AC_SUBST([STARPU_HAVE_MAGMA], [1])
  352. have_magma=yes
  353. ], [:])
  354. fi
  355. AM_CONDITIONAL(STARPU_HAVE_MAGMA, [test x$have_magma = xyes])
  356. AC_MSG_CHECKING(whether MAGMA should be used)
  357. AC_MSG_RESULT($have_magma)
  358. # cufftDoubleComplex may not be available on an old CUDA setup
  359. AC_CHECK_TYPE(cufftDoubleComplex,
  360. [have_cufftdoublecomplex=yes],
  361. [have_cufftdoublecomplex=no], [#include <cufft.h>])
  362. AM_CONDITIONAL(STARPU_HAVE_CUFFTDOUBLECOMPLEX, test x$have_cufftdoublecomplex = xyes)
  363. if test x$have_cufftdoublecomplex = xyes; then
  364. AC_DEFINE(STARPU_HAVE_CUFFTDOUBLECOMPLEX, [1], [cufftDoubleComplex is available])
  365. fi
  366. # The CURAND library is only available since CUDA 3.2
  367. have_curand=$enable_cuda
  368. if test x$enable_cuda = xyes; then
  369. SAVED_LDFLAGS="${LDFLAGS}"
  370. LDFLAGS="${LDFLAGS} ${STARPU_CUDA_LDFLAGS}"
  371. AC_HAVE_LIBRARY([curand],[have_curand=yes],[have_curand=no])
  372. LDFLAGS="${SAVED_LDFLAGS}"
  373. fi
  374. AC_MSG_CHECKING(whether CURAND is available)
  375. AC_MSG_RESULT($have_curand)
  376. if test x$have_curand = xyes; then
  377. AC_DEFINE(STARPU_HAVE_CURAND,[1], [CURAND is available])
  378. STARPU_CURAND_LDFLAGS="$STARPU_CURAND_LDFLAGS -lcurand"
  379. AC_SUBST(STARPU_CURAND_LDFLAGS)
  380. fi
  381. # Peer transfers are only supported since CUDA 4.0
  382. # Disable them if user explicity wants to disable them
  383. AC_ARG_ENABLE(cuda_memcpy_peer, [AS_HELP_STRING([--disable-cuda-memcpy-peer], [do not allow peer transfers when using CUDA 4.0])],, [enable_cuda_memcpy_peer=yes])
  384. have_cuda_memcpy_peer=no
  385. if test x$enable_cuda_memcpy_peer = xyes -a x$enable_cuda = xyes ; then
  386. SAVED_LDFLAGS="${LDFLAGS}"
  387. LDFLAGS="${LDFLAGS} ${STARPU_CUDA_LDFLAGS}"
  388. AC_CHECK_FUNC([cudaMemcpyPeer], have_cuda_memcpy_peer=yes, have_cuda_memcpy_peer=no)
  389. LDFLAGS="${SAVED_LDFLAGS}"
  390. fi
  391. if test x$have_cuda_memcpy_peer = xyes; then
  392. AC_DEFINE(HAVE_CUDA_MEMCPY_PEER,[],[Peer transfers are supported in CUDA])
  393. fi
  394. if test x$enable_cuda = xyes; then
  395. if test x$starpu_windows != xyes ; then
  396. STARPU_CUDA_LDFLAGS="$STARPU_CUDA_LDFLAGS -lstdc++"
  397. fi
  398. AC_SUBST(STARPU_CUDA_LDFLAGS)
  399. AC_SUBST(STARPU_CUFFT_LDFLAGS)
  400. AC_SUBST(STARPU_CUDA_CPPFLAGS)
  401. fi
  402. ###############################################################################
  403. # #
  404. # OpenCL settings #
  405. # #
  406. ###############################################################################
  407. AC_MSG_CHECKING(maximum number of OpenCL devices)
  408. AC_ARG_ENABLE(maxopencldev, [AS_HELP_STRING([--enable-maxopencldev=<number>],
  409. [maximum number of OPENCL devices])],
  410. nmaxopencldev=$enableval, nmaxopencldev=8)
  411. AC_MSG_RESULT($nmaxopencldev)
  412. AC_DEFINE_UNQUOTED(STARPU_MAXOPENCLDEVS, [$nmaxopencldev],
  413. [maximum number of OPENCL devices])
  414. AC_ARG_ENABLE(opencl, [AS_HELP_STRING([--disable-opencl],
  415. [do not use OpenCL device(s)])],, [enable_opencl=maybe])
  416. AC_DEFUN([STARPU_CHECK_OPENCL],
  417. [
  418. __opencl_dir=$1
  419. __opencl_include_dir=$2
  420. __opencl_lib_dir=$3
  421. if test "$__opencl_dir" != "no" ; then
  422. AC_MSG_CHECKING(whether OpenCL is available in $__opencl_dir)
  423. else
  424. AC_MSG_CHECKING(whether OpenCL is available)
  425. fi
  426. AC_MSG_RESULT()
  427. if test "$__opencl_include_dir" = "no" -a "$__opencl_dir" != "no" ; then
  428. __opencl_include_dir="$__opencl_dir/include"
  429. fi
  430. if test "$__opencl_lib_dir" = "no" -a "$__opencl_dir" != "no" ; then
  431. __opencl_lib_dir="$__opencl_dir/lib"
  432. fi
  433. SAVED_CPPFLAGS="$CPPFLAGS"
  434. SAVED_LDFLAGS="${LDFLAGS}"
  435. if test "$__opencl_include_dir" != "no" ; then
  436. CPPFLAGS="${CPPFLAGS} -I$__opencl_include_dir"
  437. fi
  438. AC_CHECK_HEADER([CL/cl.h],[have_valid_opencl=yes],[have_valid_opencl=no])
  439. unset ac_cv_header_CL_cl_h
  440. if test "$have_valid_opencl" = "yes" ; then
  441. if test "$__opencl_lib_dir" != "no"; then
  442. LDFLAGS="${SAVED_LDFLAGS} -L$__opencl_lib_dir"
  443. fi
  444. AC_HAVE_LIBRARY([OpenCL],[have_valid_opencl=yes],[have_valid_opencl=no])
  445. unset ac_cv_lib_OpenCL_main
  446. if test "$have_valid_opencl" = "no" ; then
  447. if test "$3" = "no" -a "$__opencl_dir" != "no" ; then
  448. __opencl_lib_dir="$__opencl_dir/lib64"
  449. LDFLAGS="${SAVED_LDFLAGS} -L$__opencl_lib_dir"
  450. AC_HAVE_LIBRARY([OpenCL],[have_valid_opencl=yes],[have_valid_opencl=no])
  451. unset ac_cv_lib_OpenCL_main
  452. fi
  453. fi
  454. fi
  455. if test "$have_valid_opencl" = "yes" -a "$__opencl_include_dir" != "no"; then
  456. STARPU_OPENCL_CPPFLAGS="-I$__opencl_include_dir"
  457. AC_CHECK_HEADERS([CL/cl_ext.h])
  458. fi
  459. CPPFLAGS="${SAVED_CPPFLAGS}"
  460. LDFLAGS="${SAVED_LDFLAGS}"
  461. if test "$have_valid_opencl" = "yes" ; then
  462. if test "$__opencl_lib_dir" != "no"; then
  463. STARPU_OPENCL_LDFLAGS="-L$__opencl_lib_dir"
  464. fi
  465. STARPU_OPENCL_LDFLAGS="${STARPU_OPENCL_LDFLAGS} -lOpenCL"
  466. fi
  467. ])
  468. #AC_MSG_CHECKING(whether OpenCL is available)
  469. AC_ARG_WITH(opencl-dir,
  470. [AS_HELP_STRING([--with-opencl-dir=<path>],
  471. [specify OpenCL installation directory])],
  472. [
  473. opencl_dir="$withval"
  474. # in case this was not explicit yet
  475. enable_opencl=yes
  476. ], opencl_dir=no)
  477. AC_ARG_WITH(opencl-include-dir,
  478. [AS_HELP_STRING([--with-opencl-include-dir=<path>],
  479. [specify where OpenCL headers are installed])],
  480. [
  481. opencl_include_dir="$withval"
  482. # in case this was not explicit yet
  483. enable_opencl=yes
  484. ], [opencl_include_dir=no])
  485. AC_ARG_WITH(opencl-lib-dir,
  486. [AS_HELP_STRING([--with-opencl-lib-dir=<path>],
  487. [specify where OpenCL libraries are installed])],
  488. [
  489. opencl_lib_dir="$withval"
  490. # in case this was not explicit yet
  491. enable_opencl=yes
  492. ], [opencl_lib_dir=no])
  493. if test x$enable_opencl = xyes -o x$enable_opencl = xmaybe; then
  494. STARPU_CHECK_OPENCL($opencl_dir, $opencl_include_dir, $opencl_lib_dir)
  495. if test "$have_valid_opencl" = "no" ; then
  496. for f in "/usr/local/cuda" "/c/cuda" "/cygdrive/c/cuda" "/opt/cuda" "$CUDA_INC_PATH" "$CUDA_INSTALL_PATH" ; do
  497. STARPU_CHECK_OPENCL($f, "no", "no")
  498. if test "$have_valid_opencl" = "yes" ; then
  499. break
  500. fi
  501. done
  502. fi
  503. # in case OpenCL was explicitely required, but is not available, this is an error
  504. if test x$enable_opencl = xyes -a x$have_valid_opencl = no; then
  505. AC_MSG_ERROR([cannot find OpenCL])
  506. fi
  507. # now we enable OpenCL if and only if a proper setup is available
  508. enable_opencl=$have_valid_opencl
  509. fi
  510. AC_MSG_CHECKING(whether OpenCL should be used)
  511. AC_MSG_RESULT($enable_opencl)
  512. AC_SUBST(STARPU_USE_OPENCL, $enable_opencl)
  513. AM_CONDITIONAL(STARPU_USE_OPENCL, test x$enable_opencl = xyes)
  514. if test x$enable_opencl = xyes ; then
  515. AC_DEFINE(STARPU_USE_OPENCL, [1], [OpenCL support is activated])
  516. STARPU_OPENCL_CPPFLAGS="${STARPU_OPENCL_CPPFLAGS} -DSTARPU_OPENCL_DATADIR=${datarootdir}/starpu/opencl"
  517. AC_SUBST(STARPU_OPENCL_DATAdir, "$(eval echo ${datarootdir}/starpu/opencl/examples)")
  518. AC_SUBST(STARPU_OPENCL_CPPFLAGS)
  519. AC_SUBST(STARPU_OPENCL_LDFLAGS)
  520. fi
  521. ###############################################################################
  522. # #
  523. # Cell settings #
  524. # #
  525. ###############################################################################
  526. #TODO fix the default dir
  527. AC_ARG_ENABLE(gordon, [AS_HELP_STRING([--enable-gordon],
  528. [use Cell SPUs])],, enable_gordon=maybe)
  529. if test x$enable_gordon = xyes -o x$enable_gordon = xmaybe; then
  530. AC_ARG_WITH(gordon-dir, [AS_HELP_STRING([--with-gordon-dir=<path>],
  531. [specify Gordon installation directory (default is /usr/local/)])],
  532. [
  533. gordon_dir="$withval"
  534. enable_gordon=yes
  535. ], gordon_dir=/usr/local/)
  536. # do we have a valid Gordon setup ?
  537. have_valid_gordon=yes
  538. # can we use dynamic code loading facilities ?
  539. AC_CHECK_LIB(elf, elf_memory,, [have_valid_gordon=no])
  540. AC_CHECK_LIB(spe2, spe_context_create,,[have_valid_gordon=no])
  541. AC_CHECK_FUNC(spe_in_mbox_write, [], [have_valid_gordon=no])
  542. PKG_PROG_PKG_CONFIG
  543. if test -d "$gordon_dir"; then
  544. PKG_CONFIG_PATH="${PKG_CONFIG_PATH}:$gordon_dir"
  545. fi
  546. AC_SUBST(PKG_CONFIG_PATH)
  547. PKG_CHECK_MODULES([GORDON], [libgordon], [], have_valid_gordon=no)
  548. CPPFLAGS="${CPPFLAGS} ${GORDON_CFLAGS}"
  549. LIBS="${LIBS} ${GORDON_LIBS}"
  550. # AC_CHECK_FUNC(gordon_init, [gordon], [have_valid_gordon=no])
  551. # in case Gordon was explicitely required, but is not available, this is an error
  552. if test x$enable_gordon = xyes -a x$have_valid_gordon = no; then
  553. AC_MSG_ERROR([cannot find Gordon])
  554. fi
  555. # now we enable Gordon if and only if a proper setup is available
  556. enable_gordon=$have_valid_gordon
  557. fi
  558. AC_MSG_CHECKING(whether GORDON should be used)
  559. AC_MSG_RESULT($enable_gordon)
  560. AC_SUBST(STARPU_USE_GORDON, $enable_gordon)
  561. AM_CONDITIONAL(STARPU_USE_GORDON, test x$enable_gordon = xyes)
  562. if test x$enable_gordon = xyes; then
  563. AC_DEFINE(STARPU_USE_GORDON, [1], [Cell support is enabled])
  564. GORDON_REQUIRES=gordon
  565. fi
  566. AC_SUBST(GORDON_REQUIRES)
  567. AC_MSG_CHECKING(whether blocking drivers should be disabled)
  568. AC_ARG_ENABLE(blocking-drivers, [AS_HELP_STRING([--disable-blocking-drivers], [disable blocking drivers])],
  569. enable_blocking=$enableval, enable_blocking=$enable_gordon)
  570. AC_MSG_RESULT($enable_blocking)
  571. if test x$enable_blocking = xno; then
  572. AC_DEFINE(STARPU_NON_BLOCKING_DRIVERS, [1], [drivers must progress])
  573. fi
  574. ###############################################################################
  575. # #
  576. # Debug and Performance analysis tools #
  577. # #
  578. ###############################################################################
  579. AC_MSG_CHECKING(whether debug mode should be enabled)
  580. AC_ARG_ENABLE(debug, [AS_HELP_STRING([--enable-debug], [enable debug mode])],
  581. enable_debug=$enableval, enable_debug=no)
  582. AC_MSG_RESULT($enable_debug)
  583. if test x$enable_debug = xyes; then
  584. CFLAGS="$CFLAGS -O0"
  585. else
  586. CFLAGS="$CFLAGS -O3"
  587. fi
  588. CFLAGS+=" -gdwarf-2 -g3 "
  589. AC_MSG_CHECKING(whether extra checks should be performed)
  590. AC_ARG_ENABLE(fast, [AS_HELP_STRING([--enable-fast],
  591. [do not enforce assertions])],
  592. enable_fast=$enableval, enable_fast=no)
  593. AC_MSG_RESULT($enable_fast)
  594. if test x$enable_fast = xyes; then
  595. AC_DEFINE(STARPU_NO_ASSERT, [1], [disable assertions])
  596. fi
  597. AC_MSG_CHECKING(whether debug messages should be displayed)
  598. AC_ARG_ENABLE(verbose, [AS_HELP_STRING([--enable-verbose],
  599. [display verbose debug messages])],
  600. enable_verbose=$enableval, enable_verbose=no)
  601. AC_MSG_RESULT($enable_verbose)
  602. if test x$enable_verbose = xyes; then
  603. AC_DEFINE(STARPU_VERBOSE, [1], [display verbose debug messages])
  604. fi
  605. AC_MSG_CHECKING(whether coverage testing should be enabled)
  606. AC_ARG_ENABLE(coverage, [AS_HELP_STRING([--enable-coverage],
  607. [enable coverage checking])],
  608. enable_coverage=$enableval, enable_coverage=no)
  609. AC_MSG_RESULT($enable_coverage)
  610. AC_SUBST(COVERAGE, $enable_coverage)
  611. AM_CONDITIONAL(STARPU_COVERAGE_ENABLED, [test "x$enable_coverage" = "xyes"])
  612. if test x$enable_coverage = xyes; then
  613. CPPFLAGS="${CPPFLAGS} --coverage"
  614. LDFLAGS="${LDFLAGS} --coverage"
  615. fi
  616. # shall we use FxT to generate trace of the execution ?
  617. AC_MSG_CHECKING(whether FxT traces should be generated)
  618. AC_ARG_WITH(fxt, [AS_HELP_STRING([--with-fxt[=<dir>]], [generate fxt traces])],
  619. [
  620. if test x$withval != xno; then
  621. use_fxt=yes
  622. if test x$withval = xyes; then
  623. AC_MSG_RESULT(yes)
  624. use_fxt_from_system=yes
  625. else
  626. # use specified path
  627. # TODO check if the dir is actually containing FxT
  628. use_fxt_from_system=no
  629. fxtdir=$withval
  630. AC_MSG_RESULT(yes using $fxtdir)
  631. AC_SUBST(FXTDIR, $fxtdir)
  632. fi
  633. else
  634. use_fxt=no
  635. AC_MSG_RESULT(no)
  636. fi
  637. ],
  638. [
  639. use_fxt=no
  640. AC_MSG_RESULT(no)
  641. ])
  642. AC_SUBST(STARPU_USE_FXT, $use_fxt)
  643. AM_CONDITIONAL(STARPU_USE_FXT, test x$use_fxt = xyes)
  644. if test x$use_fxt = xyes; then
  645. AC_DEFINE(STARPU_USE_FXT, [1], [enable FxT traces])
  646. AC_DEFINE(CONFIG_FUT, [1], [enable FUT traces])
  647. if test x$use_fxt_from_system = xno; then
  648. CPPFLAGS="${CPPFLAGS} -I$fxtdir/include/ "
  649. LDFLAGS="${LDFLAGS} -L$fxtdir/lib/ -lfxt"
  650. else
  651. PKG_CHECK_MODULES([FXT], [fxt])
  652. fi
  653. # if we use monotonic clocks, FxT uses -lrt
  654. AC_CHECK_LIB(rt, clock_gettime,,AC_MSG_ERROR([cannot find clock_gettime]))
  655. fi
  656. AC_MSG_CHECKING(whether performance debugging should be enabled)
  657. AC_ARG_ENABLE(perf-debug, [AS_HELP_STRING([--enable-perf-debug],
  658. [enable performance debugging through gprof])],
  659. enable_perf_debug=$enableval, enable_perf_debug=no)
  660. AC_MSG_RESULT($enable_perf_debug)
  661. AC_SUBST(STARPU_PERF_DEBUG, $enable_perf_debug)
  662. if test x$enable_perf_debug = xyes; then
  663. AC_DEFINE(STARPU_PERF_DEBUG, [1], [enable performance debug])
  664. CPPFLAGS="${CPPFLAGS} -pg -fprofile-arcs "
  665. LDFLAGS="${LDFLAGS} -pg -fprofile-arcs "
  666. fi
  667. AC_MSG_CHECKING(whether performance model debugging should be enabled)
  668. AC_ARG_ENABLE(model-debug, [AS_HELP_STRING([--enable-model-debug],
  669. [enable performance model debugging])],
  670. enable_model_debug=$enableval, enable_model_debug=no)
  671. AC_MSG_RESULT($enable_model_debug)
  672. if test x$enable_model_debug = xyes; then
  673. AC_DEFINE(STARPU_MODEL_DEBUG, [1], [enable performance model debug])
  674. fi
  675. AC_MSG_CHECKING(whether statistics should be generated)
  676. AC_ARG_ENABLE(stats, [AS_HELP_STRING([--enable-stats],
  677. [enable statistics])],
  678. enable_stats=$enableval, enable_stats=no)
  679. AC_MSG_RESULT($enable_stats)
  680. AC_SUBST(STATS, $enable_stats)
  681. AC_SUBST(STARPU_DATA_STATS, $enable_stats)
  682. if test x$enable_stats = xyes; then
  683. AC_DEFINE(STARPU_DATA_STATS, [1], [enable statistics])
  684. fi
  685. AC_CHECK_HEADERS([glpk.h])
  686. STARPU_HAVE_LIBRARY(GLPK, [glpk])
  687. ###############################################################################
  688. # #
  689. # Miscellaneous options for StarPU #
  690. # #
  691. ###############################################################################
  692. AC_MSG_CHECKING(how many buffers can be manipulated per task)
  693. AC_ARG_ENABLE(maxbuffers, [AS_HELP_STRING([--enable-maxbuffers=<nbuffers>],
  694. [maximum number of buffers per task])],
  695. nmaxbuffers=$enableval, nmaxbuffers=8)
  696. AC_MSG_RESULT($nmaxbuffers)
  697. AC_DEFINE_UNQUOTED(STARPU_NMAXBUFS, [$nmaxbuffers],
  698. [how many buffers can be manipulated per task])
  699. # We have one memory node shared by all CPU workers, one node per GPU, and
  700. # currently the Cell driver is using the same memory node as the CPU.
  701. maxnodes=1
  702. if test x$enable_cuda = xyes ; then
  703. # we could have used nmaxcudadev + 1, but this would certainly give an
  704. # odd number.
  705. maxnodes=`expr $maxnodes + $nmaxcudadev`
  706. fi
  707. if test x$enable_opencl = xyes ; then
  708. # we could have used nmaxcudadev + 1, but this would certainly give an
  709. # odd number.
  710. maxnodes=`expr $maxnodes + $nmaxopencldev`
  711. fi
  712. # todo: set maxnodes to the next power of 2 greater than maxnodes
  713. AC_MSG_CHECKING(maximum number of memory nodes)
  714. AC_MSG_RESULT($maxnodes)
  715. AC_DEFINE_UNQUOTED(STARPU_MAXNODES, [$maxnodes],
  716. [maximum number of memory nodes])
  717. AC_MSG_CHECKING(whether allocation cache should be used)
  718. AC_ARG_ENABLE(allocation-cache, [AS_HELP_STRING([--enable-allocation-cache],
  719. [enable data allocation cache])],
  720. enable_allocation_cache=$enableval, enable_allocation_cache=no)
  721. AC_MSG_RESULT($enable_allocation_cache)
  722. if test x$enable_allocation_cache = xyes; then
  723. AC_DEFINE(STARPU_USE_ALLOCATION_CACHE, [1], [enable data allocation cache])
  724. fi
  725. AC_ARG_WITH(perf-model-dir, [AS_HELP_STRING([--with-perf-model-dir=<dir>], [specify where performance models shoulds be stored])],
  726. [
  727. if test x$withval = xno; then
  728. AC_MSG_ERROR(--without-perf-model-dir is not a valid option)
  729. fi
  730. perf_model_dir="$withval"
  731. have_explicit_perf_model_dir=yes
  732. AC_DEFINE_UNQUOTED(STARPU_PERF_MODEL_DIR, ["$perf_model_dir"], [performance models location])
  733. ], [
  734. # by default, we put the performance models in
  735. # $HOME/.starpu/sampling/
  736. have_explicit_perf_model_dir=no
  737. perf_model_dir="\$HOME/.starpu/sampling/"
  738. ]
  739. )
  740. AC_MSG_CHECKING(using explicit performance model location)
  741. AC_MSG_RESULT($have_explicit_perf_model_dir)
  742. AC_MSG_CHECKING(performance models location)
  743. AC_MSG_RESULT($perf_model_dir)
  744. # On many multicore CPUs, clock cycles are not synchronized
  745. AC_CHECK_LIB([rt], [clock_gettime])
  746. AC_CHECK_FUNCS([clock_gettime])
  747. # Compute the maximum number of workers (we round it to 16 for alignment
  748. # purposes).
  749. nmaxworkers=`expr 16 \* \( \( $maxcpus + $nmaxcudadev + $nmaxopencldev + 15 \) / 16 \) `
  750. AC_MSG_CHECKING(Maximum number of workers)
  751. AC_MSG_RESULT($nmaxworkers)
  752. AC_DEFINE_UNQUOTED(STARPU_NMAXWORKERS, [$nmaxworkers], [Maximum number of workers])
  753. ###############################################################################
  754. # #
  755. # MPI #
  756. # #
  757. ###############################################################################
  758. AC_ARG_WITH(mpicc, [AS_HELP_STRING([--with-mpicc[=<path to mpicc>]],
  759. [Path of the mpicc compiler])],
  760. [
  761. if test x$withval = xyes; then
  762. AC_MSG_ERROR(--with-mpicc must be given a pathname)
  763. else
  764. mpicc_path=$withval
  765. fi
  766. ],
  767. [
  768. # nothing was specified: default value is used
  769. AC_PATH_PROG(mpicc_path, mpicc, [no], [])
  770. ])
  771. # We test if the MPICC compiler exists
  772. if test ! -x $mpicc_path; then
  773. #MPICC does not exists or is not executable
  774. AC_MSG_RESULT(The mpicc compiler is not valid)
  775. use_mpi=no
  776. else
  777. use_mpi=yes
  778. fi
  779. AC_MSG_CHECKING(mpicc path)
  780. AC_MSG_RESULT($mpicc_path)
  781. AC_SUBST(MPICC, $mpicc_path)
  782. if test x$use_mpi = xyes; then
  783. cc_or_mpicc=$mpicc_path
  784. else
  785. cc_or_mpicc=$CC
  786. fi
  787. AC_SUBST(CC_OR_MPICC, $cc_or_mpicc)
  788. # If the user specifically asks for it, or if we are in a developer checkout, we enable mpi check
  789. AC_ARG_ENABLE(mpi-check, AC_HELP_STRING([--enable-mpi-check], [Enable execution of MPI testcases]))
  790. running_mpi_check=0
  791. if test -d "$srcdir/.svn" ; then
  792. running_mpi_check=yes
  793. fi
  794. if test x$enable_mpi_check = xyes ; then
  795. running_mpi_check=yes
  796. fi
  797. if test x$enable_mpi_check = xno ; then
  798. running_mpi_check=no
  799. fi
  800. # Check if mpiexec is available
  801. AC_ARG_WITH(mpiexec, [AS_HELP_STRING([--with-mpiexec[=<path to mpiexec>]],
  802. [Path of mpiexec])],
  803. [
  804. if test x$withval = xyes; then
  805. AC_MSG_ERROR(--with-mpiexec must be given a pathname)
  806. else
  807. mpiexec_path=$withval
  808. fi
  809. ],
  810. [
  811. # nothing was specified: look in the path
  812. AC_PATH_PROG(mpiexec_path, mpiexec, [no], [$(dirname $mpicc_path):$PATH])
  813. ])
  814. AC_MSG_CHECKING(whether mpiexec is available)
  815. AC_MSG_RESULT($mpiexec_path)
  816. # We test if MPIEXEC exists
  817. if test ! -x $mpiexec_path; then
  818. #MPIEXEC does not exists or is not executable
  819. AC_MSG_RESULT(The mpiexec script is not valid)
  820. running_mpi_check=no
  821. mpiexec_path=""
  822. fi
  823. AM_CONDITIONAL(STARPU_MPI_CHECK, test x$running_mpi_check = xyes)
  824. if test x$use_mpi = xyes; then
  825. AC_MSG_CHECKING(whether MPI tests should be run)
  826. AC_MSG_RESULT($running_mpi_check)
  827. AC_SUBST(MPIEXEC,$mpiexec_path)
  828. fi
  829. AC_MSG_CHECKING(whether the StarPU MPI library should be generated)
  830. AC_MSG_RESULT($use_mpi)
  831. AC_SUBST(USE_MPI, $use_mpi)
  832. AM_CONDITIONAL(USE_MPI, test x$use_mpi = xyes)
  833. if test x$use_mpi = xyes; then
  834. AC_DEFINE(STARPU_USE_MPI,[],[whether the StarPU MPI library is available])
  835. fi
  836. ###############################################################################
  837. # #
  838. # StarPU-Top #
  839. # #
  840. ###############################################################################
  841. build_starpu_top=no
  842. AC_PATH_PROGS([QMAKE], [qmake-qt4 qmake], [not-found])
  843. if test x$QMAKE != xnot-found; then
  844. QMAKE_VERSION=`$QMAKE --version 2>&1 | head -n 1 | cut -d '.' -f 1 | cut -d ' ' -f 3`
  845. if test $QMAKE_VERSION -ge 2 ; then
  846. PKG_CHECK_EXISTS([QtGui QtNetwork QtOpenGL QtSql], [
  847. QT_MAJVERSION=`$PKG_CONFIG --modversion QtGui | cut -d '.' -f 1`
  848. QT_MINVERSION=`$PKG_CONFIG --modversion QtGui | cut -d '.' -f 2`
  849. if test $QT_MAJVERSION -gt 4 -o \( $QT_MAJVERSION -eq 4 -a $QT_MINVERSION -ge 7 \) ; then
  850. build_starpu_top=yes
  851. fi
  852. QWT_PRI=embed
  853. AC_ARG_WITH(qwt-include-dir,
  854. [AS_HELP_STRING([--with-qwt-include-dir=<path>],
  855. [specify installed libqwt include path])],
  856. [
  857. STARPU_QWT_CPPFLAGS="-I$withval"
  858. AC_SUBST(STARPU_QWT_CPPFLAGS)
  859. QWT_PRI=system
  860. ])
  861. AC_ARG_WITH(qwt-lib-dir,
  862. [AS_HELP_STRING([--with-qwt-lib-dir=<path>],
  863. [specify installed libqwt library path])],
  864. [
  865. STARPU_QWT_LDFLAGS="-L$withval"
  866. QWT_PRI=system
  867. ])
  868. AC_ARG_WITH(qwt-lib,
  869. [AS_HELP_STRING([--with-qwt-lib=<path>],
  870. [specify installed libqwt library name])],
  871. [
  872. STARPU_QWT_LDFLAGS="${STARPU_QWT_LDFLAGS} -l$withval"
  873. QWT_PRI=system
  874. ])
  875. AC_SUBST(QWT_PRI)
  876. ])
  877. fi
  878. fi
  879. AM_CONDITIONAL(BUILD_STARPU_TOP, test x$build_starpu_top = xyes)
  880. ###############################################################################
  881. # #
  882. # Flags for C Compiler #
  883. # #
  884. ###############################################################################
  885. # IS_SUPPORTED_CFLAG(flag)
  886. # ------------------------
  887. # Check if the CFLAGS `flag' is supported by the compiler
  888. AC_DEFUN([IS_SUPPORTED_CFLAG],
  889. [
  890. AC_REQUIRE([AC_PROG_CC])
  891. AC_MSG_CHECKING([whether compiler support $1])
  892. SAVED_CFLAGS="$CFLAGS"
  893. CFLAGS="$1 -we10006"
  894. AC_COMPILE_IFELSE(
  895. AC_LANG_PROGRAM(
  896. [[]],
  897. [[
  898. AC_LANG_SOURCE([
  899. const char *hello = "Hello World";
  900. ])
  901. ]]
  902. ),
  903. [
  904. GLOBAL_AM_CFLAGS="$GLOBAL_AM_CFLAGS $1"
  905. AC_MSG_RESULT(yes)
  906. ],
  907. AC_MSG_RESULT(no)
  908. )
  909. CFLAGS="$SAVED_CFLAGS"
  910. ])
  911. IS_SUPPORTED_CFLAG(-W)
  912. IS_SUPPORTED_CFLAG(-Wall)
  913. IS_SUPPORTED_CFLAG(-Wextra)
  914. AC_SUBST(GLOBAL_AM_CFLAGS)
  915. if test "x$STARPU_DEVEL" != x; then
  916. AC_DEFINE(STARPU_DEVEL, [1], [enable developer warnings])
  917. fi
  918. ###############################################################################
  919. # #
  920. # GCC extensions #
  921. # #
  922. ###############################################################################
  923. AC_ARG_ENABLE([gcc-extensions],
  924. [AS_HELP_STRING([--enable-gcc-extensions],
  925. [build the GCC plug-in that provides C language extensions (experimental)])],
  926. [enable_gcc_plugin="$enableval"],
  927. [enable_gcc_plugin="no"])
  928. if test "x$enable_gcc_plugin" = "xyes"; then
  929. STARPU_GCC_PLUGIN_SUPPORT
  930. if test "x$ac_cv_have_gcc_plugins" != "xyes"; then
  931. AC_MSG_ERROR([This compiler lacks GCC plug-in support.])
  932. fi
  933. build_gcc_plugin="yes"
  934. # GNU Guile 1.8/2.0 is used to run the test suite.
  935. AC_PATH_PROG([GUILE], [guile])
  936. if test "x$GUILE" != "x"; then
  937. run_gcc_plugin_test_suite="yes"
  938. else
  939. run_gcc_plugin_test_suite="no"
  940. fi
  941. else
  942. build_gcc_plugin="no"
  943. run_gcc_plugin_test_suite="no"
  944. fi
  945. # Bison is used to generate the C expression parser. The generated
  946. # parser is part of the distribution, though.
  947. AC_PROG_YACC
  948. AM_CONDITIONAL([BUILD_GCC_PLUGIN], [test "x$build_gcc_plugin" = "xyes"])
  949. AM_CONDITIONAL([HAVE_GUILE], [test "x$GUILE" != "x"])
  950. ###############################################################################
  951. # #
  952. # OpenCL interface #
  953. # #
  954. ###############################################################################
  955. AC_ARG_ENABLE([socl],
  956. [AS_HELP_STRING([--enable-socl],
  957. [build the OpenCL interface (SOCL)])],
  958. [enable_socl="$enableval"],
  959. [enable_socl="no"])
  960. if test "x$enable_socl" = "xyes"; then
  961. STARPU_SOCL_SUPPORT
  962. build_socl="yes"
  963. else
  964. build_socl="no"
  965. run_socl_test_suite="no"
  966. fi
  967. AM_CONDITIONAL([BUILD_SOCL], [test "x$build_socl" = "xyes"])
  968. AM_CONDITIONAL([STARPU_USE_SOCL], [test "x$build_socl" = "xyes"])
  969. ###############################################################################
  970. # #
  971. # Examples #
  972. # #
  973. ###############################################################################
  974. AC_ARG_ENABLE(opengl-render, [AS_HELP_STRING([--enable-opengl-render],
  975. [enable OpenGL rendering of some examples])],
  976. enable_opengl_render=$enableval, enable_opengl_render=no)
  977. if test x$enable_opengl_render = xyes; then
  978. STARPU_CHECK_LIB(OPENGL_RENDER, glut, glutInit,,AC_MSG_ERROR([cannot find glut]))
  979. STARPU_CHECK_LIB(OPENGL_RENDER, GL, glXCreateContext,,AC_MSG_ERROR([cannot find GL]))
  980. STARPU_CHECK_LIB(OPENGL_RENDER, GLU, gluLookAt,,AC_MSG_ERROR([cannot find GLU]))
  981. AC_DEFINE(STARPU_OPENGL_RENDER, [1], [enable OpenGL rendering of some examples])
  982. fi
  983. AC_MSG_CHECKING(whether OpenGL rendering is enabled)
  984. AC_SUBST(STARPU_OPENGL_RENDER, $enable_opengl_render)
  985. AC_MSG_RESULT($enable_opengl_render)
  986. AC_PATH_XTRA
  987. if test "x$x_includes" != "xNONE"; then
  988. AC_DEFINE(STARPU_HAVE_X11, [1], [enable X11])
  989. fi
  990. AM_CONDITIONAL([HAVE_X11], [test "x$x_includes" != "xNONE"])
  991. # In case there are BLAS kernels that are used by the example applications
  992. # we may specify which library to use. Note that this is not used for StarPU
  993. # itself.
  994. blas_lib=maybe
  995. AC_ARG_ENABLE(blas-lib,
  996. [ --enable-blas-lib[=blaslibname]:
  997. none [default]: no BLAS lib is used
  998. atlas: use ATLAS library
  999. goto: use GotoBLAS library],
  1000. [
  1001. if test "x$enableval" = "xatlas" ; then
  1002. blas_lib=atlas
  1003. elif test "x$enableval" = "xgoto" ; then
  1004. blas_lib=goto
  1005. elif test "x$enableval" = "xnone" ; then
  1006. blas_lib=none
  1007. elif test x$enableval = xno; then
  1008. blas_lib=none
  1009. else
  1010. echo
  1011. echo "Error!"
  1012. echo "Unknown BLAS library"
  1013. exit -1
  1014. fi
  1015. ])
  1016. if test x$blas_lib = xmaybe -o x$blas_lib = xgoto; then
  1017. AC_ARG_WITH(goto-dir, [AS_HELP_STRING([--with-goto-dir=<dir>], [specify GotoBLAS lib location])],
  1018. [
  1019. blas_lib=goto
  1020. gotodir=$withval
  1021. AC_SUBST(GOTODIR, $gotodir)
  1022. CPPFLAGS="${CPPFLAGS} -I$gotodir/ "
  1023. LDFLAGS="${LDFLAGS} -L$gotodir/ "
  1024. ]
  1025. )
  1026. if test x$blas_lib = xgoto; then
  1027. STARPU_CHECK_LIB(BLAS, gfortran, main,,)
  1028. # Perhaps that GotoBLAS2 is available instead (so that we have libgotoblas2.{so,a})
  1029. STARPU_CHECK_LIB(BLAS, goto2, sgemm_,, [havegoto2=no], [$STARPU_BLAS_LDFLAGS])
  1030. if test x$havegoto2 = xno; then
  1031. STARPU_CHECK_LIB(BLAS, goto, sgemm_,,AC_MSG_ERROR([cannot find goto lib]), [$STARPU_BLAS_LDFLAGS])
  1032. fi
  1033. AC_DEFINE(STARPU_GOTO, [1], [use STARPU_GOTO library])
  1034. fi
  1035. fi
  1036. if test x$blas_lib = xmaybe -o x$blas_lib = xatlas; then
  1037. AC_ARG_WITH(atlas-dir, [AS_HELP_STRING([--with-atlas-dir=<dir>], [specify ATLAS lib location])],
  1038. [
  1039. AC_MSG_CHECKING(STARPU_ATLAS location)
  1040. blas_lib=atlas
  1041. atlasdir=$withval
  1042. AC_MSG_RESULT($atlasdir)
  1043. AC_SUBST(ATLASDIR, $atlasdir)
  1044. CPPFLAGS="${CPPFLAGS} -I$atlasdir/include/ "
  1045. LDFLAGS="${LDFLAGS} -L$atlasdir/lib/ "
  1046. ]
  1047. )
  1048. if test x$blas_lib = xatlas; then
  1049. # test whether STARPU_ATLAS is actually available
  1050. AC_CHECK_HEADER([cblas.h],,AC_MSG_ERROR([cannot find atlas headers]))
  1051. STARPU_CHECK_LIB(BLAS, atlas, ATL_sgemm,,AC_MSG_ERROR([cannot find atlas lib]),)
  1052. STARPU_CHECK_LIB(BLAS, cblas, cblas_sgemm,,AC_MSG_ERROR([cannot find atlas lib]),[-latlas])
  1053. AC_DEFINE(STARPU_ATLAS, [1], [use STARPU_ATLAS library])
  1054. fi
  1055. fi
  1056. if test x$blas_lib = xmaybe; then
  1057. # Should we use MKL ?
  1058. AC_ARG_WITH(mkl-cflags, [AS_HELP_STRING([--with-mkl-cflags], [specify MKL compilation flags])],
  1059. [
  1060. CPPFLAGS="${CPPFLAGS} $withval"
  1061. blas_lib=mkl
  1062. ])
  1063. AC_ARG_WITH(mkl-ldflags, [AS_HELP_STRING([--with-mkl-ldflags], [specify MKL linking flags])],
  1064. [
  1065. LDFLAGS="${LDFLAGS} $withval"
  1066. blas_lib=mkl
  1067. ])
  1068. if test x$blas_lib = xmkl; then
  1069. AC_DEFINE(STARPU_MKL, [1], [use MKL library])
  1070. fi
  1071. fi
  1072. if test x$blas_lib = xmaybe; then
  1073. #perhaps it is possible to use some BLAS lib from the system
  1074. use_system_blas=no
  1075. STARPU_SEARCH_LIBS(BLAS,[sgemm_],[blas],use_system_blas=yes,,)
  1076. if test x$use_system_blas = xyes; then
  1077. AC_DEFINE(STARPU_SYSTEM_BLAS, [1], [use refblas library])
  1078. blas_lib=system
  1079. else
  1080. blas_lib=none
  1081. fi
  1082. fi
  1083. AM_CONDITIONAL(ATLAS_BLAS_LIB, test x$blas_lib = xatlas)
  1084. AM_CONDITIONAL(GOTO_BLAS_LIB, test x$blas_lib = xgoto)
  1085. AM_CONDITIONAL(MKL_BLAS_LIB, test x$blas_lib = xmkl)
  1086. AM_CONDITIONAL(SYSTEM_BLAS_LIB, test x$blas_lib = xsystem)
  1087. AM_CONDITIONAL(NO_BLAS_LIB, test x$blas_lib = xnone)
  1088. AC_MSG_CHECKING(which BLAS lib should be used)
  1089. AC_MSG_RESULT($blas_lib)
  1090. AC_SUBST(BLAS_LIB,$blas_lib)
  1091. ##########################################
  1092. # FFT #
  1093. ##########################################
  1094. have_fftw=no
  1095. have_fftwf=no
  1096. have_fftwl=no
  1097. PKG_CHECK_MODULES([FFTW], [fftw3], [
  1098. AC_DEFINE([STARPU_HAVE_FFTW], [1], [Define to 1 if you have the libfftw3 library.])
  1099. AC_SUBST([STARPU_HAVE_FFTW], [1])
  1100. have_fftw=yes
  1101. ], [:])
  1102. AM_CONDITIONAL(STARPU_HAVE_FFTW, [test x$have_fftw = xyes])
  1103. PKG_CHECK_MODULES([FFTWF], [fftw3f], [
  1104. AC_DEFINE([STARPU_HAVE_FFTWF], [1], [Define to 1 if you have the libfftw3f library.])
  1105. AC_SUBST([STARPU_HAVE_FFTWF], [1])
  1106. have_fftwf=yes
  1107. ], [:])
  1108. AM_CONDITIONAL(STARPU_HAVE_FFTWF, [test x$have_fftwf = xyes])
  1109. PKG_CHECK_MODULES([FFTWL], [fftw3l], [
  1110. AC_DEFINE([STARPU_HAVE_FFTWL], [1], [Define to 1 if you have the libfftw3l library.])
  1111. AC_SUBST([HAVE_FFTWFL], [1])
  1112. have_fftwl=yes
  1113. ], [:])
  1114. AM_CONDITIONAL(STARPU_HAVE_FFTWL, [test x$have_fftwl = xyes])
  1115. ##########################################
  1116. # hwloc #
  1117. ##########################################
  1118. AC_ARG_WITH([hwloc], [AS_HELP_STRING([--without-hwloc], [Disable hwloc (enabled by default)])])
  1119. SAVED_LDFLAGS="${LDFLAGS}"
  1120. SAVED_CPPFLAGS="${CPPFLAGS}"
  1121. AS_IF([test "x$with_hwloc" != "xno"], [
  1122. PKG_CHECK_MODULES([HWLOC],[hwloc], [
  1123. have_valid_hwloc=yes
  1124. have_pkgconfig_hwloc=yes], [
  1125. have_valid_hwloc=no
  1126. have_pkgconfig_hwloc=no])
  1127. AS_IF([test "$have_valid_hwloc" = "no"], [
  1128. hwloc_dir="$withval"
  1129. CPPFLAGS="${SAVED_CPPFLAGS} -I$hwloc_dir/include"
  1130. AC_CHECK_HEADER([hwloc.h],[have_valid_hwloc=yes],[have_valid_hwloc=no])
  1131. LDFLAGS="${SAVED_LDFLAGS} -L$hwloc_dir/lib"
  1132. AC_HAVE_LIBRARY([hwloc],[have_valid_hwloc=yes],[have_valid_hwloc=no])
  1133. ])
  1134. ],
  1135. have_valid_hwloc="no")
  1136. AS_IF([test "$have_valid_hwloc" = "yes"], [
  1137. AC_DEFINE([STARPU_HAVE_HWLOC], [1], [Define to 1 if you have the hwloc library.])
  1138. HWLOC_REQUIRES=hwloc
  1139. AC_SUBST([STARPU_HAVE_HWLOC], [1])
  1140. AS_IF([test "$have_pkgconfig_hwloc" = "no"], [
  1141. HWLOC_CFLAGS="-I$hwloc_dir/include"
  1142. HWLOC_LIBS="-L$hwloc_dir/lib -lhwloc"])
  1143. ])
  1144. LDFLAGS="${SAVED_LDFLAGS}"
  1145. CPPFLAGS="${SAVED_CPPFLAGS}"
  1146. AC_MSG_CHECKING(whether hwloc should be used)
  1147. AC_MSG_RESULT($have_valid_hwloc)
  1148. AC_SUBST(HWLOC_REQUIRES)
  1149. # is the header file f77.h available ?
  1150. have_f77_h=yes
  1151. AC_CHECK_HEADER([f77.h],,[have_f77_h=no])
  1152. AC_MSG_CHECKING(whether header file f77.h is available)
  1153. AC_MSG_RESULT($have_f77_h)
  1154. AC_SUBST(STARPU_HAVE_F77_H, $have_f77_h)
  1155. AM_CONDITIONAL(STARPU_HAVE_F77_H, test x$have_f77_h = xyes)
  1156. if test x$have_f77_h = xyes; then
  1157. AC_DEFINE([STARPU_HAVE_F77_H], [1], [Define to 1 if you have the <f77.h> header file.])
  1158. fi
  1159. # Do we want to run optional tests
  1160. AC_MSG_CHECKING(whether optional tests should be run)
  1161. AC_ARG_ENABLE(optional_tests, [AS_HELP_STRING([--optional-tests],
  1162. [run optional tests])],
  1163. want_optional_tests=$enableval, want_optional_tests=no)
  1164. AC_MSG_RESULT($want_optional_tests)
  1165. AM_CONDITIONAL([COND_OPT], [test "$want_optional_tests" = yes])
  1166. # File configuration
  1167. AC_CONFIG_COMMANDS([executable-scripts], [
  1168. chmod +x tests/regression/regression.sh
  1169. chmod +x gcc-plugin/tests/run-test
  1170. ])
  1171. AC_CONFIG_FILES(tests/regression/regression.sh tests/regression/profiles tests/regression/profiles.build.only)
  1172. AC_CONFIG_HEADER(src/common/config.h include/starpu_config.h)
  1173. if test $build_gcc_plugin == "yes" ; then
  1174. AC_CONFIG_HEADERS([gcc-plugin/src/starpu-gcc-config.h])
  1175. AC_OUTPUT([
  1176. gcc-plugin/Makefile
  1177. gcc-plugin/src/Makefile
  1178. gcc-plugin/tests/Makefile
  1179. gcc-plugin/tests/run-test
  1180. gcc-plugin/examples/Makefile
  1181. ])
  1182. fi
  1183. AC_OUTPUT([
  1184. Makefile
  1185. src/Makefile
  1186. tools/Makefile
  1187. socl/Makefile
  1188. socl/src/Makefile
  1189. libstarpu.pc
  1190. examples/Makefile
  1191. examples/opt/Makefile
  1192. examples/starpufft/Makefile
  1193. examples/stencil/Makefile
  1194. examples/socl/Makefile
  1195. tests/Makefile
  1196. tests/opt/Makefile
  1197. doc/Makefile
  1198. mpi/Makefile
  1199. starpu-top/StarPU-Top.pro
  1200. ])
  1201. AC_MSG_NOTICE([
  1202. CPUs enabled: $enable_cpu
  1203. CUDA enabled: $enable_cuda
  1204. OpenCL enabled: $enable_opencl
  1205. Cell enabled: $enable_gordon
  1206. GCC plug-in: $build_gcc_plugin
  1207. GCC plug-in test suite: $run_gcc_plugin_test_suite
  1208. Compile-time limits
  1209. (change these with --enable-maxcpus, --enable-maxcudadev,
  1210. --enable-maxopencldev, --enable-maxbuffers)
  1211. Maximum number of CPUs: $maxcpus
  1212. Maximum number of CUDA devices: $nmaxcudadev
  1213. Maximum number of OpenCL devices: $nmaxopencldev
  1214. Maximum number of memory nodes: $maxnodes
  1215. Maximum number of task buffers: $nmaxbuffers
  1216. GPU-GPU transfers: $have_cuda_memcpy_peer
  1217. Allocation cache: $enable_allocation_cache
  1218. MPI enabled: $use_mpi
  1219. SOCL enabled: $build_socl
  1220. Magma enabled: $have_magma
  1221. BLAS library: $blas_lib
  1222. hwloc: $have_valid_hwloc
  1223. FxT trace enabled: $use_fxt
  1224. StarPU-Top: $build_starpu_top
  1225. ])