summaryrefslogtreecommitdiff
path: root/avr/Tupfile
blob: 54b976f4d623e8400c06ea010218e29e36405ab4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
include_rules

PROG		= z180-stamp-avr
SRC		= z180-stamp-avr.c serial.c z80-if.c
SRC_Z		= ../z180/hdrom.c
#TARGETS	= $(PROG).elf

MCU_TARGET	= atmega1281
F_CPU		= 16000000UL
DEFS		= -DF_CPU=$(F_CPU) -DBAUD=115200

INCLUDES += ../z180

ifdef DEBUG
DEFS	+= -DDEBUG=2
endif

CFLAGS	= -g -Os
CFLAGS	+= -mmcu=$(MCU_TARGET)
CFLAGS	+= -std=gnu99
CFLAGS	+= -Wall -Wextra -Wimplicit-function-declaration
CFLAGS	+= -Wredundant-decls 
#CFLAGS	+= -fno-common -ffunction-sections -fdata-sections
#CFLAGS	+= -I $(INCLUDES)

CPPFLAGS += $(DEFS)

# Linker flags
LDFLAGS	+= -Wl,--gc-sections
LDFLAGS	+= -Wl,--cref


!cc = |> ^ CC %f^ avr-gcc $(CFLAGS) $(CPPFLAGS) -c %f -o %o |> %B.o
!LINK = |> ^ LINK %o^ avr-gcc $(CFLAGS) $(LDFLAGS) -Wl,-Map=%O.map %f $(LDLIBS) -o %o |> | %O.map
!OBJCOPY= |> ^ OBJCOPY %o^ avr-objcopy -Oihex %f %o |>
!OBJDUMP= |> ^ OBJDUMP %o^ avr-objdump -h -S %f > %o |> %O.lss

: foreach $(SRC) | ../z180/hdrom.h |> !cc |>  {objs}
: $(SRC_Z) |> !cc -D'const=const __flash' |> {objs}

: {objs} |> !LINK |> $(PROG).elf
: $(PROG).elf |> !OBJCOPY |> %B.hex
: $(PROG).elf |> !OBJDUMP |> %B.lss