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