-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathMakefile
55 lines (42 loc) · 1.33 KB
/
Makefile
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
46
47
48
49
50
51
52
53
54
55
TESTS_DIR = $(abspath .)
BASE_DIR = $(abspath $(TESTS_DIR)/..)
RISCV_TESTS_DIR = $(TESTS_DIR)/riscv-tests
ISA_TESTS_DIR = $(RISCV_TESTS_DIR)/isa
BUILD_DIR = $(TESTS_DIR)/build
SIM_DIR = $(BASE_DIR)/sim
SIM_EXE = $(SIM_DIR)/build/sim
CORE ?= riscv.CoreExtMem
BUILD_CORE ?= 1
RISCV_PREFIX ?= riscv64-unknown-elf
CC = $(RISCV_PREFIX)-gcc
LD = $(RISCV_PREFIX)-gcc
OBJCOPY = $(RISCV_PREFIX)-objcopy
ARCHFLAGS ?= -march=rv32imzicsr -mabi=ilp32
CFLAGS = $(ARCHFLAGS)
ifeq ($(BUILD_CORE),1)
FORCE = FORCE
else
FORCE =
endif
-include $(CUSTOM_TESTS_DIR)/Makefile.include
TEST_DIRS ?= $(ISA_TESTS_DIR)/rv32ui $(ISA_TESTS_DIR)/rv32mi $(ISA_TESTS_DIR)/rv32um $(CUSTOM_TESTS_DIR)
ALL_ISA_TESTS = $(shell find $(TEST_DIRS) -name '*.S')
UNSUPPORTED_TESTS = %fence_i.S %breakpoint.S
ALL_TESTS = $(filter-out $(UNSUPPORTED_TESTS),$(ALL_ISA_TESTS))
ALL_TARGETS = $(addsuffix .pass,$(basename $(addprefix $(BUILD_DIR)/,$(notdir $(ALL_TESTS)))))
all: $(ALL_TARGETS)
.SECONDARY:
VPATH = $(TEST_DIRS)
$(BUILD_DIR)/%.o: %.S
mkdir -p $(@D)
$(CC) $(CFLAGS) -I$(TESTS_DIR) -I$(ISA_TESTS_DIR)/macros/scalar -c -o $@ $^
%.elf: %.o
$(LD) $(ARCHFLAGS) -ffreestanding -nostdlib -T tests.ld -o $@ $^
%.bin: %.elf
$(OBJCOPY) -O binary $^ $@
$(SIM_EXE): $(FORCE)
make -C $(SIM_DIR) CORE=$(CORE)
.PHONY: FORCE
%.pass: %.bin $(SIM_EXE)
cd $(BASE_DIR); $(SIM_EXE) $<
touch $@