-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmakefile
55 lines (42 loc) · 1.75 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
###############################################################################
## Simulator Makefile
###############################################################################
# Target
TARGET ?= armv6m-sim
# Options
CFLAGS = -O2 -fPIC
CFLAGS += -Wno-write-strings
LDFLAGS =
LIBS = -lelf -lbfd
# Source Files
SRC_DIR = .
###############################################################################
# Variables
###############################################################################
OBJ_DIR ?= obj/$(TARGET)/
###############################################################################
# Variables: Lists of objects, source and deps
###############################################################################
# SRC / Object list
src2obj = $(OBJ_DIR)$(patsubst %$(suffix $(1)),%.o,$(notdir $(1)))
SRC ?= $(foreach src,$(SRC_DIR),$(wildcard $(src)/*.cpp)) $(foreach src,$(SRC_DIR),$(wildcard $(src)/*.c))
OBJ ?= $(foreach src,$(SRC),$(call src2obj,$(src)))
###############################################################################
# Rules: Compilation macro
###############################################################################
define template_cpp
$(call src2obj,$(1)): $(1) | $(OBJ_DIR)
@echo "# Compiling $(notdir $(1))"
@g++ $(CFLAGS) -c $$< -o $$@
endef
###############################################################################
# Rules
###############################################################################
all: $(TARGET)
$(OBJ_DIR):
@mkdir -p $@
$(foreach src,$(SRC),$(eval $(call template_cpp,$(src))))
$(TARGET): $(OBJ) makefile
g++ $(LDFLAGS) $(OBJ) $(LIBS) -o $@
clean:
-rm -rf $(OBJ_DIR) $(TARGET)