单独的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 LDFLAGS = -L$(CUDA_INSTALL_PATH)/lib64 LIB = -lcudart -lcurand 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) $(LDFLAGS) $(LIB) $(OBJECTS) clean: rm -f *.o $(EXECNAME)
MPI+CUDA混合程序的编译命令,布布扣,bubuko.com
原文:http://blog.csdn.net/warren912/article/details/19968419