-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathMakefile
93 lines (77 loc) · 2.23 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
.SUFFIXES:
TARGET = sqdtrt
CC = g++
CUCC = nvcc
CFLAGS = -std=c++11 -Wall
CUFLAGS = -m64 -arch=sm_35 -ccbin $(CC)
LDFLAGS = $(CFLAGS)
ifdef DEBUG
CFLAGS += -g -O0 -DDEBUG
CUFLAGS += -lineinfo
LDFLAGS += -g -O0
else
CFLAGS += -O3 -DNDEBUG
CUFLAGS +=
LDFLAGS += -O3
endif
ifdef VERBOSE
AT =
else
AT = @
endif
AR = ar cr
ECHO = @echo
SHELL = /bin/sh
define concat
$1$2$3$4$5$6$7$8
endef
#$(call make-depend,source-file,object-file,depend-file)
define make-depend
$(AT)$(CC) -MM -MF $3 -MP -MT $2 $(CFLAGS) $1
endef
define make-depend-cu
$(AT)$(CUCC) -M $(CUFLAGS) $1 > $3.$$$$; \
sed 's,.*\.o[ :]*,$2 : ,g' < $3.$$$$ > $3; \
rm -f $3.$$$$
endef
# SRCS_C = sqdtrt.cpp trtUtil.cpp common.cpp tensorUtil.cu errorHandle.cu sdt_alloc.c
SRCS = *.cpp *.c *.cu
OUTDIR = .
OBJDIR = $(call concat,$(OUTDIR),/obj)
OBJS = $(patsubst %.c, $(OBJDIR)/%.o, $(wildcard *.c))
OBJS += $(patsubst %.cpp, $(OBJDIR)/%.o, $(wildcard *.cpp))
CUOBJS = $(patsubst %.cu, $(OBJDIR)/%.o, $(wildcard *.cu))
TRIPLE?=x86_64-linux
CUDA_INSTALL_DIR = /usr/local/cuda
CUDA_LIBDIR = lib
INCPATHS =-I"$(CUDA_INSTALL_DIR)/include" -I"/usr/local/include"
LIBPATHS =-L"$(CUDA_INSTALL_DIR)/targets/$(TRIPLE)/$(CUDA_LIBDIR)" -L"/usr/local/lib" -L"/usr/local/cuda/lib64" -L"$(CUDA_INSTALL_DIR)/$(CUDA_LIBDIR)"
LIBS = $(LIBPATHS) -lcudart -lcudart_static -lnvinfer `pkg-config --libs opencv`
CFLAGS += $(INCPATHS) `pkg-config --cflags opencv`
CUFLAGS += $(INCPATHS) `pkg-config --cflags opencv`
LDFLAGS += $(LIBS)
.PHONY: all
all: $(OUTDIR)/$(TARGET)
$(OUTDIR)/$(TARGET): $(OBJS) $(CUOBJS) $(TESTOBJS)
$(ECHO) Linking: $^
$(AT)$(CC) -o $@ $^ $(LDFLAGS)
$(OBJDIR)/%.o: %.c
$(AT)if [ ! -d $(OBJDIR) ]; then mkdir -p $(OBJDIR); fi
$(call make-depend,$<,$@,$(subst .o,.d,$@))
$(ECHO) Compiling: $<
$(AT)$(CC) $(CFLAGS) -c -o $@ $<
$(OBJDIR)/%.o: %.cpp
$(AT)if [ ! -d $(OBJDIR) ]; then mkdir -p $(OBJDIR); fi
$(call make-depend,$<,$@,$(subst .o,.d,$@))
$(ECHO) Compiling: $<
$(AT)$(CC) $(CFLAGS) -c -o $@ $<
$(OBJDIR)/%.o: %.cu
$(AT)if [ ! -d $(OBJDIR) ]; then mkdir -p $(OBJDIR); fi
$(call make-depend-cu,$<,$@,$(subst .o,.d,$@))
$(ECHO) Compiling CUDA: $<
$(AT)$(CUCC) $(CUFLAGS) -c -o $@ $<
clean:
rm -rf $(OBJDIR)
ifneq "$(MAKECMDGOALS)" "clean"
-include $(OBJDIR)/*.d
endif