本博客已遷往http://coredumper.cn
單獨的MPI程序和CUDA程序的編譯命令是很簡單的。
MPI程序的編譯命令爲:
mpicc test.c -o test
CUDA程序的編譯命令爲:
nvcc test.c test_cuda.cu -o test
但是MPI+CUDA混合程序的編譯命令就沒這麼簡單了,下面舉例說明。
假設整個程序包括兩個源文件test.c和test_cuda.cu,test.c是MPI程序,test_cuda.cu是CUDA程序,在test.c中調用了test_cuda.cu中的函數。
該程序的Makefile文件內容如下:
CUDA_INSTALL_PATH = /usr/local/cuda-5.5
MPI_INSTALL_PATH = /home/cluster/mirror/mpich2
NVCC = $(CUDA_INSTALL_PATH)/bin/nvcc
MPICC = $(MPI_INSTALL_PATH)/bin/mpicc
LIBS = -lcudart -lcurand -L$(CUDA_INSTALL_PATH)/lib64
CFILES = test.c
CUFILES = test_cuda.cu
OBJECTS = test.o test_cuda.o
EXECNAME = test
all:
$(MPICC) -c $(CFILES)
$(NVCC) -c $(CUFILES)
$(MPICC) -o $(EXECNAME) $(LIBS) $(OBJECTS)
clean:
rm -f *.o $(EXECNAME)