From 0834500bb4fe08e034f7931d2ebb9be6e19a0e05 Mon Sep 17 00:00:00 2001 From: Xavier Aubert Date: Tue, 20 Feb 2024 19:47:15 +0100 Subject: [PATCH 1/4] shell script generation now correclty supports multiple test_cfg file & correct log location --- bin/templates/regress_sh.j2 | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) diff --git a/bin/templates/regress_sh.j2 b/bin/templates/regress_sh.j2 index 41fe6880ec..3dc14fad2b 100644 --- a/bin/templates/regress_sh.j2 +++ b/bin/templates/regress_sh.j2 @@ -105,8 +105,12 @@ popd > /dev/null {% else %} {% set test_cfg = "" %} {% endif %} +{% set test_cfg_list = test_cfg|replace(" ",",")|replace("+",",") %} +{% set test_cfg_list = test_cfg_list.split(",")|unique|sort %} +{% set test_cfg_path = test_cfg_list|join("__") %} + # --> Test (Index: {{run_index}}): {{t.cmd}} : {{t.description}} -{% set cmd = test_cmd + ' CV_CORE=' + project + ' CFG=' + r.builds[build].cfg + ' ' + toolchain|upper + '=1' + ' RISCVDV_CFG=' + t.riscvdv_cfg + ' SIMULATOR=' + t.simulator + ' COMP=0 USE_ISS=' + regress_macros.yesorno(t.iss) + ' COV=' + regress_macros.yesorno(t.cov) + ' SEED=random GEN_START_INDEX=' + run_index|string + ' RUN_INDEX=' + run_index|string + ' TEST_CFG_FILE=' + test_cfg + ' ' + regress_macros.cv_results(results) + ' ' + makeargs %} +{% set cmd = test_cmd + ' CV_CORE=' + project + ' CFG=' + r.builds[build].cfg + ' ' + toolchain|upper + '=1' + ' RISCVDV_CFG=' + t.riscvdv_cfg + ' SIMULATOR=' + t.simulator + ' COMP=0 USE_ISS=' + regress_macros.yesorno(t.iss) + ' COV=' + regress_macros.yesorno(t.cov) + ' SEED=random GEN_START_INDEX=' + run_index|string + ' RUN_INDEX=' + run_index|string + ' TEST_CFG_FILE=\"' + test_cfg + '\" ' + regress_macros.cv_results(results) + ' ' + makeargs %} echo "{{session}}: Running test [cd {{t.abs_dir}} && {{cmd}}]" pushd {{t.abs_dir}} > /dev/null {{cmd}} >& /dev/null; @@ -118,13 +122,7 @@ popd > /dev/null {% else %} {% set results_dir = t.simulator + '_results' %} {% endif %} -{% if t.test_cfg is defined %} - {% set sim_log = t.simulator + '-' + test_log + '_' + t.test_cfg + '.log' %} - {% set test_cfg_path = t.test_cfg %} -{% else %} - {% set sim_log = t.simulator + '-' + test_log + '.log' %} - {% set test_cfg_path = '' %} -{% endif %} +{% set sim_log = t.simulator + '-' + test_log + '.log' %} {# Determine log location #} {% if t.results %} From 56b8889c0e214702feae584fdb6aebd2c708a8b1 Mon Sep 17 00:00:00 2001 From: Xavier Aubert Date: Tue, 20 Feb 2024 20:04:25 +0100 Subject: [PATCH 2/4] added README for commands to enter to generate v2 regress lists --- cv32e40p/regress/README.md | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 cv32e40p/regress/README.md diff --git a/cv32e40p/regress/README.md b/cv32e40p/regress/README.md new file mode 100644 index 0000000000..14a1fc4131 --- /dev/null +++ b/cv32e40p/regress/README.md @@ -0,0 +1,26 @@ +CV32E40P Regress Files +================================== + +For V2 core, all the regressions files should be generated using the following cv_regress commands, where *type* has to be chosen between `sh` and `rmdb`, and *sim* is the wanted simulator (vsim, xrun, ...) + +## pulp configuration + +> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp.{type} --cfg pulp +> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp.{type} --cfg pulp + +## pulp_fpu configuration +> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp_fpu.{type} --cfg pulp_fpu --add_test_cfg floating_pt_instr_en +> ./cv_regress --{type} --file=cv32e40pv2_fpu_instr.yaml --simulator={sim} --outfile=fpu_instr_pulp_fpu.{type} --cfg pulp_fpu --add_test_cfg floating_pt_instr_en +> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp_fpu.{type} --cfg pulp_fpu --add_test_cfg floating_pt_instr_en + +## pulp_fpu_zfinx configuration +> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp_fpu_zfinx.{type} --cfg pulp_fpu_zfinx --add_test_cfg floating_pt_zfinx_instr_en +> ./cv_regress --{type} --file=cv32e40pv2_fpu_instr.yaml --simulator={sim} --outfile=fpu_instr_pulp_fpu_zfinx.{type} --cfg pulp_fpu_zfinx --add_test_cfg floating_pt_zfinx_instr_en +> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp_fpu_zfinx.{type} --cfg pulp_fpu_zfinx --add_test_cfg floating_pt_zfinx_instr_en + +## configurations with latency +To generate regressions with latency (e.g. pulp_fpu_zfinx_2cyclat), only the `--cfg` switch has to be updated: + +> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp_fpu_zfinx_2cyclat.{type} --cfg pulp_fpu_zfinx_2cyclat --add_test_cfg floating_pt_zfinx_instr_en +> ./cv_regress --{type} --file=cv32e40pv2_fpu_instr.yaml --simulator={sim} --outfile=fpu_instr_pulp_fpu_zfinx_2cyclat.{type} --cfg pulp_fpu_zfinx_2cyclat --add_test_cfg floating_pt_instr_en +> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp_fpu_zfinx_2cyclat.{type} --cfg pulp_fpu_zfinx_2cyclat --add_test_cfg floating_pt_instr_en From 9e18a04372d677cb8dabfaf0690f93d904b87fea Mon Sep 17 00:00:00 2001 From: XavierAubert Date: Tue, 20 Feb 2024 20:08:16 +0100 Subject: [PATCH 3/4] Update README.md carriage return added --- cv32e40p/regress/README.md | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/cv32e40p/regress/README.md b/cv32e40p/regress/README.md index 14a1fc4131..b4b48d4b4f 100644 --- a/cv32e40p/regress/README.md +++ b/cv32e40p/regress/README.md @@ -5,22 +5,22 @@ For V2 core, all the regressions files should be generated using the following c ## pulp configuration -> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp.{type} --cfg pulp -> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp.{type} --cfg pulp +> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp.{type} --cfg pulp
+> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp.{type} --cfg pulp
## pulp_fpu configuration -> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp_fpu.{type} --cfg pulp_fpu --add_test_cfg floating_pt_instr_en -> ./cv_regress --{type} --file=cv32e40pv2_fpu_instr.yaml --simulator={sim} --outfile=fpu_instr_pulp_fpu.{type} --cfg pulp_fpu --add_test_cfg floating_pt_instr_en -> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp_fpu.{type} --cfg pulp_fpu --add_test_cfg floating_pt_instr_en +> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp_fpu.{type} --cfg pulp_fpu --add_test_cfg floating_pt_instr_en
+> ./cv_regress --{type} --file=cv32e40pv2_fpu_instr.yaml --simulator={sim} --outfile=fpu_instr_pulp_fpu.{type} --cfg pulp_fpu --add_test_cfg floating_pt_instr_en
+> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp_fpu.{type} --cfg pulp_fpu --add_test_cfg floating_pt_instr_en
## pulp_fpu_zfinx configuration -> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp_fpu_zfinx.{type} --cfg pulp_fpu_zfinx --add_test_cfg floating_pt_zfinx_instr_en -> ./cv_regress --{type} --file=cv32e40pv2_fpu_instr.yaml --simulator={sim} --outfile=fpu_instr_pulp_fpu_zfinx.{type} --cfg pulp_fpu_zfinx --add_test_cfg floating_pt_zfinx_instr_en -> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp_fpu_zfinx.{type} --cfg pulp_fpu_zfinx --add_test_cfg floating_pt_zfinx_instr_en +> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp_fpu_zfinx.{type} --cfg pulp_fpu_zfinx --add_test_cfg floating_pt_zfinx_instr_en
+> ./cv_regress --{type} --file=cv32e40pv2_fpu_instr.yaml --simulator={sim} --outfile=fpu_instr_pulp_fpu_zfinx.{type} --cfg pulp_fpu_zfinx --add_test_cfg floating_pt_zfinx_instr_en
+> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp_fpu_zfinx.{type} --cfg pulp_fpu_zfinx --add_test_cfg floating_pt_zfinx_instr_en
## configurations with latency To generate regressions with latency (e.g. pulp_fpu_zfinx_2cyclat), only the `--cfg` switch has to be updated: -> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp_fpu_zfinx_2cyclat.{type} --cfg pulp_fpu_zfinx_2cyclat --add_test_cfg floating_pt_zfinx_instr_en -> ./cv_regress --{type} --file=cv32e40pv2_fpu_instr.yaml --simulator={sim} --outfile=fpu_instr_pulp_fpu_zfinx_2cyclat.{type} --cfg pulp_fpu_zfinx_2cyclat --add_test_cfg floating_pt_instr_en +> ./cv_regress --{type} --file=cv32e40pv2_xpulp_instr.yaml --simulator={sim} --outfile=xpulp_instr_pulp_fpu_zfinx_2cyclat.{type} --cfg pulp_fpu_zfinx_2cyclat --add_test_cfg floating_pt_zfinx_instr_en
+> ./cv_regress --{type} --file=cv32e40pv2_fpu_instr.yaml --simulator={sim} --outfile=fpu_instr_pulp_fpu_zfinx_2cyclat.{type} --cfg pulp_fpu_zfinx_2cyclat --add_test_cfg floating_pt_instr_en
> ./cv_regress --{type} --file=cv32e40pv2_interrupt_debug.yaml --simulator={sim} --outfile=int_debug_pulp_fpu_zfinx_2cyclat.{type} --cfg pulp_fpu_zfinx_2cyclat --add_test_cfg floating_pt_instr_en From 94b5ddb11b28f68055af39990300ee11b9d22629 Mon Sep 17 00:00:00 2001 From: Xavier Aubert Date: Mon, 26 Feb 2024 15:49:11 +0100 Subject: [PATCH 4/4] reverted a deprecated feature now handled by TEST_CFG parameter (old feature introduced in commits 48dacb5d8e5d266eecd37897fb2138e511d38474 and 89e3869e52ed5b65bc93e312a4cec9a39da4ed61 --- bin/lib/cv_regression.py | 3 --- bin/templates/regress_sh.j2 | 2 +- bin/templates/regress_vsif.j2 | 2 +- mk/Common.mk | 9 +-------- mk/uvmt/uvmt.mk | 2 -- 5 files changed, 3 insertions(+), 15 deletions(-) diff --git a/bin/lib/cv_regression.py b/bin/lib/cv_regression.py index 076175f676..4dea5aeaf9 100644 --- a/bin/lib/cv_regression.py +++ b/bin/lib/cv_regression.py @@ -89,9 +89,6 @@ def __init__(self, **kwargs): if not hasattr(self, 'testname'): self.testname = self.name - if not hasattr(self, 'riscvdv_cfg'): - self.riscvdv_cfg = '' - # Log equals the test name if does not exist if not hasattr(self, 'log'): self.log = self.name diff --git a/bin/templates/regress_sh.j2 b/bin/templates/regress_sh.j2 index 3dc14fad2b..f861cfd28c 100644 --- a/bin/templates/regress_sh.j2 +++ b/bin/templates/regress_sh.j2 @@ -110,7 +110,7 @@ popd > /dev/null {% set test_cfg_path = test_cfg_list|join("__") %} # --> Test (Index: {{run_index}}): {{t.cmd}} : {{t.description}} -{% set cmd = test_cmd + ' CV_CORE=' + project + ' CFG=' + r.builds[build].cfg + ' ' + toolchain|upper + '=1' + ' RISCVDV_CFG=' + t.riscvdv_cfg + ' SIMULATOR=' + t.simulator + ' COMP=0 USE_ISS=' + regress_macros.yesorno(t.iss) + ' COV=' + regress_macros.yesorno(t.cov) + ' SEED=random GEN_START_INDEX=' + run_index|string + ' RUN_INDEX=' + run_index|string + ' TEST_CFG_FILE=\"' + test_cfg + '\" ' + regress_macros.cv_results(results) + ' ' + makeargs %} +{% set cmd = test_cmd + ' CV_CORE=' + project + ' CFG=' + r.builds[build].cfg + ' ' + toolchain|upper + '=1 SIMULATOR=' + t.simulator + ' COMP=0 USE_ISS=' + regress_macros.yesorno(t.iss) + ' COV=' + regress_macros.yesorno(t.cov) + ' SEED=random GEN_START_INDEX=' + run_index|string + ' RUN_INDEX=' + run_index|string + ' TEST_CFG_FILE=\"' + test_cfg + '\" ' + regress_macros.cv_results(results) + ' ' + makeargs %} echo "{{session}}: Running test [cd {{t.abs_dir}} && {{cmd}}]" pushd {{t.abs_dir}} > /dev/null {{cmd}} >& /dev/null; diff --git a/bin/templates/regress_vsif.j2 b/bin/templates/regress_vsif.j2 index 3886b33a4f..2695a0c9dd 100644 --- a/bin/templates/regress_vsif.j2 +++ b/bin/templates/regress_vsif.j2 @@ -64,7 +64,7 @@ group {{project}} { test precmd { sv_seed: gen_random; count: 1; - run_script: 'cd {{t.abs_dir}} && {{t.precmd}} CV_SIM_PREFIX= CV_CORE={{project}} CFG={{build.cfg}} RISCVDV_CFG={{t.riscvdv_cfg}} {{toolchain|upper}}=1 SIMULATOR={{t.simulator}} RNDSEED=$RUN_ENV(BRUN_SV_SEED) NUM_TESTS={{t.num}} {{regress_macros.cv_results(results)}} {{makeargs}}'; + run_script: 'cd {{t.abs_dir}} && {{t.precmd}} CV_SIM_PREFIX= CV_CORE={{project}} CFG={{build.cfg}} {{toolchain|upper}}=1 SIMULATOR={{t.simulator}} RNDSEED=$RUN_ENV(BRUN_SV_SEED) NUM_TESTS={{t.num}} {{regress_macros.cv_results(results)}} {{makeargs}}'; }; {% else %} {% endif %} diff --git a/mk/Common.mk b/mk/Common.mk index b46654ce28..ff2b163007 100644 --- a/mk/Common.mk +++ b/mk/Common.mk @@ -191,16 +191,9 @@ ifneq ($(filter gen_corev-dv,$(MAKECMDGOALS)),) ifeq ($(TEST),) $(error ERROR must specify a TEST variable with gen_corev-dv target) endif -ifeq ($(RISCVDV_CFG),) GEN_FLAGS_MAKE := $(shell $(YAML2MAKE) --test=$(TEST) --yaml=corev-dv.yaml $(YAML2MAKE_DEBUG) --prefix=GEN --core=$(CV_CORE)) ifeq ($(GEN_FLAGS_MAKE),) -$(error ERROR Could not find corev-dv.yaml of for test: $(TEST)) -endif -else -GEN_FLAGS_MAKE := $(shell $(YAML2MAKE) --test=$(TEST) --yaml=$(RISCVDV_CFG).yaml $(YAML2MAKE_DEBUG) --prefix=GEN --core=$(CV_CORE)) -ifeq ($(GEN_FLAGS_MAKE),) -$(error ERROR Could not find corev-dv_$(RISCVDV_CFG).yaml of for test: $(TEST)) -endif +$(error ERROR Could not find corev-dv.yaml for test: $(TEST)) endif include $(GEN_FLAGS_MAKE) endif diff --git a/mk/uvmt/uvmt.mk b/mk/uvmt/uvmt.mk index 5a29233170..f28f5d1e23 100644 --- a/mk/uvmt/uvmt.mk +++ b/mk/uvmt/uvmt.mk @@ -169,8 +169,6 @@ export RISCV_DV_ROOT = $(RISCVDV_PKG) export COREV_DV_ROOT = $(COREVDV_PKG) export CV_CORE_COREV_DV_ROOT = $(CV_CORE_COREVDV_PKG) -RISCVDV_CFG ?= - # EMBench benchmarking suite EMBENCH_PKG := $(CORE_V_VERIF)/$(CV_CORE_LC)/vendor_lib/embench EMBENCH_TESTS := $(CORE_V_VERIF)/$(CV_CORE_LC)/tests/programs/embench