summaryrefslogtreecommitdiff
path: root/stm32/Tupfile
blob: 1778623f37cfd4f29bb44a0181e6079ff4d977f2 (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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
include_rules

PROG		= z180-stamp-stm32
SRC		= z180-stamp-stm32.c serial.c z80-if.c
SRC_Z		= ../z180/hdrom.c
#TARGETS	= $(PROG).elf

FP_FLAGS	= -msoft-float
DEFS		= -DSTM32F1 -DBAUD=115200

LIBNAME		= opencm3_stm32f1
OPENCM3_DIR	= $(TOP)/libopencm3
LDSCRIPT	= stm32vl-discovery.ld

###############################################################################
# Executables

TOOLCHAINDIR	= /usr/local/gcc-arm-none-eabi-4_8-2014q2/bin
TOOLCHAIN	= $(TOOLCHAINDIR)/arm-none-eabi

CC	= $(TOOLCHAIN)-gcc
LD	= $(TOOLCHAIN)-gcc
AR	= $(TOOLCHAIN)-ar
AS	= $(TOOLCHAIN)-as
OBJCOPY	= $(TOOLCHAIN)-objcopy
OBJDUMP	= $(TOOLCHAIN)-objdump
SIZE	= $(TOOLCHAIN)-size
GDB	= $(TOOLCHAIN)-gdb

###############################################################################

INCLUDES += $(OPENCM3_DIR)/include 
LIBDIRS  += $(OPENCM3_DIR)/lib

SCRIPT_DIR = $(OPENCM3_DIR)/scripts


ifdef DEBUG
DEFS	+= -DDEBUG=2
endif

CFLAGS	+= -g -Os
CFLAGS	+= -mthumb -mcpu=cortex-m3 $(FP_FLAGS) -mfix-cortex-m3-ldrd
CFLAGS	+= -std=gnu99
CFLAGS	+= -Wall -Wextra -Wimplicit-function-declaration
CFLAGS	+= -Wredundant-decls 
#CFLAGS	+= -fno-common -ffunction-sections -fdata-sections
CFLAGS	+= -I $(INCLUDES)

CPPFLAGS += $(DEFS)

# Linker flags
LDFLAGS	+= --static -nostartfiles
LDFLAGS	+= -T$(LDSCRIPT)
LDFLAGS	+= -Wl,--gc-sections
LDFLAGS	+= -Wl,--cref

LDLIBS		+= -L$(LIBDIRS) -l$(LIBNAME)
LDLIBS		+= -Wl,--start-group -lc -lgcc -lnosys -Wl,--end-group


!cc = |> ^ CC %f^ $(CC) $(CFLAGS) $(CPPFLAGS) -c %f -o %o |> %B.o
!LINK = |> ^ LINK %o^ $(LD) $(CFLAGS) $(LDFLAGS) -Wl,-Map=%O.map %f $(LDLIBS) -o %o |> | %O.map
!OBJCOPY= |> ^ OBJCOPY %o^ $(OBJCOPY) -Oihex %f %o |>
!OBJDUMP= |> ^ OBJDUMP %o^ $(OBJDUMP) -h -S %f > %o |> %O.lss
!SIZE = |> ^ SIZE^ $(SIZE) %f |> 

: foreach $(SRC) $(SRC_Z) | ../z180/hdrom.h |> !cc |>  {objs}

: {objs} |> !LINK |> $(PROG).elf
: $(PROG).elf |> !OBJCOPY |> %B.hex
: $(PROG).elf |> !OBJDUMP |> %B.lss
: $(PROG).elf |> !SIZE |>