blob: e9d49c75b9fb2611951c7c4e45560b1885d02ca7 (
plain)
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
|
SRCS = $(sort $(wildcard $(srcdir)/*.c))
OBJS = $(patsubst $(srcdir)/%.c,obj/%.o,$(SRCS))
DEPS = $(patsubst $(srcdir)/%.c,obj/%.d,$(SRCS))
gc_impl = sms
CFLAGS =
CPPFLAGS =
LDFLAGS =
# CFLAGS_AUTO = -fdata-sections -ffunction-sections -flto -g -O3 -std=c11 -Wall -Werror=implicit-function-declaration
# CFLAGS_AUTO = -g -Og -std=c11 -Wall -Werror=implicit-function-declaration
CFLAGS_AUTO = -flto -g -Og -std=c11 -Wall -Werror=implicit-function-declaration
LDFLAGS_AUTO =
LDLIBS_AUTO = -lm
CFLAGS_ALL = $(CPPFLAGS) $(CFLAGS_AUTO) $(CFLAGS)
LDFLAGS_ALL = $(LDFLAGS_AUTO) $(LDFLAGS)
LDLIBS_ALL = $(LDLIBS_AUTO) $(LDLIBS)
-include config.mak
ifeq ($(CONFIGURED),)
all:
@printf >&2 'Please run mk.sh, not make.\n'
@exit 1
else
include $(srcdir)/platform/$(platform).mk
imb3.elf: $(OBJS) obj/gc/$(gc_impl).o obj/platform/$(platform).o
$(CC) $(CFLAGS_ALL) $(LDFLAGS_ALL) -o $@ $^ $(LDLIBS_ALL)
obj/%.o: $(srcdir)/%.c
@mkdir -p $(dir $@)
$(CC) $(CFLAGS_ALL) -c -o $@ $<
# https://www.gnu.org/software/make/manual/html_node/Automatic-Prerequisites.html
obj/%.d: $(srcdir)/%.c
@mkdir -p obj
@set -e; rm -f $@; \
$(CC) -M $(CPPFLAGS) $< > $@.$$$$; \
sed 's,\($*\)\.o[ :]*,obj/\1.o $@ : ,g' < $@.$$$$ > $@; \
rm -f $@.$$$$
include $(DEPS)
endif
.PHONY: all
|