450_native_fortran_support.doxy 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. /*
  2. * This file is part of the StarPU Handbook.
  3. * Copyright (C) 2014, 2016 INRIA
  4. * See the file version.doxy for copying conditions.
  5. */
  6. /*! \page NativeFortranSupport The StarPU Native Fortran Support
  7. StarPU provides the necessary routines and support to natively access
  8. most of its functionalities from Fortran 2008+ codes.
  9. All symbols (functions, constants) are defined in <c>fstarpu_mod.f90</c>.
  10. Every symbol of the Native Fortran support API is prefixed by
  11. <c>fstarpu_</c>.
  12. Note: Mixing uses of <c>fstarpu_</c> and <c>starpu_</c>
  13. symbols in the same Fortran code has unspecified behaviour.
  14. See \ref APIMIX for a discussion about valid and unspecified
  15. combinations.
  16. \section Implementation Implementation Details and Specificities
  17. \subsection Prerequisites Prerequisites
  18. The Native Fortran support relies on Fortran 2008 specific constructs
  19. for which no equivalent are available in previous versions of the
  20. standard. It has currently been tested successfully with GNU GFortran >=
  21. 4.9 and the Intel Fortran Compiler >= 2016.
  22. \subsection Configuration Configuration
  23. The Native Fortran API is enabled and its companion
  24. <c>fstarpu_mod.f90</c> Fortran module source file is installed
  25. by default when a Fortran compiler is found, unless the detected Fortran
  26. compiler is known not to support the requirements for the Native Fortran
  27. API. The support can be disabled through the configure option \ref
  28. disable-fortran "--disable-fortran". Conditional compiled source codes
  29. may check for the availability of the Native Fortran Support by testing
  30. whether the preprocessor macro <c>STARPU_HAVE_FC</c> is defined or not.
  31. \subsection Examples Examples
  32. Several examples using the Native Fortran API are provided in
  33. StarPU's <c>examples/native_fortran/</c> examples directory, to showcase
  34. the Fortran flavor of various basic and more advanced StarPU features.
  35. \subsection AppCompile Compiling a Native Fortran Application
  36. The Fortran module <c>fstarpu_mod.f90</c> installed in StarPU's
  37. <c>include/</c> directory provides all the necessary API definitions. It
  38. must be compiled with the same compiler (same vendor, same version) as
  39. the application itself, and the resulting <c>fstarpu_mod.o</c> object
  40. file must linked with the application executable.
  41. Each example provided in StarPU's <c>examples/native_fortran/</c>
  42. examples directory comes with its own dedicated Makefile for out-of-tree
  43. build. Such example Makefiles may be used as starting points for
  44. building application codes with StarPU.
  45. \section Idioms Fortran Translation for Common StarPU API Idioms
  46. All these examples assume that the standard Fortran module <c>iso_c_binding</c>
  47. is in use.
  48. - Specifying a NULL pointer
  49. \code{.f90}
  50. type(c_ptr) :: my_ptr ! variable to store the pointer
  51. ! [...]
  52. my_ptr = C_NULL_PTR ! assign standard constant for NULL ptr
  53. \endcode
  54. - Obtaining a pointer to some object:
  55. \code{.f90}
  56. real(8), dimension(:), allocatable, target :: va
  57. type(c_ptr) :: p_va ! variable to store a pointer to array va
  58. ! [...]
  59. p_va = c_loc(va)
  60. \endcode
  61. - Obtaining a pointer to some subroutine:
  62. \code{.f90}
  63. ! pointed routine definition
  64. recursive subroutine myfunc () bind(C)
  65. ! [...]
  66. type(c_funptr) :: p_fun ! variable to store the routine pointer
  67. ! [...]
  68. p_fun = c_funloc(my_func)
  69. \endcode
  70. - Obtaining the size of some object:
  71. \code{.f90}
  72. real(8) :: a
  73. integer(c_size_t) :: sz_a ! variable to store the size of a
  74. ! [...]
  75. sz_a = c_sizeof(a)
  76. \endcode
  77. - Obtaining the length of an array dimension:
  78. \code{.f90}
  79. real(8), dimension(:,:), allocatable, target :: vb
  80. intger(c_int) :: ln_vb_1 ! variable to store the length of vb's dimension 1
  81. intger(c_int) :: ln_vb_2 ! variable to store the length of vb's dimension 2
  82. ! [...]
  83. ln_vb_1 = 1+ubound(vb,1)-lbound(vb,1) ! get length of dimension 1 of vb
  84. ln_vb_2 = 1+ubound(vb,2)-lbound(vb,2) ! get length of dimension 2 of vb
  85. \endcode
  86. - Specifying a string constant:
  87. \code{.f90}
  88. type(c_ptr) :: my_cl ! a StarPU codelet
  89. ! [...]
  90. ! set the name of a codelet to string 'my_codele't:
  91. call fstarpu_codelet_set_name(my_cl, C_CHAR_"my_codelet"//C_NULL_CHAR)
  92. ! note: using the C_CHAR_ prefix and the //C_NULL_CHAR concatenation at the end ensures
  93. ! that the string constant is properly '\0' terminated, and compatible with StarPU's
  94. ! internal C routines
  95. !
  96. ! note: plain Fortran string constants are not '\0' terminated, and as such, must not be
  97. ! passed to StarPU routines.
  98. \endcode
  99. - Combining multiple flag constants with a bitwise 'or':
  100. \code{.f90}
  101. type(c_ptr) :: my_cl ! a pointer for the codelet structure
  102. ! [...]
  103. ! add a managed buffer to a codelet, specifying both the Read/Write access mode and the Locality hint
  104. call fstarpu_codelet_add_buffer(my_cl, FSTARPU_RW.ior.FSTARPU_LOCALITY)
  105. \endcode
  106. \section InitExit Uses, Initialization and Shutdown
  107. The snippet below show an example of minimal StarPU code using the
  108. Native Fortran support. The program should <c>use</c> the standard
  109. module <c>iso_c_binding</c> as well as StarPU's <c>fstarpu_mod</c>. The
  110. StarPU runtime engine is initialized with a call to function
  111. <c>fstarpu_init</c>, which returns an integer status of 0 if successful
  112. or non-0 otherwise. Eventually, a call to <c>fstarpu_shutdown</c> ends
  113. the runtime engine and frees all internal StarPU data structures.
  114. \snippet nf_initexit.f90 To be included. You should update doxygen if you see this text.
  115. \section InsertTask Fortran Flavor of StarPU's Variadic Insert_task
  116. Fortran does not have a construction similar to C variadic functions on which
  117. <c>starpu_insert_task</c> relies at the time of this writing. However, Fortran's variable
  118. length arrays of <c>c_ptr</c> elements enable to emulate much of the
  119. convenience of C's variadic functions. This is the approach retained for
  120. implementing <c>fstarpu_insert_task</c>.
  121. The general syntax for using <c>fstarpu_insert_task</c> is as follows:
  122. \code{.f90}
  123. call fstarpu_insert_task((/ <codelet ptr> &
  124. [, <access mode flags>, <data handle>]* &
  125. [, <argument type constant>, <argument>]* &
  126. , C_NULL_PTR /))
  127. \endcode
  128. There is thus a unique array argument <c>(/ ... /)</c> passed to
  129. <c>fstarpu_insert_task</c> which itself contains the task settings.
  130. Each element of the array must be of type <c>type(c_ptr)</c>.
  131. The last element of the array must be <c>C_NULL_PTR</c>.
  132. Example extracted from nf_vector.f90:
  133. \code{.f90}
  134. call fstarpu_insert_task((/ cl_vec, & ! codelet
  135. FSTARPU_R, dh_va, & ! a first data handle
  136. FSTARPU_RW.ior.FSTARPU_LOCALITY, dh_vb, & ! a second data handle
  137. C_NULL_PTR /)) ! no more args
  138. \endcode
  139. \section Structs Functions and Subroutines Expecting Data Structures Arguments
  140. Several StarPU structures that are expected to be passed to the C API,
  141. are replaced by function/subroutine wrapper sets to allocate, set fields
  142. and free such structure. This strategy has been prefered over defining
  143. native Fortran equivalent of such structures using Fortran's derived
  144. types, to avoid potential layout mismatch between C and Fortran StarPU
  145. data structures. Examples of such data structures wrappers include
  146. <c>fstarpu_conf_allocate</c> and alike, <c>fstarpu_codelet_allocate</c>
  147. and alike, <c>fstarpu_data_filter_allocate</c> and alike.
  148. Here is an example of allocating, filling and deallocating a codelet
  149. structure:
  150. \code{.f90}
  151. ! a pointer for the codelet structure
  152. type(c_ptr) :: cl_vec
  153. ! [...]
  154. ! allocate an empty codelet structure
  155. cl_vec = fstarpu_codelet_allocate()
  156. ! add a CPU implementation function to the codelet
  157. call fstarpu_codelet_add_cpu_func(cl_vec, C_FUNLOC(cl_cpu_func_vec))
  158. ! set the codelet name
  159. call fstarpu_codelet_set_name(cl_vec, C_CHAR_"my_vec_codelet"//C_NULL_CHAR)
  160. ! add a Read-only mode data buffer to the codelet
  161. call fstarpu_codelet_add_buffer(cl_vec, FSTARPU_R)
  162. ! add a Read-Write mode data buffer to the codelet
  163. call fstarpu_codelet_add_buffer(cl_vec, FSTARPU_RW.ior.FSTARPU_LOCALITY)
  164. ! [...]
  165. ! free codelet structure
  166. call fstarpu_codelet_free(cl_vec)
  167. \endcode
  168. \section Notes Additional notes about the Native Fortran support
  169. \subsection OldFortran Using StarPU with older Fortran compilers
  170. When using older compilers, Fortran applications may still interoperate
  171. with StarPU using C marshalling functions as exemplified in StarPU's
  172. <c>examples/fortran/</c> and <c>examples/fortran90/</c> example
  173. directories, though the process will be less convenient.
  174. \subsection APIMIX Valid API Mixes and Language Mixes
  175. Mixing uses of
  176. <c>fstarpu_</c> and <c>starpu_</c> symbols in the same
  177. Fortran code has unspecified behaviour. Using <c>fstarpu_</c>
  178. symbols in C code has unspecified behaviour.
  179. For multi-language applications using both C and Fortran source files:
  180. - C source files must use <c>starpu_</c> symbols exclusively
  181. - Fortran sources must uniformly use either <c>fstarpu_</c> symbols
  182. exclusively, or <c>starpu_</c> symbols exclusively. Every other
  183. combination has unspecified behaviour.
  184. */