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