building.doxy 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. /*
  2. * This file is part of the StarPU Handbook.
  3. * Copyright (C) 2009--2011 Universit@'e de Bordeaux 1
  4. * Copyright (C) 2010, 2011, 2012, 2013 Centre National de la Recherche Scientifique
  5. * Copyright (C) 2011, 2012 Institut National de Recherche en Informatique et Automatique
  6. * See the file version.doxy for copying conditions.
  7. */
  8. /*! \page buildingAndInstalling Building and Installing StarPU
  9. \section installing_a_binary_package Installing a Binary Package
  10. One of the StarPU developers being a Debian Developer, the packages
  11. are well integrated and very uptodate. To see which packages are
  12. available, simply type:
  13. \verbatim
  14. $ apt-cache search starpu
  15. \endverbatim
  16. To install what you need, type:
  17. \verbatim
  18. $ sudo apt-get install libstarpu-1.0 libstarpu-dev
  19. \endverbatim
  20. \section installing_from_source Installing from Source
  21. StarPU can be built and installed by the standard means of the GNU
  22. autotools. The following chapter is intended to briefly remind how these tools
  23. can be used to install StarPU.
  24. \subsection optional_dependencies Optional Dependencies
  25. The <a href="http://www.open-mpi.org/software/hwloc"><c>hwloc</c> topology
  26. discovery library</a> is not mandatory to use StarPU but strongly
  27. recommended. It allows for topology aware scheduling, which improves
  28. performance. <c>hwloc</c> is available in major free operating system
  29. distributions, and for most operating systems.
  30. If <c>hwloc</c> is not available on your system, the option
  31. <c>--without-hwloc</c> should be explicitely given when calling the
  32. <c>configure</c> script. If <c>hwloc</c> is installed with a <c>pkg-config</c> file,
  33. no option is required, it will be detected automatically, otherwise
  34. <c>--with-hwloc=prefix</c> should be used to specify the location
  35. of <c>hwloc</c>.
  36. \subsection getting_sources Getting Sources
  37. StarPU's sources can be obtained from the <a href="http://runtime.bordeaux.inria.fr/StarPU/files/">download page of
  38. the StarPU website</a>.
  39. All releases and the development tree of StarPU are freely available
  40. on INRIA's gforge under the LGPL license. Some releases are available
  41. under the BSD license.
  42. The latest release can be downloaded from the <a href="http://gforge.inria.fr/frs/?group_id=1570">INRIA's gforge</a> or
  43. directly from the <a href="http://runtime.bordeaux.inria.fr/StarPU/files/">StarPU download page</a>.
  44. The latest nightly snapshot can be downloaded from the <a href="http://starpu.gforge.inria.fr/testing/">StarPU gforge website</a>.
  45. \verbatim
  46. $ wget http://starpu.gforge.inria.fr/testing/starpu-nightly-latest.tar.gz
  47. \endverbatim
  48. And finally, current development version is also accessible via svn.
  49. It should be used only if you need the very latest changes (i.e. less
  50. than a day!). Note that the client side of the software Subversion can
  51. be obtained from http://subversion.tigris.org. If you
  52. are running on Windows, you will probably prefer to use <a href="http://tortoisesvn.tigris.org/">TortoiseSVN</a>.
  53. \verbatim
  54. $ svn checkout svn://scm.gforge.inria.fr/svn/starpu/trunk StarPU
  55. \endverbatim
  56. \subsection configuring_starpu Configuring StarPU
  57. Running <c>autogen.sh</c> is not necessary when using the tarball
  58. releases of StarPU. If you are using the source code from the svn
  59. repository, you first need to generate the configure scripts and the
  60. Makefiles. This requires the availability of <c>autoconf</c>,
  61. <c>automake</c> >= 2.60, and <c>makeinfo</c>.
  62. \verbatim
  63. $ ./autogen.sh
  64. \endverbatim
  65. You then need to configure StarPU. Details about options that are
  66. useful to give to <c>./configure</c> are given in @ref{Compilation
  67. configuration}.
  68. \verbatim
  69. $ ./configure
  70. \endverbatim
  71. If <c>configure</c> does not detect some software or produces errors, please
  72. make sure to post the content of <c>config.log</c> when reporting the issue.
  73. By default, the files produced during the compilation are placed in
  74. the source directory. As the compilation generates a lot of files, it
  75. is advised to to put them all in a separate directory. It is then
  76. easier to cleanup, and this allows to compile several configurations
  77. out of the same source tree. For that, simply enter the directory
  78. where you want the compilation to produce its files, and invoke the
  79. <c>configure</c> script located in the StarPU source directory.
  80. \verbatim
  81. $ mkdir build
  82. $ cd build
  83. $ ../configure
  84. \endverbatim
  85. \subsection building_starpu Building StarPU
  86. \verbatim
  87. $ make
  88. \endverbatim
  89. Once everything is built, you may want to test the result. An
  90. extensive set of regression tests is provided with StarPU. Running the
  91. tests is done by calling <c>make check</c>. These tests are run every night
  92. and the result from the main profile is publicly <a href="http://starpu.gforge.inria.fr/testing/">available</a>.
  93. \verbatim
  94. $ make check
  95. \endverbatim
  96. \subsection installing_starpu Installing StarPU
  97. In order to install StarPU at the location that was specified during
  98. configuration:
  99. \verbatim
  100. $ make install
  101. \endverbatim
  102. Libtool interface versioning information are included in
  103. libraries names (libstarpu-1.0.so, libstarpumpi-1.0.so and
  104. libstarpufft-1.0.so).
  105. \section setting_up_your_own Code Setting up Your Own Code
  106. \subsection setting_flags_for_compiling Setting Flags for Compiling, Linking and Running Applications
  107. StarPU provides a pkg-config executable to obtain relevant compiler
  108. and linker flags.
  109. Compiling and linking an application against StarPU may require to use
  110. specific flags or libraries (for instance <c>CUDA</c> or <c>libspe2</c>).
  111. To this end, it is possible to use the <c>pkg-config</c> tool.
  112. If StarPU was not installed at some standard location, the path of StarPU's
  113. library must be specified in the <c>PKG_CONFIG_PATH</c> environment variable so
  114. that <c>pkg-config</c> can find it. For example if StarPU was installed in
  115. <c>$prefix_dir</c>:
  116. \verbatim
  117. $ PKG_CONFIG_PATH=$PKG_CONFIG_PATH:$prefix_dir/lib/pkgconfig
  118. \endverbatim
  119. The flags required to compile or link against StarPU are then
  120. accessible with the following commands:
  121. \verbatim
  122. $ pkg-config --cflags starpu-1.1 # options for the compiler
  123. $ pkg-config --libs starpu-1.1 # options for the linker
  124. \endverbatim
  125. Note that it is still possible to use the API provided in the version
  126. 0.9 of StarPU by calling <c>pkg-config</c> with the <c>libstarpu</c> package.
  127. Similar packages are provided for <c>libstarpumpi</c> and <c>libstarpufft</c>.
  128. Make sure that <c>pkg-config --libs starpu-1.1</c> actually produces some output
  129. before going further: <c>PKG_CONFIG_PATH</c> has to point to the place where
  130. <c>starpu-1.1.pc</c> was installed during <c>make install</c>.
  131. Also pass the <c>--static</c> option if the application is to be
  132. linked statically.
  133. It is also necessary to set the variable <c>LD_LIBRARY_PATH</c> to
  134. locate dynamic libraries at runtime.
  135. \verbatim
  136. $ LD_LIBRARY_PATH=$prefix_dir/lib:$LD_LIBRARY_PATH
  137. \endverbatim
  138. When using a Makefile, the following lines can be added to set the
  139. options for the compiler and the linker:
  140. \verbatim
  141. CFLAGS += $$(pkg-config --cflags starpu-1.1)
  142. LDFLAGS += $$(pkg-config --libs starpu-1.1)
  143. \endverbatim
  144. \subsection running_a_basic_starpu_application Running a Basic StarPU Application
  145. Basic examples using StarPU are built in the directory
  146. <c>examples/basic_examples/</c> (and installed in
  147. <c>$prefix_dir/lib/starpu/examples/</c>). You can for example run the example
  148. <c>vector_scal</c>.
  149. \verbatim
  150. $ ./examples/basic_examples/vector_scal
  151. BEFORE: First element was 1.000000
  152. AFTER: First element is 3.140000
  153. \endverbatim
  154. When StarPU is used for the first time, the directory
  155. <c>$STARPU_HOME/.starpu/</c> is created, performance models will be stored in
  156. that directory (@pxref{STARPU_HOME}).
  157. Please note that buses are benchmarked when StarPU is launched for the
  158. first time. This may take a few minutes, or less if <c>hwloc</c> is
  159. installed. This step is done only once per user and per machine.
  160. \subsection kernel_threads_started_by_starpu Kernel Threads Started by StarPU
  161. StarPU automatically binds one thread per CPU core. It does not use
  162. SMT/hyperthreading because kernels are usually already optimized for using a
  163. full core, and using hyperthreading would make kernel calibration rather random.
  164. Since driving GPUs is a CPU-consuming task, StarPU dedicates one core per GPU
  165. While StarPU tasks are executing, the application is not supposed to do
  166. computations in the threads it starts itself, tasks should be used instead.
  167. TODO: add a StarPU function to bind an application thread (e.g. the main thread)
  168. to a dedicated core (and thus disable the corresponding StarPU CPU worker).
  169. \subsection Enabling_OpenCL Enabling OpenCL
  170. When both CUDA and OpenCL drivers are enabled, StarPU will launch an
  171. OpenCL worker for NVIDIA GPUs only if CUDA is not already running on them.
  172. This design choice was necessary as OpenCL and CUDA can not run at the
  173. same time on the same NVIDIA GPU, as there is currently no interoperability
  174. between them.
  175. To enable OpenCL, you need either to disable CUDA when configuring StarPU:
  176. \verbatim
  177. $ ./configure --disable-cuda
  178. \endverbatim
  179. or when running applications:
  180. \verbatim
  181. $ STARPU_NCUDA=0 ./application
  182. \endverbatim
  183. OpenCL will automatically be started on any device not yet used by
  184. CUDA. So on a machine running 4 GPUS, it is therefore possible to
  185. enable CUDA on 2 devices, and OpenCL on the 2 other devices by doing
  186. so:
  187. \verbatim
  188. $ STARPU_NCUDA=2 ./application
  189. \endverbatim
  190. \section benchmarking_starpu Benchmarking StarPU
  191. Some interesting benchmarks are installed among examples in
  192. <c>$prefix_dir/lib/starpu/examples/</c>. Make sure to try various
  193. schedulers, for instance <c>STARPU_SCHED=dmda</c>.
  194. \subsection task_size_overhead Task size overhead
  195. This benchmark gives a glimpse into how big a size should be for StarPU overhead
  196. to be low enough. Run <c>tasks_size_overhead.sh</c>, it will generate a plot
  197. of the speedup of tasks of various sizes, depending on the number of CPUs being
  198. used.
  199. \subsection data_transfer_latency Data transfer latency
  200. <c>local_pingpong</c> performs a ping-pong between the first two CUDA nodes, and
  201. prints the measured latency.
  202. \subsection matrix_matrix_multiplication Matrix-matrix multiplication
  203. <c>sgemm</c> and <c>dgemm</c> perform a blocked matrix-matrix
  204. multiplication using BLAS and cuBLAS. They output the obtained GFlops.
  205. \subsection cholesky_factorization Cholesky factorization
  206. <c>cholesky\*</c> perform a Cholesky factorization (single precision). They use different dependency primitives.
  207. \subsection lu_factorization LU factorization
  208. <c>lu\*</c> perform an LU factorization. They use different dependency primitives.
  209. */