]> cloudbase.mooo.com Git - z180-stamp.git/blame - avr/Tupfile
Create include directory
[z180-stamp.git] / avr / Tupfile
CommitLineData
70da9bec
L
1include_rules
2
534e1dfc
L
3PROG = stamp-test
4SRC = main.c
d684c216 5SRC += cli.c cli_readline.c command.c command_tbl.c
534e1dfc 6SRC += cmd_help.c cmd_echo.c cmd_mem.c cmd_boot.c
d684c216
L
7SRC += env.c xmalloc.c
8SRC += timer.c con-utils.c serial.c
72f58822 9SRC += background.c z180-serv.c z80-if.c
d684c216 10
534e1dfc 11SRC_Z = ../z180/hdrom.c
d684c216 12
70da9bec
L
13#TARGETS = $(PROG).elf
14
15MCU_TARGET = atmega1281
9b6b4b31
L
16F_CPU = 18432000UL
17DEFS = -DF_CPU=$(F_CPU) -DBAUD=115200UL
70da9bec 18
21a24f90
L
19INCLUDES += -I$(TOP)/include
20
21#INCLUDES += -I../z180
70da9bec 22
e7895944
L
23###############################################################################
24
25TOOLCHAINDIR =
26TOOLCHAIN = avr
27
eded7ec4
L
28CC = $(TOOLCHAIN)-gcc
29LD = $(TOOLCHAIN)-gcc
30AR = $(TOOLCHAIN)-ar
31AS = $(TOOLCHAIN)-as
32OBJCOPY = $(TOOLCHAIN)-objcopy
33OBJDUMP = $(TOOLCHAIN)-objdump
34SIZE = $(TOOLCHAIN)-size
35GDB = $(TOOLCHAIN)-gdb
36
e7895944
L
37###############################################################################
38
70da9bec 39ifdef DEBUG
92b46605 40SRC += debug.c
70da9bec
L
41DEFS += -DDEBUG=2
42endif
43
eded7ec4 44CFLAGS = -g -Os
70da9bec 45CFLAGS += -mmcu=$(MCU_TARGET)
eded7ec4 46CFLAGS += -std=gnu99
d684c216 47CFLAGS += -Wall -Wextra
eded7ec4 48CFLAGS += -Wredundant-decls
d0581f88
L
49CFLAGS += -mrelax
50CFLAGS += -fno-common
51CFLAGS += -ffunction-sections
52CFLAGS += -fdata-sections
53CFLAGS += -fno-tree-loop-optimize
54CFLAGS += -fno-move-loop-invariants
55#CFLAGS += -flto
56CFLAGS += -fshort-enums
57
58#CFLAGS += -save-temps
59
60
21a24f90 61CFLAGS += $(INCLUDES)
70da9bec
L
62
63CPPFLAGS += $(DEFS)
64
65# Linker flags
66LDFLAGS += -Wl,--gc-sections
67LDFLAGS += -Wl,--cref
68
69
eded7ec4
L
70!cc = |> ^ CC %f^ $(CC) $(CFLAGS) $(CPPFLAGS) -c %f -o %o |> %B.o
71!LINK = |> ^ LINK %o^ $(LD) $(CFLAGS) $(LDFLAGS) -Wl,-Map=%O.map %f $(LDLIBS) -o %o |> | %O.map
72!OBJCOPY= |> ^ OBJCOPY %o^ $(OBJCOPY) -Oihex %f %o |>
73!OBJDUMP= |> ^ OBJDUMP %o^ $(OBJDUMP) -h -S %f > %o |> %O.lss
74!SIZE = |> ^ SIZE^ $(SIZE) %f |>
75
76: foreach $(SRC) | ../z180/hdrom.h |> !cc |> {objs}
77: $(SRC_Z) |> !cc -D'const=const __flash' |> {objs}
78
79: {objs} |> !LINK |> $(PROG).elf
80: $(PROG).elf |> !OBJCOPY |> %B.hex
81: $(PROG).elf |> !OBJDUMP |> %B.lss
82: $(PROG).elf |> !SIZE |>
83