]> cloudbase.mooo.com Git - z180-stamp.git/blob - stm32/Tupfile
New build system: tup
[z180-stamp.git] / stm32 / Tupfile
1 include_rules
2
3 PROG = z180-stamp-stm32
4 SRC = z180-stamp-stm32.c serial.c z80-if.c
5 SRC_Z = ../z180/hdrom.c
6 #TARGETS = $(PROG).elf
7
8 FP_FLAGS = -msoft-float
9 DEFS = -DSTM32F1 -DBAUD=115200
10
11 LIBNAME = opencm3_stm32f1
12 OPENCM3_DIR = $(TOP)/libopencm3
13 LDSCRIPT = stm32vl-discovery.ld
14
15 ###############################################################################
16 # Executables
17
18 TOOLCHAINDIR = /usr/local/gcc-arm-none-eabi-4_8-2014q2/bin
19 TOOLCHAIN = $(TOOLCHAINDIR)/arm-none-eabi
20
21 CC = $(TOOLCHAIN)-gcc
22 LD = $(TOOLCHAIN)-gcc
23 AR = $(TOOLCHAIN)-ar
24 AS = $(TOOLCHAIN)-as
25 OBJCOPY = $(TOOLCHAIN)-objcopy
26 OBJDUMP = $(TOOLCHAIN)-objdump
27 GDB = $(TOOLCHAIN)-gdb
28
29 ###############################################################################
30
31 INCLUDES += $(OPENCM3_DIR)/include
32 LIBDIRS += $(OPENCM3_DIR)/lib
33
34 SCRIPT_DIR = $(OPENCM3_DIR)/scripts
35
36
37 ifdef DEBUG
38 DEFS += -DDEBUG=2
39 endif
40
41 CFLAGS += -g -Os
42 CFLAGS += -mthumb -mcpu=cortex-m3 $(FP_FLAGS) -mfix-cortex-m3-ldrd
43 CFLAGS += -std=gnu99
44 CFLAGS += -Wall -Wextra -Wimplicit-function-declaration
45 CFLAGS += -Wredundant-decls
46 #CFLAGS += -fno-common -ffunction-sections -fdata-sections
47 CFLAGS += -I $(INCLUDES)
48
49 CPPFLAGS += $(DEFS)
50
51 # Linker flags
52 LDFLAGS += --static -nostartfiles
53 LDFLAGS += -T$(LDSCRIPT)
54 LDFLAGS += -Wl,--gc-sections
55 LDFLAGS += -Wl,--cref
56
57 LDLIBS += -L$(LIBDIRS) -l$(LIBNAME)
58 LDLIBS += -Wl,--start-group -lc -lgcc -lnosys -Wl,--end-group
59
60
61 !cc = |> ^ CC %f^ $(CC) $(CFLAGS) $(CPPFLAGS) -c %f -o %o |> %B.o
62 !LINK = |> ^ LINK %o^ $(LD) $(CFLAGS) $(LDFLAGS) -Wl,-Map=%O.map %f $(LDLIBS) -o %o |> | %O.map
63 !OBJCOPY= |> ^ OBJCOPY %o^ $(OBJCOPY) -Oihex %f %o |>
64 !OBJDUMP= |> ^ OBJDUMP %o^ $(OBJDUMP) -h -S %f > %o |> %O.lss
65
66 : foreach $(SRC) $(SRC_Z) | ../z180/hdrom.h |> !cc |> {objs}
67
68 : {objs} |> !LINK |> $(PROG).elf
69 : $(PROG).elf |> !OBJCOPY |> %B.hex
70 : $(PROG).elf |> !OBJDUMP |> %B.lss
71