-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathMakefile
68 lines (52 loc) · 1.37 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
MAKEFLAGS += -rR --no-print-directory
export q := @
top-dir := $(CURDIR)
src-dir := $(top-dir)/src
inc-dir := $(top-dir)/inc
bin-dir := $(top-dir)/bin
arch-dir := $(top-dir)/arch
export shared-dir := $(top-dir)/shared
out := $(bin-dir)/captive
src := $(patsubst src/%,$(src-dir)/%,$(shell find src/ | grep -e "\.cpp$$"))
obj := $(src:.cpp=.o)
dep := $(src:.cpp=.d)
export ndebug :=
#-DNDEBUG
common-cflags := -I$(inc-dir) -I$(shared-dir) -g -Wall -O3 -pthread $(ndebug)
cflags := $(common-cflags)
cxxflags := $(common-cflags) -std=gnu++20
asflags := -g
ldflags := -pthread -Wl,--no-as-needed -ldl -lrt
cc := gcc
cxx := g++
as := as
ld := ld
rm := rm
make := +make
dtc := dtc
all: $(out) captive-platform.dtb .FORCE
$(q)$(make) -C $(arch-dir)
clean: .FORCE
$(q)$(make) -C $(arch-dir) clean
$(rm) -f $(obj)
$(rm) -f $(dep)
$(rm) -f $(out)
%.dtb: %.dts
@echo " DTC $(patsubst $(top-dir)/%,%,$@)"
$(q)$(dtc) -I dts -O dtb -o $@ $<
$(out): $(dep) $(obj) $(bin-dir)
@echo " LD $(patsubst $(bin-dir)/%,%,$@)"
$(q)$(cxx) -o $@ $(ldflags) $(obj)
$(bin-dir):
@mkdir $@
%.o: %.cpp
@echo " C++ $(patsubst $(src-dir)/%,%,$@)"
$(q)$(cxx) -c -o $@ $(cxxflags) $<
%.o: %.S
@echo " AS $(patsubst $(src-dir)/%,%,$@)"
$(q)$(as) -o $@ $(asflags) $<
%.d: %.cpp
$(q)$(cxx) -M -MT $(@:.d=.o) -o $@ $(cxxflags) $<
.FORCE:
.PHONY: $(PHONY) .FORCE
-include $(dep)