最近在写“并行程序设计”大作业时,用到openmp,但是总是报错,信息如下

/tmp/tmpxft_0000269f_00000000-10_quicksort_ex.o:在函数‘main’中:tmpxft_0000269f_000000005_quicksort_ex.cudafe1.cpp:(.text+0x64c):对‘omp_set_num_threads’未定义的引用collect2: error: ld returned 1 exit status

遍查网络,以为碰到了什么系统设置的问题,没想到最后发现是cuda的nvcc编译器的选项问题。
原先我编译用的是linux终端命令输入 nvcc quicksort_ex.cu -o quicksort_ex
但是openmp即便引入了omp.h文件,也还需要在最后编译时加入下面的选项,才能编译成功
nvcc quicksort_ex.cu -o quicksort_ex -Xcompiler “-fopenmp”

命令最后加入-Xcompiler “-fopenmp” 就行了。

Logo

更多推荐