18mic_scc_support.doxy 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /*
  2. * This file is part of the StarPU Handbook.
  3. * Copyright (C) 2009--2011 Universit@'e de Bordeaux
  4. * Copyright (C) 2010, 2011, 2012, 2013 CNRS
  5. * Copyright (C) 2011, 2012 INRIA
  6. * See the file version.doxy for copying conditions.
  7. */
  8. /*! \page MICSCCSupport MIC Xeon Phi / SCC Support
  9. \section Compilation Compilation
  10. SCC support just needs the presence of the RCCE library.
  11. MIC Xeon Phi support actually needs two compilations of StarPU, one for the host and one for
  12. the device. The PATH environment variable has to include the path to the
  13. cross-compilation toolchain, for instance <c>/usr/linux-k1om-4.7/bin</c> .
  14. The SINK_PKG_CONFIG_PATH environment variable should include the path to the
  15. cross-compiled hwloc.pc.
  16. The script <c>mic-configure</c> can then be used to achieve the two compilations: it basically
  17. calls <c>configure</c> as appropriate from two new directories: <c>build_mic</c> and
  18. <c>build_host</c>. <c>make</c> and <c>make install</c> can then be used as usual and will
  19. recurse into both directories. If different configuration options are needed
  20. for the host and for the mic, one can use <c>--with-host-param=--with-fxt</c>
  21. for instance to specify the <c>--with-fxt</c> option for the host only, or
  22. <c>--with-mic-param=--with-fxt</c> for the mic only.
  23. One can also run StarPU just natively on the Xeon Phi, i.e. it will only run
  24. directly on the Phi without any exchange with the host CPU. The binaries in
  25. <c>build_mic</c> can be run that way.
  26. For MPI support, you will probably have to specify different MPI compiler path
  27. or option for the host and the device builds, for instance:
  28. <c>./mic-configure --with-mic-param=--with-mpicc="/.../mpiicc -mmic" --with-mic-param=--with-mpicc=/.../mpiicc</c>
  29. In case you have troubles with the coi or scif libraries (the Intel paths are
  30. really not standard, it seems...), you can still make a build in native mode
  31. only, by using <c>mic-configure --enable-native-mic</c> (and notably without
  32. <c>--enable-mic</c> since in that case we don't need mic offloading support).
  33. \section PortingApplicationsToMICSCC Porting Applications To MIC Xeon Phi / SCC
  34. The simplest way to port an application to MIC Xeon Phi or SCC is to set the field
  35. starpu_codelet::cpu_funcs_name, to provide StarPU with the function
  36. name of the CPU implementation. StarPU will thus simply use the
  37. existing CPU implementation (cross-rebuilt in the MIC Xeon Phi case). The
  38. functions have to be globally-visible (i.e. not <c>static</c>) for
  39. StarPU to be able to look them up, and -rdynamic must be passed to gcc (or
  40. -export-dynamic to ld) so that symbols of the main program are visible.
  41. For SCC execution, the function starpu_initialize() also has to be
  42. used instead of starpu_init(), so as to pass <c>argc</c> and
  43. <c>argv</c>.
  44. \section LaunchingPrograms Launching Programs
  45. SCC programs are started through RCCE.
  46. MIC programs are started from the host. StarPU automatically
  47. starts the same program on MIC devices. It however needs to get
  48. the MIC-cross-built binary. It will look for the file given by the
  49. environment variable \ref STARPU_MIC_SINK_PROGRAM_NAME or in the
  50. directory given by the environment variable \ref
  51. STARPU_MIC_SINK_PROGRAM_PATH, or in the field
  52. starpu_conf::mic_sink_program_path. It will also look in the current
  53. directory for the same binary name plus the suffix <c>-mic</c> or
  54. <c>_mic</c>.
  55. The testsuite can be started by simply running <c>make check</c> from the
  56. top directory. It will recurse into both <c>build_host</c> to run tests with only
  57. the host, and into <c>build_mic</c> to run tests with both the host and the MIC
  58. devices. Single tests with the host and the MIC can be run by starting
  59. <c>./loader-cross.sh ./the_test</c> from <c>build_mic/tests</c>.
  60. */