2021-10-23 15:53:32 +00:00
|
|
|
#=======================================================================
|
|
|
|
# Makefile for riscv-tests/isa
|
|
|
|
#-----------------------------------------------------------------------
|
|
|
|
|
|
|
|
act_dir := .
|
|
|
|
src_dir := $(act_dir)/src
|
2022-01-05 21:17:54 +00:00
|
|
|
ref_dir := $(act_dir)/references
|
2021-10-23 15:53:32 +00:00
|
|
|
work_dir := $(WORK)
|
|
|
|
work_dir_isa := $(work_dir)/rv$(XLEN)i_m/$(RISCV_DEVICE)
|
|
|
|
|
|
|
|
include $(act_dir)/Makefrag
|
|
|
|
ifneq ($(RISCV_TEST),)
|
|
|
|
target_tests = $(RISCV_TEST).elf
|
2022-01-05 21:17:54 +00:00
|
|
|
target_tests_nosim = $(empty)
|
2021-10-23 15:53:32 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
default: all
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
# Build rules
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
|
|
|
|
vpath %.S $(act_dir)
|
|
|
|
|
|
|
|
INCLUDE=$(TARGETDIR)/$(RISCV_TARGET)/device/rv$(XLEN)i_m/$(RISCV_DEVICE)/Makefile.include
|
|
|
|
ifeq ($(wildcard $(INCLUDE)),)
|
|
|
|
$(error Cannot find '$(INCLUDE)`. Check that RISCV_TARGET and RISCV_DEVICE are set correctly.)
|
|
|
|
endif
|
|
|
|
-include $(INCLUDE)
|
|
|
|
|
|
|
|
#------------------------------------------------------------
|
|
|
|
# Build and run assembly tests
|
|
|
|
|
|
|
|
%.log: %.elf
|
|
|
|
$(V) echo "Execute $(@)"
|
|
|
|
$(V) $(RUN_TARGET)
|
|
|
|
|
|
|
|
|
|
|
|
define compile_template
|
|
|
|
|
|
|
|
$(work_dir_isa)/%.elf: $(src_dir)/%.S
|
|
|
|
$(V) echo "Compile $$(@)"
|
|
|
|
@mkdir -p $$(@D)
|
|
|
|
$(V) $(COMPILE_TARGET)
|
|
|
|
|
|
|
|
.PRECIOUS: $(work_dir_isa)/%.elf
|
|
|
|
|
|
|
|
endef
|
|
|
|
|
|
|
|
target_elf = $(foreach e,$(target_tests),$(work_dir_isa)/$(e))
|
2022-01-05 21:17:54 +00:00
|
|
|
target_elf_nosim = $(foreach e,$(addsuffix .elf, $(target_tests_nosim)),$(work_dir_isa)/$(e))
|
|
|
|
combined_elf = $(target_elf_nosim) $(target_elf)
|
2021-10-23 15:53:32 +00:00
|
|
|
target_log = $(patsubst %.elf,%.log,$(target_elf))
|
|
|
|
|
2022-01-05 21:17:54 +00:00
|
|
|
ifdef target_tests_nosim
|
|
|
|
compile: copy
|
|
|
|
# now copy must be performed before compile,
|
|
|
|
# allowing us to copy over outputs if they won't simulate on spike correctly.
|
|
|
|
endif
|
|
|
|
|
|
|
|
copy:
|
|
|
|
@mkdir -p $(work_dir_isa)
|
|
|
|
$(info !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!)
|
|
|
|
$(info <<<<<<<<<<<<<<<<<<<<<<<<<<<< COPYING REFERENCES WITHOUT SIMULATING >>>>>>>>>>>>>>>>>>>>>>>>>>>>)
|
|
|
|
$(info !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!)
|
2022-02-06 19:48:23 +00:00
|
|
|
$(V) echo "Copying References without simulating for the following tests:"
|
|
|
|
$(V) echo $(target_tests_nosim)
|
2022-02-06 02:04:52 +00:00
|
|
|
$(V) for test in $(target_tests_nosim); do grep -o '^[^//#]*' $(ref_dir)/$$test.reference_output > $(work_dir_isa)/$$test.signature.output; done
|
2022-01-05 21:17:54 +00:00
|
|
|
|
|
|
|
compile: $(combined_elf)
|
|
|
|
run: $(target_log)
|
|
|
|
# note that run doesnt use the combined elf so it doesnt run the nosim tests.
|
2021-10-23 15:53:32 +00:00
|
|
|
|
|
|
|
#------------------------------------------------------------
|
|
|
|
# Clean up
|
|
|
|
|
|
|
|
clean:
|
|
|
|
rm -rf $(work_dir)
|