starpu.texi 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. \input texinfo @c -*-texinfo-*-
  2. @c %**start of header
  3. @setfilename starpu.info
  4. @settitle StarPU Handbook
  5. @c %**end of header
  6. @include chapters/version.texi
  7. @copying
  8. Copyright @copyright{} 2009--2013 Universit@'e de Bordeaux 1
  9. @noindent
  10. Copyright @copyright{} 2010--2013 Centre National de la Recherche Scientifique
  11. @noindent
  12. Copyright @copyright{} 2011, 2012 Institut National de Recherche en Informatique et Automatique
  13. @quotation
  14. Permission is granted to copy, distribute and/or modify this document
  15. under the terms of the GNU Free Documentation License, Version 1.3
  16. or any later version published by the Free Software Foundation;
  17. with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
  18. Texts. A copy of the license is included in the section entitled ``GNU
  19. Free Documentation License''.
  20. @end quotation
  21. @end copying
  22. @setchapternewpage odd
  23. @dircategory Development
  24. @direntry
  25. * StarPU: (starpu). StarPU Handbook
  26. @end direntry
  27. @titlepage
  28. @title StarPU Handbook
  29. @subtitle for StarPU @value{VERSION}
  30. @page
  31. @vskip 0pt plus 1fill
  32. @insertcopying
  33. @end titlepage
  34. @c @summarycontents
  35. @contents
  36. @page
  37. @ifnottex
  38. @node Top
  39. @top StarPU Handbook
  40. @end ifnottex
  41. This manual documents the usage of StarPU version @value{VERSION}. It
  42. was last updated on @value{UPDATED}.
  43. @ifnottex
  44. @insertcopying
  45. @end ifnottex
  46. @comment
  47. @comment When you add a new menu item, please keep the right hand
  48. @comment aligned to the same column. Do not use tabs. This provides
  49. @comment better formatting.
  50. @comment
  51. @menu
  52. * Introduction:: Getting started
  53. * Building and Installing StarPU::
  54. * Basic Examples:: Basic examples of the use of StarPU
  55. * Advanced Examples:: Advanced examples of the use of StarPU
  56. * Performance optimization:: How to optimize performance with StarPU
  57. * Performance feedback:: Performance debugging tools
  58. * Tips and Tricks:: Tips and tricks to know about
  59. * StarPU MPI support:: How to combine StarPU with MPI
  60. * StarPU FFT support:: How to perform FFT computations with StarPU
  61. * C Extensions:: Easier StarPU programming with GCC
  62. * SOCL OpenCL Extensions:: How to use OpenCL on top of StarPU
  63. * Scheduling Contexts in StarPU:: How to use Scheduling Context of StarPU
  64. * Scheduling Context Hypervisor:: How to use Scheduling Context Hypervisor with StarPU
  65. * StarPU's API:: The API to use StarPU
  66. * Scheduling Context Hypervisor's API:: The API to use the Hypervisor
  67. * Configuration Options for StarPU::
  68. * Full source code for the 'Scaling a Vector' example::
  69. * GNU Free Documentation License:: How you can copy and share this manual.
  70. * Concept Index:: Index of programming concepts.
  71. * Function Index:: Index of C functions.
  72. * Datatype Index:: Index of C datatypes.
  73. * Configuration Index:: Index of configuration options.
  74. @end menu
  75. @c ---------------------------------------------------------------------
  76. @c Introduction to StarPU
  77. @c ---------------------------------------------------------------------
  78. @node Introduction
  79. @chapter Introduction to StarPU
  80. @include chapters/introduction.texi
  81. @c ---------------------------------------------------------------------
  82. @c Installing StarPU
  83. @c ---------------------------------------------------------------------
  84. @node Building and Installing StarPU
  85. @chapter Building and Installing StarPU
  86. @include chapters/installing.texi
  87. @c ---------------------------------------------------------------------
  88. @c Basic Examples
  89. @c ---------------------------------------------------------------------
  90. @node Basic Examples
  91. @chapter Basic Examples
  92. @include chapters/basic-examples.texi
  93. @c ---------------------------------------------------------------------
  94. @c Advanced Examples
  95. @c ---------------------------------------------------------------------
  96. @node Advanced Examples
  97. @chapter Advanced Examples
  98. @include chapters/advanced-examples.texi
  99. @c ---------------------------------------------------------------------
  100. @c Performance options
  101. @c ---------------------------------------------------------------------
  102. @node Performance optimization
  103. @chapter How to optimize performance with StarPU
  104. @include chapters/perf-optimization.texi
  105. @c ---------------------------------------------------------------------
  106. @c Performance feedback
  107. @c ---------------------------------------------------------------------
  108. @node Performance feedback
  109. @chapter Performance feedback
  110. @include chapters/perf-feedback.texi
  111. @c ---------------------------------------------------------------------
  112. @c Tips and Tricks
  113. @c ---------------------------------------------------------------------
  114. @node Tips and Tricks
  115. @chapter Tips and Tricks to know about
  116. @include chapters/tips-tricks.texi
  117. @c ---------------------------------------------------------------------
  118. @c MPI support
  119. @c ---------------------------------------------------------------------
  120. @node StarPU MPI support
  121. @chapter StarPU MPI support
  122. @include chapters/mpi-support.texi
  123. @c ---------------------------------------------------------------------
  124. @c FFT support
  125. @c ---------------------------------------------------------------------
  126. @node StarPU FFT support
  127. @chapter StarPU FFT support
  128. @include chapters/fft-support.texi
  129. @c ---------------------------------------------------------------------
  130. @c C Extensions
  131. @c ---------------------------------------------------------------------
  132. @node C Extensions
  133. @chapter C Extensions
  134. @include chapters/c-extensions.texi
  135. @c ---------------------------------------------------------------------
  136. @c SOCL
  137. @c ---------------------------------------------------------------------
  138. @node SOCL OpenCL Extensions
  139. @chapter SOCL OpenCL Extensions
  140. @include chapters/socl.texi
  141. @c ---------------------------------------------------------------------
  142. @c Scheduling Contexts in StarPU
  143. @c ---------------------------------------------------------------------
  144. @node Scheduling Contexts in StarPU
  145. @chapter Scheduling Contexts in StarPU
  146. @include chapters/sched_ctx.texi
  147. @c ---------------------------------------------------------------------
  148. @c Scheduling Context Hypervisor
  149. @c ---------------------------------------------------------------------
  150. @node Scheduling Context Hypervisor
  151. @chapter Scheduling Context Hypervisor
  152. @include chapters/sched_ctx_hypervisor.texi
  153. @c ---------------------------------------------------------------------
  154. @c StarPU API
  155. @c ---------------------------------------------------------------------
  156. @node StarPU's API
  157. @chapter StarPU's API
  158. @include chapters/api.texi
  159. @c ---------------------------------------------------------------------
  160. @c Scheduling Context Hypervisor's API
  161. @c ---------------------------------------------------------------------
  162. @node Scheduling Context Hypervisor's API
  163. @chapter Scheduling Context Hypervisor's API
  164. @include chapters/hypervisor_api.texi
  165. @c ---------------------------------------------------------------------
  166. @c Configuration options
  167. @c ---------------------------------------------------------------------
  168. @node Configuration Options for StarPU
  169. @chapter Configuration Options for StarPU
  170. @include chapters/configuration.texi
  171. @c ---------------------------------------------------------------------
  172. @c Appendices
  173. @c ---------------------------------------------------------------------
  174. @c ---------------------------------------------------------------------
  175. @c Full source code for the 'Scaling a Vector' example
  176. @c ---------------------------------------------------------------------
  177. @node Full source code for the 'Scaling a Vector' example
  178. @appendix Full source code for the 'Scaling a Vector' example
  179. @include chapters/scaling-vector-example.texi
  180. @c ---------------------------------------------------------------------
  181. @c License
  182. @c ---------------------------------------------------------------------
  183. @node GNU Free Documentation License
  184. @appendix GNU Free Documentation License
  185. @include chapters/fdl-1.3.texi
  186. @c ---------------------------------------------------------------------
  187. @c Indices
  188. @c ---------------------------------------------------------------------
  189. @c comment it out for now, it is too small to be kept for now. See how
  190. @c it can be merged with the glossary section in the introduction
  191. @node Concept Index
  192. @unnumbered Concept Index
  193. @printindex cp
  194. @node Function Index
  195. @unnumbered Function Index
  196. @printindex fn
  197. @node Datatype Index
  198. @unnumbered Datatype Index
  199. @printindex tp
  200. @node Configuration Index
  201. @unnumbered Configuration Index
  202. @printindex vr
  203. @bye