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)

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