如何在英特尔至强融核协处理器上编译 VM 并运行 Erlang 程序?
1 回答
Intel Xeon Phi 不是典型的 x86_64 架构,因此无法在其上运行官方的 Erlang VM。唯一的方法是使用交叉编译并在支持 Erlang 的不同(主机)机器上自己构建 VM,以便它在目标系统(本例中为 Phi)上运行。
Xeon Phi 还支持与典型x86_64架构略有不同的指令集,因此您还需要编辑代码。如果你只是交叉编译虚拟机而不接触代码,你可能会得到一个错误:
/tmp/iccvaLP3vas_.s: Assembler messages:
/tmp/iccvaLP3vas_.s:25794: Error: `mfence' is not supported on `k1om'
因此,首先您需要围绕内存围栏指令添加子句, Phi (和)#ifndef
不支持这些子句。这归结为打开文件并添加以下预处理器指令:mfence
lfence
sfence
erts/include/internal/i386/ethr_membar.h
#ifndef __MIC__
...
#endif
围绕函数中的__asm__
语句ethr_mfence__
,例如ethr_sfence__
ethr_lfence__
static __inline__ void
ethr_mfence__(void)
{
#if ETHR_SIZEOF_PTR == 4
if (ETHR_X86_RUNTIME_CONF_HAVE_NO_SSE2__)
ETHR_NO_SSE2_MEMORY_BARRIER__;
else
#endif
#ifndef __MIC__
__asm__ __volatile__ ("mfence\n\t" : : : "memory");
#endif
}
现在你可以尝试交叉编译它。首先下载源代码(在我的例子中是 Erlang VM 17.5),然后运行:
$ cd otp_src_17.5
$ export ERL_TOP=`pwd`;
$ ./configure \
--host=k1om-unknown-linux-gnu \
--build=x86_64-pc-linux-gnu \
--without-termcap \
--without-javac \
--without-ssl \
--prefix=/path/to/my/new_installation \
CC=icc \
CFLAGS=-mmic \
LDFLAGS=-mmic \
DED_LD=icc \
DED_LDFLAGS="-mmic -shared -Wl,-Bsymbolic" \
DED_LD_FLAG_RUNTIME_LIBRARY_PATH="-Wl,-R"
$ make
$ make install
icc
是官方的英特尔编译器,-mmic
编译至强融核需要标志。host
和build
标志分别是您编译的机器和编译的机器(Phi)的系统/架构。在我的情况下,它们具有以下值,但如果它对您不同,您可能需要使用自动检测您的操作系统/CPU 架构的config.guess脚本。
$ ./config.guess
$ x86_64-pc-linux-gnu
就是这样!现在你应该可以在你的 Phi 上 ssh 并运行 Erlang。
$ ssh my-phi-coprocessor
$ cd /path/to/my/new_installation/
$ export PATH=`pwd`/bin:$PATH;
$ erl -version
Erlang (SMP,ASYNC_THREADS) (BEAM) emulator version 6.4