forked from komar007/ukbdc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
44 lines (36 loc) · 1.1 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
SHELL=/bin/bash
.DEFAULT_GOAL := all
# Clear suffixes to disable implicit rules
.SUFFIXES:
include Makefile.config
define RULES_TEMPLATE=
obj/$1:
mkdir -p obj/$1
obj/$1/%.d: %.c | obj/$1
@$(CC) $(CFLAGS) $$(OPTS_$1) -DPLATFORM_$1 -MM -MT "$$(@:.d=.o) $$@" $$< > $$@
obj/$1/%.o: %.c | obj/$1
$(CC) $(CFLAGS) $$(OPTS_$1) -DPLATFORM_$1 -c -o $$@ $$<
endef
$(foreach target,$(TARGETS),$(eval $(call RULES_TEMPLATE,$(target))))
define INCLUDE_TEMPLATE=
-include $$(SOURCES_$1:%.c=obj/$1/%.d) $$(BASE_SOURCES:%.c=obj/$1/%.d)
endef
$(foreach target,$(TARGETS),$(eval $(call INCLUDE_TEMPLATE,$(target))))
define RESULT_DEPS_TEMPLATE=
bin/$$(RESULT_$1).elf: $$(SOURCES_$1:%.c=obj/$1/%.o) $(BASE_SOURCES:%.c=obj/$1/%.o) | bin/
$(CC) $(CFLAGS) $(LDFLAGS) $$(OPTS_$1) -o $$@ $$^
endef
$(foreach target,$(TARGETS),$(eval $(call RESULT_DEPS_TEMPLATE,$(target))))
bin/:
mkdir -p bin/
bin/%.hex: bin/%.elf
avr-objcopy -O ihex $^ $@
define TARGET_TEMPLATE=
.PHONY: $1
$1: bin/$$(RESULT_$1).hex
endef
$(foreach target,$(TARGETS),$(eval $(call TARGET_TEMPLATE,$(target))))
.PHONY: clean all
all: $(TARGETS)
clean:
rm -fr bin/ obj/