MPI+CUDA混合程序的編譯命令

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章