Skip to content

Commit

Permalink
Merge pull request #2368 from silabs-kjetil/cv32e40x-arch-test
Browse files Browse the repository at this point in the history
Adding make targets needed to run riscof arch-tests for cv32e40x
  • Loading branch information
silabs-robin authored Feb 26, 2024
2 parents 3a808bc + 0d71089 commit 5da7184
Show file tree
Hide file tree
Showing 5 changed files with 152 additions and 2 deletions.
2 changes: 1 addition & 1 deletion bin/clonetb
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ clone() {
clone_cv32e40x() {
CV_CORE=cv32e40x
VERIF_ENV_REPO=https://github.com/openhwgroup/cv32e40x-dv.git
VERIF_ENV_REF=a78635844f929fe7a852e3ddcd15dd809c377850
VERIF_ENV_REF=d2ef40f9338a05af4ed9551a1c75d53370744e64
clone

ignore_cloned_directory
Expand Down
2 changes: 1 addition & 1 deletion mk/Common.mk
Original file line number Diff line number Diff line change
Expand Up @@ -232,7 +232,7 @@ endif
###############################################################################
# cfg
CFGYAML2MAKE = $(CORE_V_VERIF)/bin/cfgyaml2make
CFG_YAML_PARSE_TARGETS=comp ldgen comp_corev-dv gen_corev-dv test hex clean_hex corev-dv sanity-veri-run bsp compliance
CFG_YAML_PARSE_TARGETS=comp ldgen comp_corev-dv gen_corev-dv test hex clean_hex corev-dv sanity-veri-run bsp compliance riscof_sim_run
ifneq ($(filter $(CFG_YAML_PARSE_TARGETS),$(MAKECMDGOALS)),)
ifneq ($(CFG),)
ifneq ($(CFG_PATH_OVERRIDE),)
Expand Down
96 changes: 96 additions & 0 deletions mk/riscof.mk
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
###############################################################################
#
# Copyright 2023 OpenHW Group
# Copyright 2023 Dolphin Design
# Copyright 2024 Silicon Labs
#
# Licensed under the Solderpad Hardware Licence, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://solderpad.org/licenses/
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
###############################################################################
#
# This Makefile adds RISCOF RISCV-ARCH-TEST SUITE, related make variables
# to support running of riscof's riscv-arch-test suite within the core-v-verif
# testbench
#
###############################################################################

RISCOF_ARCH_TEST_SUITE_PKG := $(CORE_V_VERIF)/$(CV_CORE_LC)/vendor_lib/riscof/riscof_arch_test_suite
RISCOF_SIM ?= NO

RISCOF_TEST_PLUSARGS ?= +signature=DUT-$(CV_CORE).signature
RISCOF_TEST_RUN_DIR ?=$(SIM_CFG_RESULTS)/riscof_dut_work
SIM_RISCOF_ARCH_TESTS_RESULTS ?= $(RISCOF_TEST_RUN_DIR)

RISCOF_CONFIG_FILE ?= config.ini
RISCOF_VERBOSE ?= info

###############################################################################
# Generate command to clone RISCOF RISCV-ARCH-TEST SUITE
RISCOF_TEST_SUITE_CLONE_CMD = git clone -b $(RISCOF_ARCH_TEST_SUITE_BRANCH) --single-branch $(RISCOF_ARCH_TEST_SUITE_REPO) --recurse $(RISCOF_ARCH_TEST_SUITE_PKG)

ifeq ($(RISCOF_ARCH_TEST_SUITE_TAG), latest)
CLONE_RISCOF_ARCH_TEST_SUITE_CMD = riscof --verbose $(RISCOF_VERBOSE) arch-test --clone --dir $(RISCOF_ARCH_TEST_SUITE_PKG)
else
CLONE_RISCOF_ARCH_TEST_SUITE_CMD = $(RISCOF_TEST_SUITE_CLONE_CMD); cd $(RISCOF_ARCH_TEST_SUITE_PKG); git checkout $(RISCOF_ARCH_TEST_SUITE_TAG)
endif

###############################################################################
#Clean riscof riscv-arch-test suite
clean_riscof_arch_test_suite:
rm -rf $(RISCOF_ARCH_TEST_SUITE_PKG)


###############################################################################
#Clone the riscv-arch-test suite in core-v-verif for running the tests
clone_riscof_arch_test_suite: $(RISCOF_ARCH_TEST_SUITE_PKG)

$(RISCOF_ARCH_TEST_SUITE_PKG):
$(CLONE_RISCOF_ARCH_TEST_SUITE_CMD)

###############################################################################
#RISCOF Validate YAML Command
ifeq ($(call IS_YES,$(RISCOF_SIM)),YES)
RISCOF_VALIDATE_YAML_CMD = riscof validateyaml --config=$(RISCOF_CONFIG_FILE) --work-dir=$(SIM_CFG_RESULTS)/riscof_work
else
RISCOF_VALIDATE_YAML_CMD = echo $(RISCOF_SIM)
endif

.PHONY: riscof_validate_yaml
riscof_validate_yaml:
$(shell $(RISCOF_VALIDATE_YAML_CMD))

###############################################################################
#RISCOF Get Testlist Command
ifeq ($(call IS_YES,$(RISCOF_SIM)),YES)
RISCOF_GET_TESTLIST_CMD = riscof testlist --config=$(RISCOF_CONFIG_FILE) --suite=$(RISCOF_ARCH_TEST_SUITE_PKG)/ --env=$(RISCOF_ARCH_TEST_SUITE_PKG)/riscv-test-suite/env --work-dir=$(SIM_CFG_RESULTS)/riscof_work
else
RISCOF_GET_TESTLIST_CMD = echo $(RISCOF_SIM)
endif

.PHONY: riscof_get_testlist
riscof_get_testlist:
$(shell $(RISCOF_GET_TESTLIST_CMD))

#################################################################################
##RISCOF Run Command
RISCOF_RUN_ALL_CMD = riscof --verbose $(RISCOF_VERBOSE) run --config=$(RISCOF_CONFIG_FILE) --suite=$(RISCOF_ARCH_TEST_SUITE_PKG)/ --env=$(RISCOF_ARCH_TEST_SUITE_PKG)/riscv-test-suite/env --work-dir=$(SIM_CFG_RESULTS)/riscof_work
ifeq ($(call IS_NO,$(RISCOF_REF_RUN)),NO)
RISCOF_RUN_ALL_CMD += --no-ref-run
endif
ifeq ($(call IS_NO,$(RISCOF_DUT_RUN)),NO)
RISCOF_RUN_ALL_CMD += --no-dut-run
endif

.PHONY: riscof_run_all
riscof_run_all:
$(shell $(RISCOF_RUN_ALL_CMD))
5 changes: 5 additions & 0 deletions mk/uvmt/uvmt.mk
Original file line number Diff line number Diff line change
Expand Up @@ -357,6 +357,11 @@ isacov_logdiff:
@rm -rf trace.tmp agent.tmp
@(test ! -s $(ISACOV_LOGDIR)/isacov_logdiff && echo OK) || (echo FAIL; false)

###############################################################################
# RISCOF Makefile:
# - RISCOF Compliance Test Suite and Variables for build and simulations
include $(CORE_V_VERIF)/mk/riscof.mk

###############################################################################
# Include the targets/rules for the selected SystemVerilog simulator
#ifeq ($(SIMULATOR), unsim)
Expand Down
49 changes: 49 additions & 0 deletions mk/uvmt/xrun.mk
Original file line number Diff line number Diff line change
Expand Up @@ -492,6 +492,55 @@ compliance: $(XRUN_COMPLIANCE_PREREQ)
+firmware=$(COMPLIANCE_PKG)/work/$(RISCV_ISA)/$(RISCV_DEVICE)/$(COMPLIANCE_PROG).hex \
+elf_file=$(COMPLIANCE_PKG)/work/$(RISCV_ISA)/$(RISCV_DEVICE)/$(COMPLIANCE_PROG).elf

################################################################################
# RISCOF RISCV-ARCH-TEST DUT simulation targets
XRUN_RISCOF_SIM_PREREQ = $(RISCOF_TEST_RUN_DIR)/$(TEST).elf

comp_dut_riscof_sim:
@echo "$(BANNER)"
@echo "* Compiling xrun in $(SIM_RISCOF_ARCH_TESTS_RESULTS)"
@echo "* Log: $(SIM_RISCOF_ARCH_TESTS_RESULTS)/xrun.log"
@echo "$(BANNER)"
mkdir -p $(SIM_RISCOF_ARCH_TESTS_RESULTS) && \
cd $(SIM_RISCOF_ARCH_TESTS_RESULTS) && $(XRUN) \
$(XRUN_COMP) \
$(XRUN_ELAB_COV_FLAGS) \
-top $(RTLSRC_VLOG_TB_TOP) \
-l xrun.log \
-elaborate

comp_dut_rtl_riscof_sim: $(CV_CORE_PKG) $(SVLIB_PKG) comp_dut_riscof_sim

setup_riscof_sim: clean_riscof_arch_test_suite clone_riscof_arch_test_suite comp_dut_rtl_riscof_sim

gen_riscof_ovpsim_ic:
@touch -f $(RISCOF_TEST_RUN_DIR)/ovpsim.ic
@if [ ! -z "$(CFG_OVPSIM)" ]; then \
echo "$(CFG_OVPSIM)" > $(RISCOF_TEST_RUN_DIR)/ovpsim.ic; \
fi

# Target to run RISCOF DUT sim with XRUN
riscof_sim_run: $(XRUN_RISCOF_SIM_PREREQ) comp_dut_rtl_riscof_sim gen_riscof_ovpsim_ic
@echo "$(BANNER)"
@echo "* Running xrun in $(RISCOF_TEST_RUN_DIR)"
@echo "* Log: $(RISCOF_TEST_RUN_DIR)/xrun-$(TEST).log"
@echo "$(BANNER)"
cd $(RISCOF_TEST_RUN_DIR) && \
export IMPERAS_TOOLS=$(RISCOF_TEST_RUN_DIR)/ovpsim.ic && \
export IMPERAS_QUEUE_LICENSE=1 && \
$(XRUN) \
-R -xmlibdirname xcelium.d \
-l xrun-$(TEST).log \
$(XRUN_COMP_RUN) \
$(XRUN_RUN_WAVES_FLAGS) \
-covtest $(TEST) \
+UVM_TESTNAME=uvmt_cv32e40x_riscof_firmware_test_c \
$(CFG_PLUSARGS) \
$(RISCOF_TEST_PLUSARGS) \
+firmware=$(TEST).hex \
+elf_file=$(TEST).elf \
+itb_file=$(TEST).itb
@echo "* Log: $(RISCOF_TEST_RUN_DIR)/xrun-$(TEST).log"


###############################################################################
Expand Down

0 comments on commit 5da7184

Please sign in to comment.