| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 | @c -*-texinfo-*-@c This file is part of the StarPU Handbook.@c Copyright (C) 2013  Universit@'e de Bordeaux 1@c See the file starpu.texi for copying conditions.@section CompilationSCC support just needs the presence of the RCCE library.MIC support actually needs two compilations of StarPU, one for the host and one forthe device. The @code{super-configure} script can be used to achieve this: it basicallycalls @code{configure} as appropriate from two new directories: @code{build_mic} and@code{build_host}. @code{make} and @code{make install} can then be used as usual and willrecurse into both directories.@c TODO: move to configuration section ?It can be parameterized with the following environment variables:@table @asis@item @code{MIC_HOST}Defines the value of the @code{--host} parameter passed to @code{configure} for thecross-compilation. The current default is @code{x86_64-k1om-linux}.@item @code{MIC_CC_PATH}Defines the path to the MIC cross-compiler. The current default is @code{/usr/linux-k1om-4.7/bin/}.@item @code{COI_DIR}Defines the path to the COI library. The current default is @code{/opt/intel/mic/coi}@end table@section Porting applications to MIC/SCCThe simplest way to port an application to MIC/SCC is to add the@code{cpu_funcs_name} field in the codelet, to provide StarPU with the functionname of the CPU implementation. StarPU will thus simply use the existing CPUimplementation (cross-rebuilt in the MIC case). The functions have to beglobally-visible (i.e. not @code{static}) for StarPU to be able to look them up.@code{starpu_initialize} also has to be used instead of @code{starpu_init}, soas to pass @code{argc} and @code{argv}.@section Launching programsSCC programs are started through RCCEMIC programs are started from the host. StarPU automaticallystarts the same program on MIC devices. It however needs to getthe MIC-cross-built binary. It will look for the file given by the@code{STARPU_MIC_SINK_PROGRAM_NAME} environment variable or in the directorygiven by the @code{STARPU_MIC_SINK_PROGRAM_PATH} environment variable, or inthe @code{mic_sink_program_path} field of the @code{starpu_config} structure.It will also look in the current directory for the same binary name plus a@code{-mic} or @code{_mic} suffix.
 |