本博客已迁往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)