-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
43 lines (32 loc) · 859 Bytes
/
Makefile
File metadata and controls
43 lines (32 loc) · 859 Bytes
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
TARGET = template
MCU = z80
BUILD_DIR = build
TOOLCHAIN_PATH = /usr/local/Cellar/sdcc/4.0.0
TOOLCHAIN = $(TOOLCHAIN_PATH)/bin
TOOLCHAIN_INCLUDE = $(TOOLCHAIN_PATH)/share/sdcc/include
CC = $(TOOLCHAIN)/sdcc
LD = $(TOOLCHAIN)/sdld
AR = $(TOOLCHAIN)/sdar
OBJCPY = $(TOOLCHAIN)/sdobjcopy
CP = /bin/cp
RM = /bin/rm
# Includes
CFLAGS = -I$(TOOLCHAIN_INCLUDE)
CFLAGS += -I./include
# Compile flags
CFLAGS += -m$(MCU) -p$(MCU)
CFLAGS += --Werror --std-sdcc99
CFLAGS += --vc --code-loc 16384 --opt-code-size
ARFLAGS = -a
ASFLAGS = -plosgff
SRCS += src/main.c
SRCS += src/vt.c
OBJS = $(addprefix $(BUILD_DIR)/, $(addsuffix .rel, $(basename $(SRCS))))
.PHONY: $(BUILD_DIR)/$(TARGET).ihx
$(BUILD_DIR)/$(TARGET).ihx: $(OBJS)
$(CC) $(CFLAGS) $(OBJS) -o $@
clean:
$(RM) -rf $(BUILD_DIR)
$(BUILD_DIR)/%.rel: %.c
mkdir -p $(dir $@)
$(CC) $(CFLAGS) -c -o $@ $<