]> cloudbase.mooo.com Git - z180-stamp.git/blame - avr/Tupfile
Add build configuration for ATmega2561
[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
c0abd68b 10SRC += cmd_loadihex.c cmd_loadcpm3.c cmd_sd.c cmd_fat.c
e63b2f75 11SRC += env.c xmalloc.c con-utils.c print-utils.c getopt-min.c
845cbdbd 12SRC += timer.c serial.c i2c.c bcd.c pcf8583.c mmc.c
05994bd9 13SRC += background.c z180-serv.c z80-if.c gpio.c
4f881b02 14SRC += $(FATFS) $(TOP)/fatfs/src/option/unicode.c
d684c216 15
e63b2f75
L
16#TODO: time lib
17SRC += ../time/asctime_r.c ../time/gmtime_r.c ../time/mk_gmtime.c
18SRC += ../time/print_lz.c ../time/isLeap.c
19b9a7d8 19SRC += ../time/time.c ../time/fatfs_time.c
be5cfb4b
L
20SRC += ../time/system_time.c ../time/set_system_time.c
21
22ASRC += ../time/system_tick.S
e63b2f75 23
534e1dfc 24SRC_Z = ../z180/hdrom.c
d684c216 25
70da9bec
L
26#TARGETS = $(PROG).elf
27
f3e47f67
L
28ifdef MCU
29 MCU_TARGET = @(MCU)
30else
31 MCU_TARGET = atmega1281
32endif
33ifeq ($(MCU_TARGET),atmega1281)
34 DEFS += -DMCU_STRING=\"ATmega1281\"
35else
36 DEFS += -DMCU_STRING=\"ATmega2561\"
37endif
38
9b6b4b31 39F_CPU = 18432000UL
f3e47f67 40DEFS += -DF_CPU=$(F_CPU)
70da9bec 41
21a24f90
L
42INCLUDES += -I$(TOP)/include
43
44#INCLUDES += -I../z180
70da9bec 45
e7895944
L
46###############################################################################
47
05994bd9 48TOOLCHAINDIR =
e7895944
L
49TOOLCHAIN = avr
50
eded7ec4
L
51CC = $(TOOLCHAIN)-gcc
52LD = $(TOOLCHAIN)-gcc
53AR = $(TOOLCHAIN)-ar
54AS = $(TOOLCHAIN)-as
55OBJCOPY = $(TOOLCHAIN)-objcopy
56OBJDUMP = $(TOOLCHAIN)-objdump
57SIZE = $(TOOLCHAIN)-size
58GDB = $(TOOLCHAIN)-gdb
59
e7895944
L
60###############################################################################
61
70da9bec 62ifdef DEBUG
92b46605 63SRC += debug.c
70da9bec
L
64DEFS += -DDEBUG=2
65endif
66
eded7ec4 67CFLAGS = -g -Os
70da9bec 68CFLAGS += -mmcu=$(MCU_TARGET)
eded7ec4 69CFLAGS += -std=gnu99
d684c216 70CFLAGS += -Wall -Wextra
05994bd9
L
71CFLAGS += -Wredundant-decls
72CFLAGS += -mrelax
d0581f88
L
73CFLAGS += -fno-common
74CFLAGS += -ffunction-sections
75CFLAGS += -fdata-sections
76CFLAGS += -fno-tree-loop-optimize
77CFLAGS += -fno-move-loop-invariants
85787726 78CFLAGS += -fno-split-wide-types
d0581f88
L
79#CFLAGS += -flto
80CFLAGS += -fshort-enums
81
85787726 82#CFLAGS += -fdiagnostics-color=always
d0581f88
L
83#CFLAGS += -save-temps
84
4f881b02 85CFLAGS_$(FATFS) = -fno-strict-aliasing
d0581f88 86
21a24f90 87CFLAGS += $(INCLUDES)
70da9bec
L
88
89CPPFLAGS += $(DEFS)
90
be5cfb4b
L
91#ASFLAGS += -Wa,-adhlns=$(<:.S=.lst),-gstabs
92ASFLAGS += -mmcu=$(MCU_TARGET) -x assembler-with-cpp $(ASFLAGS)
93
70da9bec
L
94# Linker flags
95LDFLAGS += -Wl,--gc-sections
96LDFLAGS += -Wl,--cref
97
be5cfb4b
L
98# Assemble: create object files from assembler source files.
99#.S.o:
100# $(CC) -c $(ALL_ASFLAGS) $< -o $@
101
70da9bec 102
be5cfb4b 103!as = |> ^ AS %f^ $(CC) $(ASFLAGS) -c %f -o %o |> %B.o
4f881b02 104!cc = |> ^ CC %f^ $(CC) $(CFLAGS) $(CPPFLAGS) $(CFLAGS_%f) -c %f -o %o |> %B.o
eded7ec4
L
105!LINK = |> ^ LINK %o^ $(LD) $(CFLAGS) $(LDFLAGS) -Wl,-Map=%O.map %f $(LDLIBS) -o %o |> | %O.map
106!OBJCOPY= |> ^ OBJCOPY %o^ $(OBJCOPY) -Oihex %f %o |>
107!OBJDUMP= |> ^ OBJDUMP %o^ $(OBJDUMP) -h -S %f > %o |> %O.lss
05994bd9 108!SIZE = |> ^ SIZE^ $(SIZE) %f |>
eded7ec4 109
be5cfb4b 110: foreach $(ASRC) |> !as |> {objs}
eded7ec4
L
111: foreach $(SRC) | ../z180/hdrom.h |> !cc |> {objs}
112: $(SRC_Z) |> !cc -D'const=const __flash' |> {objs}
113
114: {objs} |> !LINK |> $(PROG).elf
115: $(PROG).elf |> !OBJCOPY |> %B.hex
116: $(PROG).elf |> !OBJDUMP |> %B.lss
117: $(PROG).elf |> !SIZE |>