-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
85 lines (53 loc) · 1.27 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
PROJ_NAME=ads1256_da
LINK=$(CXX)
#LINK=$(CC)
uname_m := $(shell uname -m)
SRCS = ads1256_da.cpp
ifeq ($(uname_m),armv7l)
LIBS= -lbcm2835
else
SRCS += bcm_fake.c
endif
#
###################################################
CFLAGS_ADD :=
DEPSDIR=.deps
OBJDIR=.objs
ALLFLAGS := -g2 -O2 -Wall -grecord-gcc-switches
ALLFLAGS += -pthread
ALLFLAGS += -march=native
ALLFLAGS += $(CFLAGS_ADD)
ALLFLAGS += -I.
SRCPATHS = .
vpath %.c $(SRCPATHS)
vpath %.cpp $(SRCPATHS)
vpath %.s $(STMSRC)
vpath %.o $(OBJDIR)
vpath %.d $(DEPSDIR)
OBJS0a = $(SRCS:.cpp=.o)
OBJS0 = $(OBJS0a:.c=.o)
OBJS = $(OBJS0:.s=.o)
OBJS1 = $(addprefix $(OBJDIR)/,$(OBJS))
CFLAGS = $(ALLFLAGS) -std=c11
CXXFLAGS = $(ALLFLAGS) -std=c++17 -fgnu-keywords
###################################################
.PHONY: proj
all: proj dirs
dirs:
mkdir -p $(DEPSDIR) $(OBJDIR)
proj: dirs $(PROJ_NAME)
$(OBJDIR)/*.o: Makefile
$(OBJDIR)/%.o: %.c
$(CC) $(CFLAGS) -c -MMD -o $@ $<
mv $(OBJDIR)/$*.d $(DEPSDIR)
$(OBJDIR)/%.o: %.cpp
$(CXX) $(CXXFLAGS) -c -MMD -o $@ $<
mv $(OBJDIR)/$*.d $(DEPSDIR)
$(OBJDIR)/%.o: %.s
$(CC) $(CFLAGS) -c -o $@ $<
$(PROJ_NAME): $(OBJS1)
$(LINK) $(CFLAGS) $(LDFLAGS) $^ $(LIBS) -o $@
clean:
rm -f *.o *.d $(OBJDIR)/*.o $(DEPSDIR)/*.d
include $(wildcard $(DEPSDIR)/*.d)
#