]>
Commit | Line | Data |
---|---|---|
70da9bec L |
1 | include_rules |
2 | ||
534e1dfc L |
3 | PROG = stamp-test |
4 | SRC = main.c | |
d684c216 | 5 | SRC += cli.c cli_readline.c command.c command_tbl.c |
534e1dfc | 6 | SRC += cmd_help.c cmd_echo.c cmd_mem.c cmd_boot.c |
d684c216 L |
7 | SRC += env.c xmalloc.c |
8 | SRC += timer.c con-utils.c serial.c | |
72f58822 | 9 | SRC += background.c z180-serv.c z80-if.c |
d684c216 | 10 | |
534e1dfc | 11 | SRC_Z = ../z180/hdrom.c |
d684c216 | 12 | |
70da9bec L |
13 | #TARGETS = $(PROG).elf |
14 | ||
15 | MCU_TARGET = atmega1281 | |
9b6b4b31 L |
16 | F_CPU = 18432000UL |
17 | DEFS = -DF_CPU=$(F_CPU) -DBAUD=115200UL | |
70da9bec | 18 | |
21a24f90 L |
19 | INCLUDES += -I$(TOP)/include |
20 | ||
21 | #INCLUDES += -I../z180 | |
70da9bec | 22 | |
e7895944 L |
23 | ############################################################################### |
24 | ||
25 | TOOLCHAINDIR = | |
26 | TOOLCHAIN = avr | |
27 | ||
eded7ec4 L |
28 | CC = $(TOOLCHAIN)-gcc |
29 | LD = $(TOOLCHAIN)-gcc | |
30 | AR = $(TOOLCHAIN)-ar | |
31 | AS = $(TOOLCHAIN)-as | |
32 | OBJCOPY = $(TOOLCHAIN)-objcopy | |
33 | OBJDUMP = $(TOOLCHAIN)-objdump | |
34 | SIZE = $(TOOLCHAIN)-size | |
35 | GDB = $(TOOLCHAIN)-gdb | |
36 | ||
e7895944 L |
37 | ############################################################################### |
38 | ||
70da9bec | 39 | ifdef DEBUG |
92b46605 | 40 | SRC += debug.c |
70da9bec L |
41 | DEFS += -DDEBUG=2 |
42 | endif | |
43 | ||
eded7ec4 | 44 | CFLAGS = -g -Os |
70da9bec | 45 | CFLAGS += -mmcu=$(MCU_TARGET) |
eded7ec4 | 46 | CFLAGS += -std=gnu99 |
d684c216 | 47 | CFLAGS += -Wall -Wextra |
eded7ec4 | 48 | CFLAGS += -Wredundant-decls |
d0581f88 L |
49 | CFLAGS += -mrelax |
50 | CFLAGS += -fno-common | |
51 | CFLAGS += -ffunction-sections | |
52 | CFLAGS += -fdata-sections | |
53 | CFLAGS += -fno-tree-loop-optimize | |
54 | CFLAGS += -fno-move-loop-invariants | |
55 | #CFLAGS += -flto | |
56 | CFLAGS += -fshort-enums | |
57 | ||
58 | #CFLAGS += -save-temps | |
59 | ||
60 | ||
21a24f90 | 61 | CFLAGS += $(INCLUDES) |
70da9bec L |
62 | |
63 | CPPFLAGS += $(DEFS) | |
64 | ||
65 | # Linker flags | |
66 | LDFLAGS += -Wl,--gc-sections | |
67 | LDFLAGS += -Wl,--cref | |
68 | ||
69 | ||
eded7ec4 L |
70 | !cc = |> ^ CC %f^ $(CC) $(CFLAGS) $(CPPFLAGS) -c %f -o %o |> %B.o |
71 | !LINK = |> ^ LINK %o^ $(LD) $(CFLAGS) $(LDFLAGS) -Wl,-Map=%O.map %f $(LDLIBS) -o %o |> | %O.map | |
72 | !OBJCOPY= |> ^ OBJCOPY %o^ $(OBJCOPY) -Oihex %f %o |> | |
73 | !OBJDUMP= |> ^ OBJDUMP %o^ $(OBJDUMP) -h -S %f > %o |> %O.lss | |
74 | !SIZE = |> ^ SIZE^ $(SIZE) %f |> | |
75 | ||
76 | : foreach $(SRC) | ../z180/hdrom.h |> !cc |> {objs} | |
77 | : $(SRC_Z) |> !cc -D'const=const __flash' |> {objs} | |
78 | ||
79 | : {objs} |> !LINK |> $(PROG).elf | |
80 | : $(PROG).elf |> !OBJCOPY |> %B.hex | |
81 | : $(PROG).elf |> !OBJDUMP |> %B.lss | |
82 | : $(PROG).elf |> !SIZE |> | |
83 |