123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- /*
- * This file is part of the StarPU Handbook.
- * Copyright (C) 2009--2011 Universit@'e de Bordeaux 1
- * Copyright (C) 2010, 2011, 2012, 2013 Centre National de la Recherche Scientifique
- * Copyright (C) 2011, 2012 Institut National de Recherche en Informatique et Automatique
- * See the file version.doxy for copying conditions.
- */
- /*! \page MICSCCSupport MIC/SCC Support
- \section Compilation Compilation
- SCC support just needs the presence of the RCCE library.
- MIC support actually needs two compilations of StarPU, one for the host and one for
- the device. The script <c>mic-configure</c> can be used to achieve this: it basically
- calls <c>configure</c> as appropriate from two new directories: <c>build_mic</c> and
- <c>build_host</c>. <c>make</c> and <c>make install</c> can then be used as usual and will
- recurse into both directories.
- \internal
- TODO: move to configuration section?
- \endinternal
- It can be parameterized with the environment variables \ref
- STARPU_MIC_HOST, \ref STARPU_MIC_CC_PATH and \ref STARPU_COI_DIR.
- \section PortingApplicationsToMICSCC Porting Applications To MIC/SCC
- The simplest way to port an application to MIC/SCC is to set the field
- starpu_codelet::cpu_funcs_name, to provide StarPU with the function
- name of the CPU implementation. StarPU will thus simply use the
- existing CPU implementation (cross-rebuilt in the MIC case). The
- functions have to be globally-visible (i.e. not <c>static</c>) for
- StarPU to be able to look them up.
- For SCC execution, the function starpu_initialize() also has to be
- used instead of starpu_init(), so as to pass <c>argc</c> and
- <c>argv</c>.
- \section LaunchingPrograms Launching Programs
- SCC programs are started through RCCE.
- MIC programs are started from the host. StarPU automatically
- starts the same program on MIC devices. It however needs to get
- the MIC-cross-built binary. It will look for the file given by the
- environment variable \ref STARPU_MIC_SINK_PROGRAM_NAME or in the
- directory given by the environment variable \ref
- STARPU_MIC_SINK_PROGRAM_PATH, or in the field
- starpu_config::mic_sink_program_path. It will also look in the current
- directory for the same binary name plus the suffix <c>-mic</c> or
- <c>_mic</c>.
- */
|