450_native_fortran_support.doxy 9.9 KB

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