我有一个包含几个文件(.cu,.cpp,.h)的项目,我想编译并链接它。
我的文件如下:
1) Graph.cpp - 只是c ++代码
2) Graph.h - 上面的标题(工作正常)
3) Common.h - __host__ __device__
函数
#ifndef COMMON_CUH
#define COMMON_CUH
#include "cuda_runtime.h"
#include "device_launch_parameters.h"
__host__ __device__ unsigned int fun1(int, int);
__host__ __device__ int fun2(int);
__host__ __device__ int fun3(int);
__host__ __device__ unsigned int fun4(int, int);
#endif
4) Common.cu - 执行上述
#include "cuda_runtime.h"
#include "device_launch_parameters.h"
#include "Common.h"
__host__ __device__ unsigned int fun1(int a, int n)
{
...
}
...other functions...
5) kernel.cu - 主文件
#include "cuda_runtime.h"
#include "device_launch_parameters.h"
#include "Graph.h"
#include "LogCreate.h"
#include "Common.h"
some __global__ functions. c++ functions, main etc.
我尝试使用的一个makefile:
CUDA_INSTALL_PATH ?= /usr/local/cuda
# Compilers
CXX := g++
CC := gcc
LINK := g++ -fPIC
NVCC := nvcc -ccbin /usr/bin
# Includes
INCLUDES = -I. -I$(CUDA_INSTALL_PATH)/include
# Common flags
COMMONFLAGS += $(INCLUDES)
NVCCFLAGS += $(COMMONFLAGS)
NVCCFLAGS += -arch=sm_35
# Debug mode
NVCCFLAGS += --compiler-options -Wall -G
CXXFLAGS += $(COMMONFLAGS)
CFLAGS += $(COMMONFLAGS)
LIB_CUDA := -L$(CUDA_INSTALL_PATH)/lib64 -lcudart
OBJS = Common.cuh.o Graph.cpp.o LogCreate.cpp.o kernel.cu.o
TARGET = main
LINKLINE = $(LINK) -o $(TARGET) $(OBJS) $(LIB_CUDA)
.SUFFIXES: .c .cpp .h .cu .cuh .o
%.cuh.o: %.cu %.cuh
$(NVCC) $(NVCCFLAGS) -dc $< -o $@
%.cu.o: %.cu
$(NVCC) $(NVCCFLAGS) -dc $< -o $@
%.cpp.o: %.cpp %.h
$(CXX) $(CXXFLAGS) -c $< -o $@
$(TARGET): $(OBJS) Makefile
$(LINKLINE)
clean:
rm -rf *.o
给了我:
Common.cuh.o: In function `__sti____cudaRegisterAll_41_tmpxft_0000107c_00000000_6_Common_cpp1_ii__Z3Powii()':
tmpxft_0000107c_00000000-3_Common.cudafe1.cpp:(.text+0x1c1): undefined reference to `__cudaRegisterLinkedBinary_41_tmpxft_0000107c_00000000_6_Common_cpp1_ii__Z3Powii'
kernel.cu.o: In function `__sti____cudaRegisterAll_41_tmpxft_000010ad_00000000_6_kernel_cpp1_ii_filename()':
tmpxft_000010ad_00000000-3_kernel.cudafe1.cpp:(.text+0x2f33): undefined reference to `__cudaRegisterLinkedBinary_41_tmpxft_000010ad_00000000_6_kernel_cpp1_ii_filename'
collect2: error: ld returned 1 exit status
make: *** [main] Error 1
我想(Here's a link)可能是我的问题的一个障碍,但我不知道如何处理它。
编写makefile的另一个尝试是(不太通用):
setting like before and main part:
all:
$(NVCC) $(NVCCFLAGS) -dc Common.cu kernel.cu
$(NVCC) $(NVCCFLAGS) -dlink Common.o kernel.o -o link.o
$(CXX) $(CXXFLAGS) -c Graph.cpp Graph.h -o graph.o
$(LINK) -o main Common.o kernel.o link.o graph.o $(LIB_CUDA)
给了我:
g++ -fPIC -o main Common.o kernel.o link.o graph.o -L/usr/local/cuda/lib64 -lcudart
graph.o: file not recognized: File format not recognized
collect2: error: ld returned 1 exit status
make: *** [all] Error 1
我搜索了很多网站,但仍然不知道如何修复它。我读过之前放置的链接的一部分,但也许我错过了一些或者只是没有理解。
请解释在Makefile中编译/链接时处理许多文件(使用主机和设备代码)的正确方法。感谢
答案 0 :(得分:4)
您的第一种方法未正确处理CUDA separate compilation(您没有设备链接步骤)。
你的第二种方法更接近标记。
这是错误的:
$(CXX) $(CXXFLAGS) -c Graph.cpp Graph.h -o graph.o
它应该是:
$(CXX) $(CXXFLAGS) -c Graph.cpp -o graph.o