tbm-mcu/Makefile

68 lines
1.3 KiB
Makefile
Raw Normal View History

TARGET ?= host
TARGET := $(filter host stm32f0,${TARGET})
ifeq (${TARGET},)
$(error No support available for the target)
endif
2017-03-09 12:32:04 +00:00
BUILD ?= build
BUILD := $(addsuffix /${TARGET},${BUILD})
2017-03-09 12:32:04 +00:00
all: $(BUILD)/tbm
2017-02-27 14:48:38 +00:00
-include scripts/Makefile.${TARGET}
2017-02-27 14:48:38 +00:00
2017-03-09 12:32:04 +00:00
CFLAGS += -Iinclude
CFLAGS += -Wall -Wundef -Wextra -Wshadow -Wimplicit-function-declaration
CFLAGS += -Wredundant-decls -Wmissing-prototypes -Wstrict-prototypes
2017-05-15 16:34:51 +02:00
CFLAGS += -Os
LDFLAGS += -Os
2017-03-09 12:32:04 +00:00
2017-04-07 16:32:44 +02:00
obj-y += source/bitops.o
2017-03-09 12:32:04 +00:00
obj-y += source/main.o
2017-03-11 12:42:32 +00:00
obj-y += source/core/flash.o
2017-05-19 19:02:03 +02:00
obj-y += source/fs/mufs/super.o
2017-05-19 19:02:03 +02:00
obj-y += source/ftl/dev.o
obj-y += source/ftl/ftl.o
2017-05-19 19:02:03 +02:00
obj-y += source/ftl/gc.o
obj-y += source/ftl/map.o
obj-y += source/shell/cmd.o
obj-y += source/shell/flash.o
obj-y += source/shell/ftl.o
obj-y += source/shell/mufs.o
obj-y += source/shell/part.o
2017-03-09 12:32:04 +00:00
obj = $(addprefix $(BUILD)/, $(obj-y))
# Include the dependencies.
-include $(obj:.o=.d)
# Set up the toolchain.
CC := $(PREFIX)-gcc
LD := $(PREFIX)-gcc
GDB := $(PREFIX)-gdb
MAKE := make
.SECONDARY:
clean:
@echo "CLEAN"
@rm -rf $(BUILD)
# Rule to compile C source code.
$(BUILD)/%.o: %.c
@echo "CC $<"
@mkdir -p $(dir $@)
@$(CC) -c $< -o $@ $(CFLAGS) -MT $@ -MMD -MP -MF $(@:.o=.d)
$(BUILD)/tbm: $(obj) $(LDSCRIPT)
2017-03-09 12:32:04 +00:00
@echo "LD $@"
@mkdir -p $(dir $@)
@$(LD) -o $@ $(CFLAGS) $(LDFLAGS) $(obj) $(LIBS)
2017-02-27 14:48:38 +00:00
.PHONY: clean