configure.ac 46 KB

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