我们可以使用cilk plus和gcc-5.2
卸载到图形硬件g++ -std=c++14 -Wall -O3 -march=native -fcilkplus vec_add.cpp -o vec_add
vec_add.cpp:6:0: warning: ignoring #pragma offload target [-Wunknown-pragmas]
#pragma offload target(gfx) pin(out, in1, in2 : length(n))
编译器为以下测试代码提供了上述警告:
#include <iostream>
#include <cilk/cilk.h>
void vec_add(int n, float *out, float *in1, float *in2)
{
#pragma offload target(gfx) pin(out, in1, in2 : length(n))
cilk_for(int i = 0; i != n; ++i)
{
out[i] = in1[i] + in2[i];
}
}
static int ar_sz = 100000;
int main (int argc, char **argv)
{
float foo[ar_sz];
float bar[ar_sz];
float out[ar_sz];
for(int i = 0; i != ar_sz; ++i)
{
foo[i] = i + ar_sz * 10;
bar[i] = i;
}
vec_add(ar_sz, out, foo, bar);
for(int i = 0; i != ar_sz; i += 100)
{
std::cout << "foo[" << i << "] =" << foo[i] << "\t|\tbar[" << i << "] =" << bar[i] << std::endl;
}
}
编译
FLAGS=-std=c++14 -Wall -O3 -march=native -fcilkplus
all: vec_add fib
vec_add: vec_add.cpp
g++ $(FLAGS) $< -o $@
答案 0 :(得分:0)
据我所知,GCC不支持卸载编译指示,所以不可能这样做。实际上,警告信息明确表示它是一个未知的编译指示。
答案 1 :(得分:0)
&#34; GCC编译器已经添加了对Cilk Plus的完全支持。&#34;这意味着完全支持cilk plus的语言扩展。 Gcc根本无法卸载到intel集成显卡。据报道,OpenMP可以卸载到Xeon Phi协处理器和nvidia显卡。