4 # Library modules to use
8 OPENCM3_DIR=/home/mj/stm/libopencm3
11 all: $(BINARY).elf $(BINARY).bin
13 flash: $(BINARY).flash
23 include $(OPENCM3_DIR)/mk/genlink-config.mk
25 PREFIX ?= arm-none-eabi
32 OBJCOPY := $(PREFIX)-objcopy
33 OBJDUMP := $(PREFIX)-objdump
39 TGT_CFLAGS += $(OPT) $(CSTD) $(DEBUG)
40 TGT_CFLAGS += $(ARCH_FLAGS)
41 TGT_CFLAGS += -Wall -Wextra -Wshadow -Wimplicit-function-declaration
42 TGT_CFLAGS += -Wredundant-decls -Wmissing-prototypes -Wstrict-prototypes
43 TGT_CFLAGS += -fno-common -ffunction-sections -fdata-sections
44 TGT_CFLAGS += -I. -I../lib
48 TGT_LDFLAGS += --static -nostartfiles
49 TGT_LDFLAGS += -T$(LDSCRIPT)
50 TGT_LDFLAGS += $(ARCH_FLAGS) $(DEBUG)
51 TGT_LDFLAGS += -Wl,-Map=$(*).map -Wl,--cref
52 TGT_LDFLAGS += -Wl,--gc-sections
54 TGT_LDFLAGS += -Wl,--print-gc-sections
57 LDLIBS += -Wl,--start-group -lc -lgcc -lnosys -Wl,--end-group
59 include $(OPENCM3_DIR)/mk/genlink-rules.mk
62 @printf " OBJCOPY $(*).bin\n"
63 $(Q)$(OBJCOPY) -Obinary $(*).elf $(*).bin
65 %.elf: $(OBJS) $(LDSCRIPT)
66 @printf " LD $(*).elf\n"
67 $(Q)$(LD) $(TGT_LDFLAGS) $(LDFLAGS) $(OBJS) $(LDLIBS) -o $*.elf
70 @printf " CC $(*).c\n"
71 $(Q)$(CC) $(TGT_CFLAGS) $(CFLAGS) $(TGT_CPPFLAGS) $(CPPFLAGS) -o $@ -c $<
76 $(Q)rm -f *.elf *.bin *.o *.d *.map $(LDSCRIPT)
80 $(Q)../bin/st-flash write $(*).bin 0x8000000
85 -include $(OBJS:.o=.d)