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