Makefile 3.6 KiB raw
1
# Radiance build file.
2
3
# Core standard library modules.
4
STD := -pkg std $(patsubst %,-mod %,$(shell cat std.lib))
5
6
# Full standard library with test modules.
7
STD_TEST := $(STD) $(patsubst %,-mod %,$(shell cat std.lib.test))
8
9
# Source files.
10
STD_LIB := $(shell find lib -name '*.rad')
11
BIN_DIR := bin
12
RAD_BIN := $(BIN_DIR)/radiance.rv64.dev
13
14
# Emulator command used to invoke the self-hosted compiler.
15
EMU       := $(or $(RAD_EMULATOR),emulator)
16
EMU_FLAGS := -memory-size=385024 \
17
			 -data-size=348160 \
18
			 -stack-size=512 \
19
			 -count-instructions
20
RADIANCE  := $(EMU) $(EMU_FLAGS) -run $(RAD_BIN)
21
22
# Verify the emulator binary exists.
23
EMU_PATH := $(shell command -v $(EMU) 2>/dev/null)
24
25
default: emulator $(RAD_BIN)
26
test: emulator std-test bin-test
27
28
# Emulator command check
29
30
emulator:
31
ifeq ($(EMU_PATH),)
32
	$(error Emulator not found. Install it or set RAD_EMULATOR to its path)
33
endif
34
35
# Compiler build
36
37
SEED      := seed/radiance.rv64
38
SEED_OPTS := $(STD) -pkg radiance -mod compiler/radiance.rad -entry radiance
39
40
$(RAD_BIN): $(STD_LIB) compiler/radiance.rad | $(BIN_DIR)
41
	@echo "radiance $(SEED) => $@"
42
	@$(EMU) $(EMU_FLAGS) -run $(SEED) $(SEED_OPTS) -o $@
43
44
$(BIN_DIR):
45
	@mkdir -p $@
46
47
# Standard Library Tests
48
49
STD_LIB_TEST := lib/std.test.rv64
50
51
std-test: $(STD_LIB_TEST)
52
	@echo
53
	@$(EMU) $(EMU_FLAGS) -run $(STD_LIB_TEST)
54
55
$(STD_LIB_TEST): $(STD_LIB) $(RAD_BIN)
56
	@echo "radiance -test $(STD_TEST) -entry std -o $@"
57
	@$(RADIANCE) -test $(STD_TEST) -entry std -o $@
58
59
clean-std-test:
60
	@rm -f lib/std.test.rv64 \
61
		lib/std.test.rv64.debug \
62
		lib/std.test.rv64.s \
63
		lib/std.test.rv64.o \
64
		lib/std.test.rv64.rw.data \
65
		lib/std.test.rv64.ro.data
66
67
# Binary Tests
68
69
BIN_TEST_DIR := test/tests
70
# Only tests with `//! returns:` are compiled to binaries and executed.
71
BIN_TEST_EXE_SRC := $(shell grep -rl '^//! returns:' $(BIN_TEST_DIR))
72
BIN_TEST_RAD_EXE_SRC := $(filter %.rad,$(BIN_TEST_EXE_SRC))
73
BIN_TEST_RAS_EXE_SRC := $(filter %.ras,$(BIN_TEST_EXE_SRC))
74
BIN_TEST_RAD_ASM_SRC := $(wildcard $(BIN_TEST_RAD_EXE_SRC:.rad=.ras))
75
BIN_TEST_EXE_BIN := $(patsubst %.rad,%.rv64,$(BIN_TEST_RAD_EXE_SRC)) \
76
	$(patsubst %.ras,%.rv64,$(BIN_TEST_RAS_EXE_SRC))
77
BIN_RUNNER   := test/runner.rv64
78
BIN_TEST_RUN := test/run
79
80
bin-test: $(BIN_RUNNER) $(BIN_TEST_EXE_BIN)
81
	@echo
82
	@$(BIN_TEST_RUN)
83
84
# Runner binary: the lowering IL checker.
85
$(BIN_RUNNER): test/runner.rad $(STD_LIB) $(RAD_BIN)
86
	@echo "radiance test/runner.rad => $@"
87
	@$(RADIANCE) $(STD) -pkg runner -mod test/runner.rad -entry runner -o $@
88
89
# A `.rad` executable test can have a same-basename `.ras` module.
90
$(patsubst %.ras,%.rv64,$(BIN_TEST_RAD_ASM_SRC)): %.rv64: %.ras
91
92
# Compile each executable test to a binary.
93
$(BIN_TEST_DIR)/%.rv64: $(BIN_TEST_DIR)/%.rad $(RAD_BIN)
94
	@echo "radiance $< => $@"
95
	@$(RADIANCE) -pkg test -mod $< $(patsubst %,-mod %,$(wildcard $(@:.rv64=.ras))) -o $@
96
97
$(BIN_TEST_DIR)/%.rv64: $(BIN_TEST_DIR)/%.ras $(BIN_RUNNER)
98
	@echo "asm $< => $@"
99
	@$(EMU) $(EMU_FLAGS) -run $(BIN_RUNNER) -- assemble $< $@
100
101
clean-bin-test:
102
	@rm -f $(BIN_RUNNER) \
103
		$(BIN_RUNNER:.rv64=.rv64.debug) \
104
		$(BIN_RUNNER:.rv64=.rv64.s) \
105
		$(BIN_RUNNER:.rv64=.rv64.o) \
106
		$(BIN_RUNNER:.rv64=.rv64.rw.data) \
107
		$(BIN_RUNNER:.rv64=.rv64.ro.data) \
108
		$(BIN_TEST_EXE_BIN) \
109
		$(wildcard $(BIN_TEST_DIR)/*.rv64.debug) \
110
		$(wildcard $(BIN_TEST_DIR)/*.rv64.s) \
111
		$(wildcard $(BIN_TEST_DIR)/*.rv64.rw.data) \
112
		$(wildcard $(BIN_TEST_DIR)/*.rv64.ro.data)
113
114
seed:
115
	seed/update
116
117
clean-rad:
118
	rm -rf bin/*
119
	rm -f seed/radiance.rv64.s[0-9]*
120
121
clean: clean-std-test clean-bin-test clean-rad
122
123
t: test
124
c: clean
125
126
.PHONY: test clean default std-test bin-test seed \
127
	clean-std-test clean-bin-test clean-rad emulator
128
.SUFFIXES:
129
.DELETE_ON_ERROR:
130
.SILENT: