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