From a8a03d60119aacff857dd1bbc54d0685d6928d62 Mon Sep 17 00:00:00 2001 From: David Harris Date: Fri, 5 Apr 2024 18:19:46 -0700 Subject: [PATCH 01/13] Reorganizing sim directory for multiple simulators --- Makefile | 4 ++- sim/questa/coverage | 2 ++ sim/{ => questa}/sim-buildroot | 0 sim/{ => questa}/sim-buildroot-batch | 0 sim/{ => questa}/sim-imperas | 0 sim/{ => questa}/sim-testfloat | 0 sim/{ => questa}/sim-testfloat-batch | 0 sim/{ => questa}/sim-testfloat-verilator | 0 sim/{ => questa}/sim-wally | 0 sim/{ => questa}/sim-wally-batch | 0 sim/{ => questa}/wave-dos/ahb-muldiv.do | 0 sim/{ => questa}/wave-dos/ahb-waves.do | 0 sim/{ => questa}/wave-dos/cache-waves.do | 0 sim/{ => questa}/wave-dos/default-waves.do | 0 sim/{ => questa}/wave-dos/generic.do | 0 sim/{ => questa}/wave-dos/linux-waves.do | 0 sim/{ => questa}/wave-dos/peripheral-waves.do | 0 sim/{ => vcs}/run_vcs.sh | 0 sim/{ => verilator}/verilate | 0 sim/wsim | 33 +++++++++++++++++++ sim/{ => xcelium}/wally.xrun | 0 21 files changed, 38 insertions(+), 1 deletion(-) create mode 100755 sim/questa/coverage rename sim/{ => questa}/sim-buildroot (100%) rename sim/{ => questa}/sim-buildroot-batch (100%) rename sim/{ => questa}/sim-imperas (100%) rename sim/{ => questa}/sim-testfloat (100%) rename sim/{ => questa}/sim-testfloat-batch (100%) rename sim/{ => questa}/sim-testfloat-verilator (100%) rename sim/{ => questa}/sim-wally (100%) rename sim/{ => questa}/sim-wally-batch (100%) rename sim/{ => questa}/wave-dos/ahb-muldiv.do (100%) rename sim/{ => questa}/wave-dos/ahb-waves.do (100%) rename sim/{ => questa}/wave-dos/cache-waves.do (100%) rename sim/{ => questa}/wave-dos/default-waves.do (100%) rename sim/{ => questa}/wave-dos/generic.do (100%) rename sim/{ => questa}/wave-dos/linux-waves.do (100%) rename sim/{ => questa}/wave-dos/peripheral-waves.do (100%) rename sim/{ => vcs}/run_vcs.sh (100%) rename sim/{ => verilator}/verilate (100%) create mode 100755 sim/wsim rename sim/{ => xcelium}/wally.xrun (100%) diff --git a/Makefile b/Makefile index 97e61f47e..33eeea45d 100644 --- a/Makefile +++ b/Makefile @@ -48,10 +48,12 @@ imperasdv_cov: vcover report -details -html sim/riscv.ucdb funcovreg: - iter-elf.bash --search ${WALLY}/tests/riscof/work/wally-riscv-arch-test/rv64i_m --cover + #iter-elf.bash --search ${WALLY}/tests/riscof/work/wally-riscv-arch-test/rv64i_m --cover #iter-elf.bash --search ${WALLY}/tests/riscof/work/wally-riscv-arch-test/rv64i_m/I --cover #iter-elf.bash --search ${WALLY}/tests/riscof/work/wally-riscv-arch-test/rv64i_m/privilege --cover #iter-elf.bash --search ${WALLY}/tests/riscof/work/wally-riscv-arch-test/rv64i_m/Q --cover + rm -f ${WALLY}/tests/riscof/work/riscv-arch-test/rv64i_m/*/src/*/dut/my.elf + iter-elf.bash --search ${WALLY}/tests/riscof/work/riscv-arch-test/rv64i_m/I --cover vcover report -details -html sim/riscv.ucdb coverage: diff --git a/sim/questa/coverage b/sim/questa/coverage new file mode 100755 index 000000000..038253911 --- /dev/null +++ b/sim/questa/coverage @@ -0,0 +1,2 @@ +# recompile coverage tests and run coverage including them +pushd $WALLY/tests/coverage; make; popd; ./regression-wally -coverage diff --git a/sim/sim-buildroot b/sim/questa/sim-buildroot similarity index 100% rename from sim/sim-buildroot rename to sim/questa/sim-buildroot diff --git a/sim/sim-buildroot-batch b/sim/questa/sim-buildroot-batch similarity index 100% rename from sim/sim-buildroot-batch rename to sim/questa/sim-buildroot-batch diff --git a/sim/sim-imperas b/sim/questa/sim-imperas similarity index 100% rename from sim/sim-imperas rename to sim/questa/sim-imperas diff --git a/sim/sim-testfloat b/sim/questa/sim-testfloat similarity index 100% rename from sim/sim-testfloat rename to sim/questa/sim-testfloat diff --git a/sim/sim-testfloat-batch b/sim/questa/sim-testfloat-batch similarity index 100% rename from sim/sim-testfloat-batch rename to sim/questa/sim-testfloat-batch diff --git a/sim/sim-testfloat-verilator b/sim/questa/sim-testfloat-verilator similarity index 100% rename from sim/sim-testfloat-verilator rename to sim/questa/sim-testfloat-verilator diff --git a/sim/sim-wally b/sim/questa/sim-wally similarity index 100% rename from sim/sim-wally rename to sim/questa/sim-wally diff --git a/sim/sim-wally-batch b/sim/questa/sim-wally-batch similarity index 100% rename from sim/sim-wally-batch rename to sim/questa/sim-wally-batch diff --git a/sim/wave-dos/ahb-muldiv.do b/sim/questa/wave-dos/ahb-muldiv.do similarity index 100% rename from sim/wave-dos/ahb-muldiv.do rename to sim/questa/wave-dos/ahb-muldiv.do diff --git a/sim/wave-dos/ahb-waves.do b/sim/questa/wave-dos/ahb-waves.do similarity index 100% rename from sim/wave-dos/ahb-waves.do rename to sim/questa/wave-dos/ahb-waves.do diff --git a/sim/wave-dos/cache-waves.do b/sim/questa/wave-dos/cache-waves.do similarity index 100% rename from sim/wave-dos/cache-waves.do rename to sim/questa/wave-dos/cache-waves.do diff --git a/sim/wave-dos/default-waves.do b/sim/questa/wave-dos/default-waves.do similarity index 100% rename from sim/wave-dos/default-waves.do rename to sim/questa/wave-dos/default-waves.do diff --git a/sim/wave-dos/generic.do b/sim/questa/wave-dos/generic.do similarity index 100% rename from sim/wave-dos/generic.do rename to sim/questa/wave-dos/generic.do diff --git a/sim/wave-dos/linux-waves.do b/sim/questa/wave-dos/linux-waves.do similarity index 100% rename from sim/wave-dos/linux-waves.do rename to sim/questa/wave-dos/linux-waves.do diff --git a/sim/wave-dos/peripheral-waves.do b/sim/questa/wave-dos/peripheral-waves.do similarity index 100% rename from sim/wave-dos/peripheral-waves.do rename to sim/questa/wave-dos/peripheral-waves.do diff --git a/sim/run_vcs.sh b/sim/vcs/run_vcs.sh similarity index 100% rename from sim/run_vcs.sh rename to sim/vcs/run_vcs.sh diff --git a/sim/verilate b/sim/verilator/verilate similarity index 100% rename from sim/verilate rename to sim/verilator/verilate diff --git a/sim/wsim b/sim/wsim new file mode 100755 index 000000000..c02b8accd --- /dev/null +++ b/sim/wsim @@ -0,0 +1,33 @@ +#!/usr/bin/python3 +# +# wsim +# David_Harris@hmc.edu 5 April 2024 +# Invoke a Wally simulation for a desired configuration and test suite or ELF on the specified simulator +# usage: wsim CONFIG TESTSUITE [-s/--sim SIMULATOR] [-g/--gui] +# example: wsim rv64gc arch64i +# example: wsim rv64gc tests/riscof/work/riscv-arch-test/rv64i_m/I/src/ref/ref.elf +# example: wsim rv32i arch32i -s verilator +# +# SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1 + +import argparse + +# Read arguments +parser = argparse.ArgumentParser() +parser.add_argument("config", help="Configuration file") +parser.add_argument("testsuite", help="Test suite or ELF file") +parser.add_argument("--sim", "-s", help="Simulator", choices=["questa", "verilator", "vcs"], default="questa") +parser.add_argument("--gui", "-g", help="Simulate with GUI", action="store_true") +args = parser.parse_args() +print("Config: " + args.config + " tests " + args.testsuite + " sim " + args.sim + " gui " + str(args.gui)) + +if (args.sim == "questa"): + cmd = "do wally-batch.do " + args.config + " " + args.testsuite + system("vsim -c -do \"" + cmd + "\"") +elif (args.sim == "verilator"): + print("Running Verilator") +elif (args.sim == "vcs"): + print("Running VCS") +else: + print("Unknown simulator") + exit(1) \ No newline at end of file diff --git a/sim/wally.xrun b/sim/xcelium/wally.xrun similarity index 100% rename from sim/wally.xrun rename to sim/xcelium/wally.xrun From a1d3e5b15ebb09d872b10be3374e3c9446af56cc Mon Sep 17 00:00:00 2001 From: David Harris Date: Fri, 5 Apr 2024 18:42:48 -0700 Subject: [PATCH 02/13] Moved do files into questa --- sim/{ => questa}/GetLineNum.do | 0 sim/{ => questa}/coverage-exclusions-rv64gc.do | 0 sim/{ => questa}/fpga-wave.do | 0 sim/{ => questa}/linux-wave.do | 0 sim/{ => questa}/testfloat-batch.do | 0 sim/{ => questa}/testfloat.do | 0 sim/{ => questa}/wally-batch.do | 15 ++++++++------- sim/{ => questa}/wally-imperas-cov.do | 0 sim/{ => questa}/wally-imperas-no-idv.do | 0 sim/{ => questa}/wally-imperas.do | 0 sim/{ => questa}/wally-linux-imperas.do | 0 sim/{ => questa}/wally.do | 0 sim/{ => questa}/wave-all.do | 0 sim/{ => questa}/wave-fpu.do | 0 sim/{ => questa}/wave.do | 0 15 files changed, 8 insertions(+), 7 deletions(-) rename sim/{ => questa}/GetLineNum.do (100%) rename sim/{ => questa}/coverage-exclusions-rv64gc.do (100%) rename sim/{ => questa}/fpga-wave.do (100%) rename sim/{ => questa}/linux-wave.do (100%) rename sim/{ => questa}/testfloat-batch.do (100%) rename sim/{ => questa}/testfloat.do (100%) rename sim/{ => questa}/wally-batch.do (82%) rename sim/{ => questa}/wally-imperas-cov.do (100%) rename sim/{ => questa}/wally-imperas-no-idv.do (100%) rename sim/{ => questa}/wally-imperas.do (100%) rename sim/{ => questa}/wally-linux-imperas.do (100%) rename sim/{ => questa}/wally.do (100%) rename sim/{ => questa}/wave-all.do (100%) rename sim/{ => questa}/wave-fpu.do (100%) rename sim/{ => questa}/wave.do (100%) diff --git a/sim/GetLineNum.do b/sim/questa/GetLineNum.do similarity index 100% rename from sim/GetLineNum.do rename to sim/questa/GetLineNum.do diff --git a/sim/coverage-exclusions-rv64gc.do b/sim/questa/coverage-exclusions-rv64gc.do similarity index 100% rename from sim/coverage-exclusions-rv64gc.do rename to sim/questa/coverage-exclusions-rv64gc.do diff --git a/sim/fpga-wave.do b/sim/questa/fpga-wave.do similarity index 100% rename from sim/fpga-wave.do rename to sim/questa/fpga-wave.do diff --git a/sim/linux-wave.do b/sim/questa/linux-wave.do similarity index 100% rename from sim/linux-wave.do rename to sim/questa/linux-wave.do diff --git a/sim/testfloat-batch.do b/sim/questa/testfloat-batch.do similarity index 100% rename from sim/testfloat-batch.do rename to sim/questa/testfloat-batch.do diff --git a/sim/testfloat.do b/sim/questa/testfloat.do similarity index 100% rename from sim/testfloat.do rename to sim/questa/testfloat.do diff --git a/sim/wally-batch.do b/sim/questa/wally-batch.do similarity index 82% rename from sim/wally-batch.do rename to sim/questa/wally-batch.do index 4afe42202..f7c449272 100644 --- a/sim/wally-batch.do +++ b/sim/questa/wally-batch.do @@ -20,11 +20,15 @@ onbreak {resume} +set CONFIG ${1} +set TESTSUITE ${2} +set WKDIR wkdir/work_${CONFIG}_${TESTSUITE} + # create library -if [file exists wkdir/work_${1}_${2}] { - vdel -lib wkdir/work_${1}_${2} -all +if [file exists ${WKDIR}] { + vdel -lib ${WKDIR} -all } -vlib wkdir/work_${1}_${2} +vlib ${WKDIR} # Create directory for coverage data mkdir -p cov @@ -63,10 +67,7 @@ if {$argc >= 3} { # "Extra checking for conflicts with always_comb done at vopt time" # because vsim will run vopt -# default to config/rv64ic, but allow this to be overridden at the command line. For example: -# do wally-pipelined-batch.do ../config/rv32imc rv32imc - -vlog -lint -work wkdir/work_${1}_${2} +incdir+../config/$1 +incdir+../config/deriv/$1 +incdir+../config/shared ../src/cvw.sv ../testbench/testbench.sv ../testbench/common/*.sv ../src/*/*.sv ../src/*/*/*.sv -suppress 2583 -suppress 7063,2596,13286 +vlog -lint -work ${WKDIR} +incdir+../config/$1 +incdir+../config/deriv/$1 +incdir+../config/shared ../src/cvw.sv ../testbench/testbench.sv ../testbench/common/*.sv ../src/*/*.sv ../src/*/*/*.sv -suppress 2583 -suppress 7063,2596,13286 # start and run simulation # remove +acc flag for faster sim during regressions if there is no need to access internal signals diff --git a/sim/wally-imperas-cov.do b/sim/questa/wally-imperas-cov.do similarity index 100% rename from sim/wally-imperas-cov.do rename to sim/questa/wally-imperas-cov.do diff --git a/sim/wally-imperas-no-idv.do b/sim/questa/wally-imperas-no-idv.do similarity index 100% rename from sim/wally-imperas-no-idv.do rename to sim/questa/wally-imperas-no-idv.do diff --git a/sim/wally-imperas.do b/sim/questa/wally-imperas.do similarity index 100% rename from sim/wally-imperas.do rename to sim/questa/wally-imperas.do diff --git a/sim/wally-linux-imperas.do b/sim/questa/wally-linux-imperas.do similarity index 100% rename from sim/wally-linux-imperas.do rename to sim/questa/wally-linux-imperas.do diff --git a/sim/wally.do b/sim/questa/wally.do similarity index 100% rename from sim/wally.do rename to sim/questa/wally.do diff --git a/sim/wave-all.do b/sim/questa/wave-all.do similarity index 100% rename from sim/wave-all.do rename to sim/questa/wave-all.do diff --git a/sim/wave-fpu.do b/sim/questa/wave-fpu.do similarity index 100% rename from sim/wave-fpu.do rename to sim/questa/wave-fpu.do diff --git a/sim/wave.do b/sim/questa/wave.do similarity index 100% rename from sim/wave.do rename to sim/questa/wave.do From 7b5680932397c45b5adecd72fb0c7fec7e37f840 Mon Sep 17 00:00:00 2001 From: David Harris Date: Fri, 5 Apr 2024 19:08:14 -0700 Subject: [PATCH 03/13] wsim runs a Questa sim --- sim/questa/wally-batch.do | 20 +++++++++++++------- sim/wsim | 3 ++- testbench/tests.vh | 12 ++++++------ 3 files changed, 21 insertions(+), 14 deletions(-) diff --git a/sim/questa/wally-batch.do b/sim/questa/wally-batch.do index f7c449272..f1489b7cb 100644 --- a/sim/questa/wally-batch.do +++ b/sim/questa/wally-batch.do @@ -20,9 +20,10 @@ onbreak {resume} -set CONFIG ${1} +set CFG ${1} set TESTSUITE ${2} -set WKDIR wkdir/work_${CONFIG}_${TESTSUITE} +set WKDIR wkdir/${CFG}_${TESTSUITE} +set WALLY $::env(WALLY) # create library if [file exists ${WKDIR}] { @@ -67,12 +68,16 @@ if {$argc >= 3} { # "Extra checking for conflicts with always_comb done at vopt time" # because vsim will run vopt -vlog -lint -work ${WKDIR} +incdir+../config/$1 +incdir+../config/deriv/$1 +incdir+../config/shared ../src/cvw.sv ../testbench/testbench.sv ../testbench/common/*.sv ../src/*/*.sv ../src/*/*/*.sv -suppress 2583 -suppress 7063,2596,13286 +set CONFIG ${WALLY}/config +set SRC ${WALLY}/src +set TB ${WALLY}/testbench + +vlog -lint -work ${WKDIR} +incdir+${CONFIG}/$1 +incdir+${CONFIG}/deriv/$1 +incdir+${CONFIG}/shared ${SRC}/cvw.sv ${TB}/testbench.sv ${TB}/common/*.sv ${SRC}/*/*.sv ${SRC}/*/*/*.sv -suppress 2583 -suppress 7063,2596,13286 # start and run simulation # remove +acc flag for faster sim during regressions if there is no need to access internal signals -vopt wkdir/work_${1}_${2}.testbench -work wkdir/work_${1}_${2} -G TEST=$2 ${configOptions} -o testbenchopt ${CoverageVoptArg} -vsim -lib wkdir/work_${1}_${2} testbenchopt -fatal 7 -suppress 3829 ${CoverageVsimArg} +vopt wkdir/${CFG}_${TESTSUITE}.testbench -work ${WKDIR} -G TEST=$2 ${configOptions} -o testbenchopt ${CoverageVoptArg} +vsim -lib ${WKDIR} testbenchopt -fatal 7 -suppress 3829 ${CoverageVsimArg} # vsim -lib wkdir/work_${1}_${2} testbenchopt -fatal 7 -suppress 3829 # power add generates the logging necessary for said generation. @@ -82,9 +87,10 @@ run -all if {$coverage} { - echo "Saving coverage to ${1}_${2}.ucdb" + set UCDB cov/${CONFIG}_${TESTSUITE}.ucdb + echo "Saving coverage to ${UCDB}" do coverage-exclusions-rv64gc.do # beware: this assumes testing the rv64gc configuration - coverage save -instance /testbench/dut/core cov/${1}_${2}.ucdb + coverage save -instance /testbench/dut/core ${UCDB} } # These aren't doing anything helpful diff --git a/sim/wsim b/sim/wsim index c02b8accd..723fb644b 100755 --- a/sim/wsim +++ b/sim/wsim @@ -11,6 +11,7 @@ # SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1 import argparse +import os # Read arguments parser = argparse.ArgumentParser() @@ -23,7 +24,7 @@ print("Config: " + args.config + " tests " + args.testsuite + " sim " + args.sim if (args.sim == "questa"): cmd = "do wally-batch.do " + args.config + " " + args.testsuite - system("vsim -c -do \"" + cmd + "\"") + os.system("cd questa; vsim -c -do \"" + cmd + "\"") elif (args.sim == "verilator"): print("Running Verilator") elif (args.sim == "vcs"): diff --git a/testbench/tests.vh b/testbench/tests.vh index 6958fc50d..8dfd69415 100644 --- a/testbench/tests.vh +++ b/testbench/tests.vh @@ -35,12 +35,12 @@ string tvpaths[] = '{ "$RISCV/imperas-riscv-tests/work/", - "../tests/riscof/work/riscv-arch-test/", - "../tests/riscof/work/wally-riscv-arch-test/", - "../benchmarks/coremark/work/", - "../addins/embench-iot/", - "../tests/custom/work/", - "../tests/coverage/" + "../../tests/riscof/work/riscv-arch-test/", + "../../tests/riscof/work/wally-riscv-arch-test/", + "../../benchmarks/coremark/work/", + "../../addins/embench-iot/", + "../../tests/custom/work/", + "../../tests/coverage/" }; string coverage64gc[] = '{ From 4cc9dd75832ac274c6891daf07269be9f1243bc8 Mon Sep 17 00:00:00 2001 From: David Harris Date: Fri, 5 Apr 2024 21:45:56 -0700 Subject: [PATCH 04/13] regression-wally refactoring to support mulitple simulators --- .gitignore | 12 +- sim/lint-wally | 2 +- sim/questa/coverage-exclusions-rv64gc.do | 282 +++++++------- sim/questa/sim-wally-batch | 2 +- sim/questa/wally-batch.do | 2 +- sim/regression-wally | 454 +++++++++++------------ sim/wsim | 5 +- 7 files changed, 365 insertions(+), 394 deletions(-) diff --git a/.gitignore b/.gitignore index 2acbd1f2a..963128c60 100644 --- a/.gitignore +++ b/.gitignore @@ -46,7 +46,6 @@ linux/buildroot linux/testvector-generation/boottrace.S linux/testvector-generation/boottrace_disasm.log sim/slack-notifier/slack-webhook-url.txt -sim/logs fpga/generator/IP fpga/generator/vivado.* fpga/generator/.Xil/* @@ -89,7 +88,6 @@ synthDC/hdl sim/power.saif tests/fp/vectors/*.tv synthDC/Summary.csv -sim/wkdir tests/custom/work tests/custom/*/*/*.list tests/custom/*/*/*.elf @@ -112,8 +110,6 @@ tests/wally-riscv-arch-test/riscv-test-suite/rv*i_m/I/src/*.S tests/wally-riscv-arch-test/riscv-test-suite/rv*i_m/I/Makefrag sim/branch_BP_GSHARE10.log sim/branch_BP_GSHARE16.log -sim/cov/ -sim/covhtmlreport/ sim/imperas.log sim/results-error/ sim/test1.rep @@ -186,3 +182,11 @@ sim/branch/* sim/obj_dir examples/verilog/fulladder/obj_dir config/deriv +sim/questa/cov +sim/questa/covhtmlreport/ +sim/questa/logs +sim/questa/wkdir +sim/verilator/logs +sim/verilator/wkdir +sim/vcs/logs +sim/vcs/wkdir diff --git a/sim/lint-wally b/sim/lint-wally index 5964d20ed..4187b0429 100755 --- a/sim/lint-wally +++ b/sim/lint-wally @@ -21,7 +21,7 @@ if [ "$1" == "-nightly" ]; then fi done else - configs=(rv32e rv64gc rv32gc rv32imc rv32i rv64i div_2_1i_rv64gc ) # add fdqh_rv64gc when working + configs=(rv32e rv64gc rv32gc rv32imc rv32i rv64i ) # add fdqh_rv64gc when working fi for config in ${configs[@]}; do diff --git a/sim/questa/coverage-exclusions-rv64gc.do b/sim/questa/coverage-exclusions-rv64gc.do index 36098d90d..3331c4574 100644 --- a/sim/questa/coverage-exclusions-rv64gc.do +++ b/sim/questa/coverage-exclusions-rv64gc.do @@ -28,6 +28,10 @@ # This file should be a last resort. It's preferable to put # // coverage off # statements inline with the code whenever possible. + +set WALLY $::env(WALLY) +set SRC ${WALLY}/src + # a hack to describe coverage exclusions without hardcoding linenumbers: do GetLineNum.do @@ -44,13 +48,13 @@ coverage exclude -scope /dut/core/fpu/fpu/fdivsqrt/fdivsqrtfsm -ftrans state DON # which won't happen while the divider is busy. coverage exclude -scope /dut/core/fpu/fpu/fdivsqrt/fdivsqrtfsm -ftrans state BUSY->IDLE # All Memory-stage stalls have resolved by time fdivsqrt finishes regular operation in this configuration, so can't test StallM -coverage exclude -scope /dut/core/fpu/fpu/fdivsqrt/fdivsqrtfsm -linerange [GetLineNum ../src/fpu/fdivsqrt/fdivsqrtfsm.sv "exclusion-tag: fdivsqrtfsm stallm"] -item b 1 -coverage exclude -scope /dut/core/fpu/fpu/fdivsqrt/fdivsqrtfsm -linerange [GetLineNum ../src/fpu/fdivsqrt/fdivsqrtfsm.sv "exclusion-tag: fdivsqrtfsm stallm"] -item s 1 +coverage exclude -scope /dut/core/fpu/fpu/fdivsqrt/fdivsqrtfsm -linerange [GetLineNum ${SRC}/fpu/fdivsqrt/fdivsqrtfsm.sv "exclusion-tag: fdivsqrtfsm stallm"] -item b 1 +coverage exclude -scope /dut/core/fpu/fpu/fdivsqrt/fdivsqrtfsm -linerange [GetLineNum ${SRC}/fpu/fdivsqrt/fdivsqrtfsm.sv "exclusion-tag: fdivsqrtfsm stallm"] -item s 1 # Division by zero never sets sticky/guard/overflow/round to cause inexact or underflow result, but check out of paranoia -coverage exclude -scope /dut/core/fpu/fpu/postprocess/flags -linerange [GetLineNum ../src/fpu/postproc/flags.sv "assign FpInexact"] -item e 1 -fecexprrow 15 -coverage exclude -scope /dut/core/fpu/fpu/postprocess/flags -linerange [GetLineNum ../src/fpu/postproc/flags.sv "assign Underflow"] -item e 1 -fecexprrow 22 +coverage exclude -scope /dut/core/fpu/fpu/postprocess/flags -linerange [GetLineNum ${SRC}/fpu/postproc/flags.sv "assign FpInexact"] -item e 1 -fecexprrow 15 +coverage exclude -scope /dut/core/fpu/fpu/postprocess/flags -linerange [GetLineNum ${SRC}/fpu/postproc/flags.sv "assign Underflow"] -item e 1 -fecexprrow 22 # Convert int to fp will never underflow -coverage exclude -scope /dut/core/fpu/fpu/postprocess/cvtshiftcalc -linerange [GetLineNum ../src/fpu/postproc/cvtshiftcalc.sv "assign CvtResUf"] -item e 1 -fecexprrow 4 +coverage exclude -scope /dut/core/fpu/fpu/postprocess/cvtshiftcalc -linerange [GetLineNum ${SRC}/fpu/postproc/cvtshiftcalc.sv "assign CvtResUf"] -item e 1 -fecexprrow 4 ################## # Cache Exclusions @@ -62,89 +66,89 @@ coverage exclude -scope /dut/core/fpu/fpu/postprocess/cvtshiftcalc -linerange [G coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -fstate CurrState STATE_FLUSH STATE_FLUSH_WRITEBACK STATE_FLUSH_WRITEBACK STATE_WRITEBACK coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -ftrans CurrState STATE_WRITE_LINE->STATE_READY STATE_FETCH->STATE_READY # exclude unused transitions from case statement. Unfortunately the whole branch needs to be excluded I think. Expression coverage should still work. -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache state-case"] -item b 1 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache state-case"] -item b 1 # I$ does not flush -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache FlushCache"] -item e 1 -fecexprrow 2 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache FlushCache"] -item e 1 -fecexprrow 2 # exclude branch/condition coverage: LineDirty if statement -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache FETCHStatement"] -item bc 1 -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache FLUSHStatement"] -item bs 1 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache FETCHStatement"] -item bc 1 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache FLUSHStatement"] -item bs 1 # exclude the unreachable logic -set start [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag-start: icache case"] -set end [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag-end: icache case"] +set start [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag-start: icache case"] +set end [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag-end: icache case"] coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange $start-$end -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache WRITEBACKStatement"] +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache WRITEBACKStatement"] # exclude Atomic Operation logic -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: cache AnyMiss"] -item e 1 -fecexprrow 6 -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache storeAMO1"] -item e 1 -fecexprrow 2-4 -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache AnyUpdateHit"] -item e 1 -fecexprrow 2 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: cache AnyMiss"] -item e 1 -fecexprrow 6 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache storeAMO1"] -item e 1 -fecexprrow 2-4 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache AnyUpdateHit"] -item e 1 -fecexprrow 2 # cache write logic -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache CacheW"] -item e 1 -fecexprrow 4 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache CacheW"] -item e 1 -fecexprrow 4 # output signal logic -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache StallStates"] -item e 1 -fecexprrow 8 12 14 -set start [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag-start: icache flushdirtycontrols"] -set end [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag-end: icache flushdirtycontrols"] +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache StallStates"] -item e 1 -fecexprrow 8 12 14 +set start [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag-start: icache flushdirtycontrols"] +set end [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag-end: icache flushdirtycontrols"] coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange $start-$end -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache CacheBusW"] -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache SelAdrCauses"] -item e 1 -fecexprrow 4 10 -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache SelAdrTag"] -item e 1 -fecexprrow 8 -coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: icache CacheBusRCauses"] -item e 1 -fecexprrow 1-2 12 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache CacheBusW"] +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache SelAdrCauses"] -item e 1 -fecexprrow 4 10 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache SelAdrTag"] -item e 1 -fecexprrow 8 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: icache CacheBusRCauses"] -item e 1 -fecexprrow 1-2 12 # cache.sv AdrSelMuxData and AdrSelMuxTag and CacheBusAdrMux, excluding unhit Flush branch -coverage exclude -scope /dut/core/ifu/bus/icache/icache/AdrSelMuxData -linerange [GetLineNum ../src/generic/mux.sv "exclusion-tag: mux3"] -item b 1 -coverage exclude -scope /dut/core/ifu/bus/icache/icache/AdrSelMuxTag -linerange [GetLineNum ../src/generic/mux.sv "exclusion-tag: mux3"] -item b 1 -coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheBusAdrMux -linerange [GetLineNum ../src/generic/mux.sv "exclusion-tag: mux3"] -item b 1 3 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/AdrSelMuxData -linerange [GetLineNum ${SRC}/generic/mux.sv "exclusion-tag: mux3"] -item b 1 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/AdrSelMuxTag -linerange [GetLineNum ${SRC}/generic/mux.sv "exclusion-tag: mux3"] -item b 1 +coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheBusAdrMux -linerange [GetLineNum ${SRC}/generic/mux.sv "exclusion-tag: mux3"] -item b 1 3 # CacheWay Dirty logic. -scope does not accept wildcards. set numcacheways 4 for {set i 0} {$i < $numcacheways} {incr i} { - coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "exclusion-tag: icache SetDirtyWay"] -item e 1 - coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "exclusion-tag: icache SelectedWiteWordEn"] -item e 1 -fecexprrow 4 6 + coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "exclusion-tag: icache SetDirtyWay"] -item e 1 + coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "exclusion-tag: icache SelectedWiteWordEn"] -item e 1 -fecexprrow 4 6 # below: flushD can't go high during an icache write b/c of pipeline stall - coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "exclusion-tag: cache SetValidEN"] -item e 1 -fecexprrow 4 - coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "exclusion-tag: cache ClearValidEN"] -item e 1 -fecexprrow 4 + coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "exclusion-tag: cache SetValidEN"] -item e 1 -fecexprrow 4 + coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "exclusion-tag: cache ClearValidEN"] -item e 1 -fecexprrow 4 # No CMO to clear valid bits of I$ - coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "// exclusion-tag: icache ClearValidBits"] - coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "// exclusion-tag: icache ClearValidWay"] -item e 1 + coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "// exclusion-tag: icache ClearValidBits"] + coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "// exclusion-tag: icache ClearValidWay"] -item e 1 # No dirty ways in read-only I$ - coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "// exclusion-tag: icache DirtyWay"] -item e 1 + coverage exclude -scope /dut/core/ifu/bus/icache/icache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "// exclusion-tag: icache DirtyWay"] -item e 1 } # I$ buscachefsm does not perform atomics or write/writeback; HREADY is always 1 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicReadData"] -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicElse"] -item s 1 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicPhase"] -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicWait"] -item bs 1 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm FetchWriteback"] -item b 2 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm FetchWriteback"] -item s 1 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm WritebackWriteback"] -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm WritebackWriteback2"] -item bs 1 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY4"] -item bs 1 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY6"] -item bs 1 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADYread"] -item c 1 -feccondrow 1 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm FetchWriteback"] -item c 1 -feccondrow 1,2,3,4,6 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY4"] -item c 1 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY6"] -item c 1 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "assign HTRANS"] -item c 1 -feccondrow 5 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "assign BeatCntEn"] -item e 1 -fecexprrow 4 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "assign CacheAccess"] -item e 1 -fecexprrow 4 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "assign BusStall"] -item e 1 -fecexprrow 10,12,18 -coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "assign CacheBusAck"] -item e 1 -fecexprrow 3 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicReadData"] +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicElse"] -item s 1 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicPhase"] +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicWait"] -item bs 1 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm FetchWriteback"] -item b 2 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm FetchWriteback"] -item s 1 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm WritebackWriteback"] +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm WritebackWriteback2"] -item bs 1 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY4"] -item bs 1 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY6"] -item bs 1 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADYread"] -item c 1 -feccondrow 1 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm FetchWriteback"] -item c 1 -feccondrow 1,2,3,4,6 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY4"] -item c 1 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY6"] -item c 1 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "assign HTRANS"] -item c 1 -feccondrow 5 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "assign BeatCntEn"] -item e 1 -fecexprrow 4 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "assign CacheAccess"] -item e 1 -fecexprrow 4 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "assign BusStall"] -item e 1 -fecexprrow 10,12,18 +coverage exclude -scope /dut/core/ifu/bus/icache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "assign CacheBusAck"] -item e 1 -fecexprrow 3 ## D$ Exclusions. # InvalidateCache is I$ only: -coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: dcache InvalidateCheck"] -item b 2 -coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: dcache InvalidateCheck"] -item s 1 -coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: dcache CacheEn"] -item e 1 -fecexprrow 12 -coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/cachefsm -linerange [GetLineNum ../src/cache/cachefsm.sv "exclusion-tag: cache AnyMiss"] -item e 1 -fecexprrow 4 +coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: dcache InvalidateCheck"] -item b 2 +coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: dcache InvalidateCheck"] -item s 1 +coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: dcache CacheEn"] -item e 1 -fecexprrow 12 +coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/cachefsm -linerange [GetLineNum ${SRC}/cache/cachefsm.sv "exclusion-tag: cache AnyMiss"] -item e 1 -fecexprrow 4 set numcacheways 4 for {set i 0} {$i < $numcacheways} {incr i} { - coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "exclusion-tag: dcache invalidateway"] -item bes 1 -fecexprrow 4 + coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "exclusion-tag: dcache invalidateway"] -item bes 1 -fecexprrow 4 # InvalidateCacheDelay is always 0 for D$ because it is flushed, not invalidated - coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "exclusion-tag: dcache HitWay"] -item 3 1 -fecexprrow 2 + coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "exclusion-tag: dcache HitWay"] -item 3 1 -fecexprrow 2 # FlushStage=1 will never happen when SetValidWay=1 since a pipeline stall is asserted by the cache in the fetch stage, which happens before # going into the WRITE_LINE state (and asserting SetValidWay). No TrapM can fire and since StallW is high, a stallM caused by WFIStallM would not cause a flushW. - coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "exclusion-tag: cache SetValidEN"] -item e 1 -fecexprrow 4 - coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "exclusion-tag: cache ClearValidEN"] -item e 1 -fecexprrow 4 -# Not right; other ways can get flushed and dirtied simultaneously coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/CacheWays[$i] -linerange [GetLineNum ../src/cache/cacheway.sv "exclusion-tag: cache UpdateDirty"] -item c 1 -feccondrow 6 + coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "exclusion-tag: cache SetValidEN"] -item e 1 -fecexprrow 4 + coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "exclusion-tag: cache ClearValidEN"] -item e 1 -fecexprrow 4 +# Not right; other ways can get flushed and dirtied simultaneously coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/CacheWays[$i] -linerange [GetLineNum ${SRC}/cache/cacheway.sv "exclusion-tag: cache UpdateDirty"] -item c 1 -feccondrow 6 } # D$ writeback, flush, write_line, or flush_writeback states can't be cancelled by a flush coverage exclude -scope /dut/core/lsu/bus/dcache/dcache/cachefsm -ftrans CurrState STATE_WRITEBACK->STATE_READY STATE_FLUSH->STATE_READY STATE_WRITE_LINE->STATE_READY STATE_FLUSH_WRITEBACK->STATE_READY @@ -164,16 +168,16 @@ coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker/adrdecs/ddr4dec coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker/adrdecs/sdcdec # PMA Regions 1, 2, and 3 (dtim, irom, ddr4) are never used in the rv64gc configuration, so exclude coverage -set line [GetLineNum ../src/mmu/pmachecker.sv "exclusion-tag: unused-atomic"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "exclusion-tag: unused-atomic"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2,4 coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2,4 -set line [GetLineNum ../src/mmu/pmachecker.sv "exclusion-tag: unused-tim"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "exclusion-tag: unused-tim"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2,4 coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2,4 -set line [GetLineNum ../src/mmu/pmachecker.sv "exclusion-tag: unused-cachable"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "exclusion-tag: unused-cachable"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2 coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2 -set line [GetLineNum ../src/mmu/pmachecker.sv "exclusion-tag: unused-idempotent"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "exclusion-tag: unused-idempotent"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2,4,6 coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2,4,6,8 @@ -183,7 +187,7 @@ coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker/adrdecs/uncoreramdec coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker/adrdecs/spidec # The following peripherals are always supported -set line [GetLineNum ../src/mmu/adrdec.sv "exclusion-tag: adrdecSel"] +set line [GetLineNum ${SRC}/mmu/adrdec.sv "exclusion-tag: adrdecSel"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/bootromdec -linerange $line-$line -item e 1 -fecexprrow 3,7 coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/gpiodec -linerange $line-$line -item e 1 -fecexprrow 3 coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/uartdec -linerange $line-$line -item e 1 -fecexprrow 3 @@ -191,104 +195,104 @@ coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/plicdec -line coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/spidec -linerange $line-$line -item e 1 -fecexprrow 3 #Excluding signals in lsu: clintdec and uncoreram accept all sizes so 'SizeValid' will never be 0 -set line [GetLineNum ../src/mmu/adrdec.sv "& SizeValid"] +set line [GetLineNum ${SRC}/mmu/adrdec.sv "& SizeValid"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/clintdec -linerange $line-$line -item e 1 -fecexprrow 5 -set line [GetLineNum ../src/mmu/adrdec.sv "& SizeValid"] +set line [GetLineNum ${SRC}/mmu/adrdec.sv "& SizeValid"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/uncoreramdec -linerange $line-$line -item e 1 -fecexprrow 5 -# set line [GetLineNum ../src/mmu/adrdec.sv "& Supported"] +# set line [GetLineNum ${SRC}/mmu/adrdec.sv "& Supported"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/dtimdec coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/iromdec coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/ddr4dec coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker/adrdecs/sdcdec # No DTIM or IROM -coverage exclude -scope /dut/core/ifu/bus/icache/UnCachedDataMux -linerange [GetLineNum ../src/generic/mux.sv "exclusion-tag: mux3"] -item b 1 -coverage exclude -scope /dut/core/lsu/bus/dcache/UnCachedDataMux -linerange [GetLineNum ../src/generic/mux.sv "exclusion-tag: mux3"] -item b 1 +coverage exclude -scope /dut/core/ifu/bus/icache/UnCachedDataMux -linerange [GetLineNum ${SRC}/generic/mux.sv "exclusion-tag: mux3"] -item b 1 +coverage exclude -scope /dut/core/lsu/bus/dcache/UnCachedDataMux -linerange [GetLineNum ${SRC}/generic/mux.sv "exclusion-tag: mux3"] -item b 1 #################### # Unused access types due to sharing IFU and LSU logic #################### ## The lsu never executes instructions so 'ExecuteAccessF' will never be 1 -set line [GetLineNum ../src/mmu/pmachecker.sv "AccessRWXC ="] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "AccessRWXC ="] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 6 -set line [GetLineNum ../src/mmu/pmachecker.sv "ReadAccessM \\| ExecuteAccessF"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "ReadAccessM \\| ExecuteAccessF"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 4 -set line [GetLineNum ../src/mmu/pmachecker.sv "ExecuteAccessF & PMAAccessFault"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "ExecuteAccessF & PMAAccessFault"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2 -set line [GetLineNum ../src/mmu/mmu.sv "ExecuteAccessF \\| ReadAccessM"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "ExecuteAccessF \\| ReadAccessM"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu -linerange $line-$line -item e 1 -fecexprrow 2 -set line [GetLineNum ../src/mmu/mmu.sv "TLBPageFault & ExecuteAccessF"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "TLBPageFault & ExecuteAccessF"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu -linerange $line-$line -item e 1 -fecexprrow 1,2,4 -set line [GetLineNum ../src/mmu/mmu.sv "PMAInstrAccessFaultF \\|"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "PMAInstrAccessFaultF \\|"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu -linerange $line-$line -item e 1 -fecexprrow 2,4,5,6 -set line [GetLineNum ../src/mmu/pmpchecker.sv "EnforcePMP & ExecuteAccessF"] +set line [GetLineNum ${SRC}/mmu/pmpchecker.sv "EnforcePMP & ExecuteAccessF"] coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmp/pmpchecker -linerange $line-$line -item e 1 -fecexprrow 1,2,4,5,6 -set line [GetLineNum ../src/mmu/pmpchecker.sv "EnforcePMP & ExecuteAccessF"] +set line [GetLineNum ${SRC}/mmu/pmpchecker.sv "EnforcePMP & ExecuteAccessF"] coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker -linerange $line-$line -item e 1 -fecexprrow 3 ## The IFU has ReadAccess = WriteAccess = 0 and ExecuteAccess = 1 hardwired, so exclude alternatives -set line [GetLineNum ../src/mmu/pmachecker.sv "ReadAccessM \\| WriteAccessM"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "ReadAccessM \\| WriteAccessM"] coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2 4 -set line [GetLineNum ../src/mmu/pmachecker.sv "WriteAccessM \\| ExecuteAccessF"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "WriteAccessM \\| ExecuteAccessF"] coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 1-5 -set line [GetLineNum ../src/mmu/pmachecker.sv "ReadAccessM \\| ExecuteAccessF"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "ReadAccessM \\| ExecuteAccessF"] coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 1-3 -set line [GetLineNum ../src/mmu/pmachecker.sv "ExecuteAccessF & PMAAccessFault"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "ExecuteAccessF & PMAAccessFault"] coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 1 -set line [GetLineNum ../src/mmu/pmachecker.sv "ReadAccessM & PMAAccessFault"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "ReadAccessM & PMAAccessFault"] coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 2-4 -set line [GetLineNum ../src/mmu/pmachecker.sv "PMAStoreAmoAccessFaultM ="] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "PMAStoreAmoAccessFaultM ="] coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -set line [GetLineNum ../src/mmu/pmachecker.sv "AccessRWXC \\| AtomicAccessM"] +set line [GetLineNum ${SRC}/mmu/pmachecker.sv "AccessRWXC \\| AtomicAccessM"] coverage exclude -scope /dut/core/ifu/immu/immu/pmachecker -linerange $line-$line -item e 1 -fecexprrow 3 -set line [GetLineNum ../src/mmu/mmu.sv "ExecuteAccessF \\| ReadAccessM"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "ExecuteAccessF \\| ReadAccessM"] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -fecexprrow 1,3,4 -set line [GetLineNum ../src/mmu/mmu.sv "ReadAccessM & ~WriteAccessM"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "ReadAccessM & ~WriteAccessM"] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -fecexprrow 2-4 -set line [GetLineNum ../src/mmu/mmu.sv "assign AmoAccessM"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "assign AmoAccessM"] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -set line [GetLineNum ../src/mmu/mmu.sv "assign AmoMisalignedCausesAccessFaultM"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "assign AmoMisalignedCausesAccessFaultM"] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -set line [GetLineNum ../src/mmu/mmu.sv "DataMisalignedM & WriteAccessM"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "DataMisalignedM & WriteAccessM"] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -fecexprrow 1,2,4 -set line [GetLineNum ../src/mmu/mmu.sv "TLBPageFault & ExecuteAccessF"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "TLBPageFault & ExecuteAccessF"] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -fecexprrow 3 -set line [GetLineNum ../src/mmu/mmu.sv "TLBPageFault & ReadNoAmoAccessM"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "TLBPageFault & ReadNoAmoAccessM"] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -fecexprrow 1,2,4 -set line [GetLineNum ../src/mmu/mmu.sv "StoreAmoPageFaultM \="] +set line [GetLineNum ${SRC}/mmu/mmu.sv "StoreAmoPageFaultM \="] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -fecexprrow 1,2,4 -set line [GetLineNum ../src/mmu/mmu.sv "DataMisalignedM & ReadNoAmoAccessM"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "DataMisalignedM & ReadNoAmoAccessM"] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -fecexprrow 1,2,4 -set line [GetLineNum ../src/mmu/pmpchecker.sv "EnforcePMP & WriteAccessM"] +set line [GetLineNum ${SRC}/mmu/pmpchecker.sv "EnforcePMP & WriteAccessM"] coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker -linerange $line-$line -item e 1 -fecexprrow 1,2,4,5,6 -set line [GetLineNum ../src/mmu/pmpchecker.sv "EnforcePMP & ReadAccessM"] +set line [GetLineNum ${SRC}/mmu/pmpchecker.sv "EnforcePMP & ReadAccessM"] coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker -linerange $line-$line -item e 1 -fecexprrow 1,2,4,5,6 -set line [GetLineNum ../src/mmu/mmu.sv "LoadAccessFaultM \="] +set line [GetLineNum ${SRC}/mmu/mmu.sv "LoadAccessFaultM \="] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -fecexprrow 2,4,5,6 -set line [GetLineNum ../src/mmu/mmu.sv "StoreAmoAccessFaultM \="] +set line [GetLineNum ${SRC}/mmu/mmu.sv "StoreAmoAccessFaultM \="] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line -item e 1 -fecexprrow 2,4,5,6 -set line [GetLineNum ../src/mmu/tlb/tlbcontrol.sv "ReadAccess \\| WriteAccess"] +set line [GetLineNum ${SRC}/mmu/tlb/tlbcontrol.sv "ReadAccess \\| WriteAccess"] coverage exclude -scope /dut/core/ifu/immu/immu/tlb/tlb/tlbcontrol -linerange $line-$line -item e 1 -fecexprrow 1,3,4 -set line [GetLineNum ../src/mmu/tlb/tlbcontrol.sv "CAMHit & TLBAccess"] +set line [GetLineNum ${SRC}/mmu/tlb/tlbcontrol.sv "CAMHit & TLBAccess"] coverage exclude -scope /dut/core/ifu/immu/immu/tlb/tlb/tlbcontrol -linerange $line-$line -item e 1 -fecexprrow 3 -set line [GetLineNum ../src/mmu/tlb/tlbcontrol.sv "~CAMHit & TLBAccess"] +set line [GetLineNum ${SRC}/mmu/tlb/tlbcontrol.sv "~CAMHit & TLBAccess"] coverage exclude -scope /dut/core/ifu/immu/immu/tlb/tlb/tlbcontrol -linerange $line-$line -item e 1 -fecexprrow 3 # IMMU only makes word-sized accesses -set line [GetLineNum ../src/mmu/mmu.sv "exclusion-tag: immu-wordaccess"] +set line [GetLineNum ${SRC}/mmu/mmu.sv "exclusion-tag: immu-wordaccess"] set line2 [expr $line + 6 ] coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line2 -item e 1 -fecexprrow 4 coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line2 -item b 1 coverage exclude -scope /dut/core/ifu/immu/immu -linerange $line-$line2 -item s 1 # IMMU never disables translations -coverage exclude -scope /dut/core/ifu/ifu/immu/immu/tlb/tlb/tlbcontrol -linerange [GetLineNum ../src/mmu/tlb/tlbcontrol.sv "assign Translate"] -item e 1 -fecexprrow 2 -coverage exclude -scope /dut/core/ifu/ifu/immu/immu/tlb/tlb/tlbcontrol -linerange [GetLineNum ../src/mmu/tlb/tlbcontrol.sv "assign UpdateDA"] -item e 1 -fecexprrow 5 +coverage exclude -scope /dut/core/ifu/ifu/immu/immu/tlb/tlb/tlbcontrol -linerange [GetLineNum ${SRC}/mmu/tlb/tlbcontrol.sv "assign Translate"] -item e 1 -fecexprrow 2 +coverage exclude -scope /dut/core/ifu/ifu/immu/immu/tlb/tlb/tlbcontrol -linerange [GetLineNum ${SRC}/mmu/tlb/tlbcontrol.sv "assign UpdateDA"] -item e 1 -fecexprrow 5 # never reaches this when ENVCFG_ADUE_1 because HPTW updates A bit first -coverage exclude -scope /dut/core/ifu/ifu/immu/immu/tlb/tlb/tlbcontrol -linerange [GetLineNum ../src/mmu/tlb/tlbcontrol.sv "assign PrePageFault"] -item e 1 -fecexprrow 18 +coverage exclude -scope /dut/core/ifu/ifu/immu/immu/tlb/tlb/tlbcontrol -linerange [GetLineNum ${SRC}/mmu/tlb/tlbcontrol.sv "assign PrePageFault"] -item e 1 -fecexprrow 18 @@ -298,19 +302,19 @@ coverage exclude -scope /dut/core/ifu/ifu/immu/immu/tlb/tlb/tlbcontrol -linerang ############### # RV64GC HPTW never starts at L1_ADR -set line [GetLineNum ../src/mmu/hptw.sv "InitialWalkerState == L1_ADR"] +set line [GetLineNum ${SRC}/mmu/hptw.sv "InitialWalkerState == L1_ADR"] coverage exclude -scope /dut/core/lsu/lsu/hptw/hptw -linerange $line-$line -item c 1 -feccondrow 2 # Never possible to get a page fault when neither reading nor writing -set line [GetLineNum ../src/mmu/hptw.sv "assign HPTWLoadPageFault"] +set line [GetLineNum ${SRC}/mmu/hptw.sv "assign HPTWLoadPageFault"] coverage exclude -scope /dut/core/lsu/lsu/hptw/hptw -linerange $line-$line -item e 1 -fecexprrow 7 # Never possible to get a store page fault from an ITLB walk -set line [GetLineNum ../src/mmu/hptw.sv "assign HPTWStoreAmoPageFault"] +set line [GetLineNum ${SRC}/mmu/hptw.sv "assign HPTWStoreAmoPageFault"] coverage exclude -scope /dut/core/lsu/lsu/hptw/hptw -linerange $line-$line -item e 1 -fecexprrow 3 # Never possible to get Access = 0 on a nonleaf PTE with no OtherPageFault (because InvalidRead/Write will be 1 on the nonleaf) -set line [GetLineNum ../src/mmu/hptw.sv "assign HPTWUpdateDA"] +set line [GetLineNum ${SRC}/mmu/hptw.sv "assign HPTWUpdateDA"] coverage exclude -scope /dut/core/lsu/lsu/hptw/hptw -linerange $line-$line -item e 1 -fecexprrow 3 ############### @@ -318,78 +322,78 @@ coverage exclude -scope /dut/core/lsu/lsu/hptw/hptw -linerange $line-$line -item ############### # IMMU PMP does not support CBO instructions -coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker -linerange [GetLineNum ../src/mmu/pmpchecker.sv "exclusion-tag: immu-pmpcbom"] -coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker -linerange [GetLineNum ../src/mmu/pmpchecker.sv "exclusion-tag: immu-pmpcboz"] -coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker -linerange [GetLineNum ../src/mmu/pmpchecker.sv "exclusion-tag: immu-pmpcboaccess"] +coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker -linerange [GetLineNum ${SRC}/mmu/pmpchecker.sv "exclusion-tag: immu-pmpcbom"] +coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker -linerange [GetLineNum ${SRC}/mmu/pmpchecker.sv "exclusion-tag: immu-pmpcboz"] +coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker -linerange [GetLineNum ${SRC}/mmu/pmpchecker.sv "exclusion-tag: immu-pmpcboaccess"] # No irom -set line [GetLineNum ../src/ifu/ifu.sv "~ITLBMissF & ~CacheableF & ~SelIROM"] +set line [GetLineNum ${SRC}/ifu/ifu.sv "~ITLBMissF & ~CacheableF & ~SelIROM"] coverage exclude -scope /dut/core/ifu -linerange $line-$line -item c 1 -feccondrow 6 -set line [GetLineNum ../src/ifu/ifu.sv "~ITLBMissF & CacheableF & ~SelIROM"] +set line [GetLineNum ${SRC}/ifu/ifu.sv "~ITLBMissF & CacheableF & ~SelIROM"] coverage exclude -scope /dut/core/ifu -linerange $line-$line -item c 1 -feccondrow 4 # no DTIM -set line [GetLineNum ../src/lsu/lsu.sv "assign BusRW"] +set line [GetLineNum ${SRC}/lsu/lsu.sv "assign BusRW"] coverage exclude -scope /dut/core/lsu -linerange $line-$line -item c 1 -feccondrow 4 -set line [GetLineNum ../src/lsu/lsu.sv "assign CacheRWM"] +set line [GetLineNum ${SRC}/lsu/lsu.sv "assign CacheRWM"] coverage exclude -scope /dut/core/lsu -linerange $line-$line -item c 1 -feccondrow 4 # Excluding reset and clear for impossible case in the wficountreg in privdec -set line [GetLineNum ../src/generic/flop/floprc.sv "reset \\| clear"] -coverage exclude -scope /dut/core/priv/priv/pmd/wfi/wficountreg -linerange $line-$line -item c 1 -feccondrow 2 +#set line [GetLineNum ${SRC}/generic/flop/floprc.sv "reset \\| clear"] +#coverage exclude -scope /dut/core/priv/priv/pmd/wfi/wficountreg -linerange $line-$line -item c 1 -feccondrow 2 # Exclude system reset case in ebu -set line [GetLineNum ../src/ebu/ebufsmarb.sv "BeatCounter\\("] +set line [GetLineNum ${SRC}/ebu/ebufsmarb.sv "BeatCounter\\("] coverage exclude -scope /dut/core/ebu/ebu/ebufsmarb -linerange $line-$line -item e 1 -fecexprrow 1 -set line [GetLineNum ../src/ebu/ebufsmarb.sv "FinalBeatReg\\("] +set line [GetLineNum ${SRC}/ebu/ebufsmarb.sv "FinalBeatReg\\("] coverage exclude -scope /dut/core/ebu/ebu/ebufsmarb -linerange $line-$line -item e 1 -fecexprrow 1 -set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicElse"] +set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicElse"] coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item bc 1 -set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicWait"] +set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicWait"] coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item bc 1 # The WritebackWriteback and FetchWriteback support back to back pipelined cache writebacks and fetch then # writebacks. The cache never issues these type of requests. -set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm WritebackWriteback"] +set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm WritebackWriteback"] coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item bc 2 -set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm FetchWriteback"] +set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm FetchWriteback"] coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item bc 2 # FetchWait never occurs because HREADY is never 0. -set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm FetchWait"] +set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm FetchWait"] coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item bc 1 # all of these HREADY exclusions occur because HREADY is always 1. The ram_ahb module never stalls. -set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY0"] +set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY0"] coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item c 1 -feccondrow 1 -#set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY1"] +#set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY1"] #coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item c 1 -feccondrow 1 -#set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY2"] +#set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY2"] #coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item c 1 -feccondrow 1 -set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY3"] +set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY3"] coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item c 1 -feccondrow 4 -set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY4"] +set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY4"] coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item c 1 -feccondrow 1 coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item c 1 -feccondrow 3 -set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY5"] +set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY5"] coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item c 1 -feccondrow 1 -set line [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY6"] +set line [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm HREADY6"] coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item c 1 -feccondrow 1 coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange $line-$line -item c 1 -feccondrow 5 -coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "assign CacheBusAck"] -item e 1 -fecexprrow 5 +coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "assign CacheBusAck"] -item e 1 -fecexprrow 5 -coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicElse"] -item s 1 -coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ../src/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicWait"] -item s 1 +coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicElse"] -item s 1 +coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -linerange [GetLineNum ${SRC}/ebu/buscachefsm.sv "exclusion-tag: buscachefsm AtomicWait"] -item s 1 # these transitions will not happen coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefsm -ftrans CurrState DATA_PHASE->ADR_PHASE ATOMIC_READ_DATA_PHASE->ADR_PHASE ATOMIC_PHASE->ADR_PHASE @@ -399,15 +403,15 @@ coverage exclude -scope /dut/core/lsu/bus/dcache/ahbcacheinterface/AHBBuscachefs coverage exclude -srcfile priorityonehot.sv # Excluding pmpadrdecs[0] coverage case for PAgePMPAdrIn being hardwired to 1 -coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker/pmp/pmpadrdecs[0] -linerange [GetLineNum ../src/mmu/pmpadrdec.sv "exclusion-tag: PAgePMPAdrIn"] -item e 1 -fecexprrow 1 -coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmp/pmpchecker/pmp/pmpadrdecs[0] -linerange [GetLineNum ../src/mmu/pmpadrdec.sv "exclusion-tag: PAgePMPAdrIn"] -item e 1 -fecexprrow 1 +coverage exclude -scope /dut/core/ifu/immu/immu/pmp/pmpchecker/pmp/pmpadrdecs[0] -linerange [GetLineNum ${SRC}/mmu/pmpadrdec.sv "exclusion-tag: PAgePMPAdrIn"] -item e 1 -fecexprrow 1 +coverage exclude -scope /dut/core/lsu/dmmu/dmmu/pmp/pmpchecker/pmp/pmpadrdecs[0] -linerange [GetLineNum ${SRC}/mmu/pmpadrdec.sv "exclusion-tag: PAgePMPAdrIn"] -item e 1 -fecexprrow 1 #################### # Privileged #################### # Instruction Misaligned never asserted because compresssed instructions are accepted -coverage exclude -scope /dut/core/priv/priv/trap -linerange [GetLineNum ../src/privileged/trap.sv "assign ExceptionM"] -item e 1 -fecexprrow 2 +coverage exclude -scope /dut/core/priv/priv/trap -linerange [GetLineNum ${SRC}/privileged/trap.sv "assign ExceptionM"] -item e 1 -fecexprrow 2 #################### # EBU diff --git a/sim/questa/sim-wally-batch b/sim/questa/sim-wally-batch index 38caa95f3..58497efe9 100755 --- a/sim/questa/sim-wally-batch +++ b/sim/questa/sim-wally-batch @@ -1 +1 @@ -vsim -c -do "do wally-batch.do rv64gc wally64periph" +../wsim rv64gc arch64i diff --git a/sim/questa/wally-batch.do b/sim/questa/wally-batch.do index f1489b7cb..5a69c906d 100644 --- a/sim/questa/wally-batch.do +++ b/sim/questa/wally-batch.do @@ -87,7 +87,7 @@ run -all if {$coverage} { - set UCDB cov/${CONFIG}_${TESTSUITE}.ucdb + set UCDB cov/${CFG}_${TESTSUITE}.ucdb echo "Saving coverage to ${UCDB}" do coverage-exclusions-rv64gc.do # beware: this assumes testing the rv64gc configuration coverage save -instance /testbench/dut/core ${UCDB} diff --git a/sim/regression-wally b/sim/regression-wally index f58c8bdfe..b8d15632e 100755 --- a/sim/regression-wally +++ b/sim/regression-wally @@ -12,161 +12,45 @@ ################################## import sys,os,shutil import multiprocessing - - - -class bcolors: - HEADER = '\033[95m' - OKBLUE = '\033[94m' - OKCYAN = '\033[96m' - OKGREEN = '\033[92m' - WARNING = '\033[93m' - FAIL = '\033[91m' - ENDC = '\033[0m' - BOLD = '\033[1m' - UNDERLINE = '\033[4m' - +#import os from collections import namedtuple -regressionDir = os.path.dirname(os.path.abspath(__file__)) -os.chdir(regressionDir) +from multiprocessing import Pool, TimeoutError -coverage = '-coverage' in sys.argv -fp = '-fp' in sys.argv -nightly = '-nightly' in sys.argv -softfloat = '-softfloat' in sys.argv +################################## +# Define lists of configurations and tests to run on each configuration +################################## -TestCase = namedtuple("TestCase", ['name', 'variant', 'cmd', 'grepstr']) -# name: the name of this test configuration (used in printing human-readable -# output and picking logfile names) -# cmd: the command to run to test (should include the logfile as '{}', and -# the command needs to write to that file) -# grepstr: the string to grep through the log file for. The test succeeds iff -# grep finds that string in the logfile (is used by grep, so it may -# be any pattern grep accepts, see `man 1 grep` for more info). +tests = [ + ["rv32e", ["arch32e"]], + ["rv32i", ["arch32i"]], + ["rv32imc", ["arch32i", "arch32c", "arch32m", "wally32periph"]], + ["rv32gc", ["arch32f", "arch32d", "arch32f_fma", "arch32d_fma", "arch32f_divsqrt", "arch32d_divsqrt", + "arch32i", "arch32priv", "arch32c", "arch32m", "arch32a", "arch32zifencei", "arch32zicond", + "arch32zba", "arch32zbb", "arch32zbc", "arch32zbs", "arch32zfh", "arch32zfh_fma", + "arch32zfh_divsqrt", "arch32zfaf", "wally32a", "wally32priv", "wally32periph", + "arch32zbkb", "arch32zbkc", "arch32zbkx", "arch32zknd", "arch32zkne", "arch32zknh"]], # "arch32zcb", "arch32zfad", + ["rv64e", ["arch64e"]], + ["rv64i", ["arch64i"]], + ["rv64imc", ["arch64i", "arch64c", "arch64m", "wally64periph"]], + ] -# edit this list to add more test cases -if (nightly): - nightMode = "-nightly"; - configs = [] -else: - nightMode = ""; - configs = [ - TestCase( - name="lints", - variant="all", - cmd="./lint-wally " + nightMode + " | tee {}", - grepstr="lints run with no errors or warnings" - ) +# Separate out floating-point tests for RV64 to speed up coverage +tests64gc_nofp = [ + ["rv64gc", ["coverage64gc", "arch64i", "arch64priv", "arch64c", "arch64m", + "arch64zifencei", "arch64zicond", "arch64a", "wally64a", "wally64periph", "wally64priv", + "arch64zbkb", "arch64zbkc", "arch64zbkx", "arch64zknd", "arch64zkne", "arch64zknh", + "arch64zba", "arch64zbb", "arch64zbc", "arch64zbs"]] # add when working: "arch64zcb", "arch64zicboz" ] -def getBuildrootTC(boot): - INSTR_LIMIT = 1000000 # multiple of 100000; 4M is interesting because it gets into the kernel and enabling VM - MAX_EXPECTED = 246000000 # *** TODO: replace this with a search for the login prompt. - if boot: - name="buildrootboot" - BRcmd="vsim > {} -c < {} -c < {} -c < {} -c < {} -c < {} -c < {} -c < {} -c < {} -c < XLEN +# RV32 cacheless designs will not work unless DTIM supports FLEN > XLEN. This support is not planned. # ["nodcache_rv32gc", ["ahb32"]], # ["nocache_rv32gc", ["ahb32"]], + ["noicache_rv32gc", ["ahb32"]], ["noicache_rv64gc", ["ahb64"]], ["nodcache_rv64gc", ["ahb64"]], ["nocache_rv64gc", ["ahb64"]], ### add misaligned tests + # fp/int divider permutations ["div_2_1_rv32gc", ["arch32f_divsqrt", "arch32d_divsqrt", "arch32m"]], ["div_2_1i_rv32gc", ["arch32f_divsqrt", "arch32d_divsqrt", "arch32m"]], ["div_2_2_rv32gc", ["arch32f_divsqrt", "arch32d_divsqrt", "arch32m"]], @@ -224,69 +107,108 @@ if (nightly): ["div_4_4_rv64gc", ["arch64f_divsqrt", "arch64d_divsqrt", "arch64m"]], ["div_4_4i_rv64gc", ["arch64f_divsqrt", "arch64d_divsqrt", "arch64m"]], - ### branch predictor simulation - - # ["bpred_TWOBIT_6_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_8_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_10_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_12_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_14_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_16_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_6_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_8_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_10_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_12_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_14_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_TWOBIT_16_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - - # ["bpred_GSHARE_6_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_6_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_8_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_8_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_12_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_12_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_14_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_14_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_16_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_16_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - - # # btb - # ["bpred_GSHARE_10_16_6_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_16_6_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_16_8_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_16_8_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_16_12_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_16_12_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - - # # ras - # ["bpred_GSHARE_10_2_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_2_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_3_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_3_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_4_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_4_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_6_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_6_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_10_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - # ["bpred_GSHARE_10_10_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - -# enable floating-point tests when lint is fixed + # fpu permutations ["f_rv32gc", ["arch32f", "arch32f_divsqrt", "arch32f_fma"]], ["fh_rv32gc", ["arch32f", "arch32f_divsqrt", "arch32f_fma", "arch32zfh", "arch32zfh_divsqrt"]], ["fdh_rv32gc", ["arch32f", "arch32f_divsqrt", "arch32f_fma", "arch32d", "arch32d_divsqrt", "arch32d_fma", "arch32zfh", "arch32zfh_divsqrt"]], ["fdq_rv32gc", ["arch32f", "arch32f_divsqrt", "arch32f_fma", "arch32d", "arch32d_divsqrt", "arch32d_fma", "arch32i"]], ["fdqh_rv32gc", ["arch32f", "arch32f_divsqrt", "arch32f_fma", "arch32d", "arch32d_divsqrt", "arch32d_fma", "arch32zfh", "arch32zfh_divsqrt", "arch32i"]], ["f_rv64gc", ["arch64f", "arch64f_divsqrt", "arch64f_fma"]], - ["fh_rv64gc", ["arch64f", "arch64f_divsqrt", "arch64f_fma", "arch64zfh", "arch64zfh_divsqrt"]], # hanging 1/31/24 dh; try again when lint is fixed + ["fh_rv64gc", ["arch64f", "arch64f_divsqrt", "arch64f_fma", "arch64zfh", "arch64zfh_divsqrt"]], ["fdh_rv64gc", ["arch64f", "arch64f_divsqrt", "arch64f_fma", "arch64d", "arch64d_divsqrt", "arch64d_fma", "arch64zfh", "arch64zfh_divsqrt"]], ["fdq_rv64gc", ["arch64f", "arch64f_divsqrt", "arch64f_fma", "arch64d", "arch64d_divsqrt", "arch64d_fma", "arch64i"]], ["fdqh_rv64gc", ["arch64f", "arch64f_divsqrt", "arch64f_fma", "arch64d", "arch64d_divsqrt", "arch64d_fma", "arch64zfh", "arch64zfh_divsqrt", "arch64i", "wally64q"]], - - ] - for test in derivconfigtests: + +bpredtests = [ + ["bpred_TWOBIT_6_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_8_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_10_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_12_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_14_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_16_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_6_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_8_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_10_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_12_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_14_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_16_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + + ["bpred_GSHARE_6_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_6_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_8_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_8_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_12_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_12_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_14_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_14_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_16_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_16_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + + # btb + ["bpred_GSHARE_10_16_6_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_6_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_8_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_8_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_12_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_12_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + + # ras + ["bpred_GSHARE_10_2_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_2_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_3_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_3_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_4_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_4_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_6_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_6_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_10_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_10_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"] +] + +TestCase = namedtuple("TestCase", ['name', 'variant', 'cmd', 'grepstr']) +# name: the name of this test configuration (used in printing human-readable +# output and picking logfile names) +# cmd: the command to run to test (should include the logfile as '{}', and +# the command needs to write to that file) +# grepstr: the string to grep through the log file for. The test succeeds iff +# grep finds that string in the logfile (is used by grep, so it may +# be any pattern grep accepts, see `man 1 grep` for more info). + +class bcolors: + HEADER = '\033[95m' + OKBLUE = '\033[94m' + OKCYAN = '\033[96m' + OKGREEN = '\033[92m' + WARNING = '\033[93m' + FAIL = '\033[91m' + ENDC = '\033[0m' + BOLD = '\033[1m' + UNDERLINE = '\033[4m' + +def getBuildrootTC(boot): + INSTR_LIMIT = 1000000 # multiple of 100000; 4M is interesting because it gets into the kernel and enabling VM + MAX_EXPECTED = 246000000 # *** TODO: replace this with a search for the login prompt. + if boot: + name="buildrootboot" + BRcmd="vsim > {} -c < {} -c < {} -c <= 4 and test[2] == "configOptions"): @@ -294,22 +216,89 @@ if (nightly): cmdPrefix = "vsim > {} -c < {} -c < {} -c < /dev/null" % (text, logfile) + return os.system(grepcmd) == 0 + +def run_test_case(config): + """Run the given test case, and return 0 if the test suceeds and 1 if it fails""" + logname = "questa/logs/"+config.variant+"_"+config.name+".log" +# cmd = config.cmd.format(logname) + cmd = config.cmd + " > " + logname + print(cmd) + os.chdir(regressionDir) + os.system(cmd) + if search_log_for_text(config.grepstr, logname): + print(f"{bcolors.OKGREEN}%s_%s: Success{bcolors.ENDC}" % (config.variant, config.name)) + return 0 + else: + print(f"{bcolors.FAIL}%s_%s: Failures detected in output{bcolors.ENDC}" % (config.variant, config.name)) + print(" Check %s" % logname) + return 1 + +regressionDir = os.path.dirname(os.path.abspath(__file__)) +os.chdir(regressionDir) + +coveragesim = "questa" # Questa is required for code/functional coverage +defaultsim = "questa" # Default simulator for all other tests; change to Verilator when flow is ready + +coverage = '-coverage' in sys.argv +fp = '-fp' in sys.argv +nightly = '-nightly' in sys.argv +testfloat = '-testfloat' in sys.argv + +if (nightly): + nightMode = "-nightly"; + sims = ["questa", "verilator", "vcs"] +else: + nightMode = ""; + sims = [defaultsim] + +if (coverage): # only run RV64GC tests in coverage mode + coverStr = '-coverage' +else: + coverStr = '' +# Run Lint +configs = [ + TestCase( + name="lints", + variant="all", + cmd="./lint-wally " + nightMode + " | tee {}", + grepstr="lints run with no errors or warnings" + ) + ] -# softfloat tests -if (softfloat): +if (coverage): # only run RV64GC tests on Questa in coverage mode + addTests(tests64gc_nofp, "questa") + if (fp): + addTests(tests64gc_fp, "questa") +else: + for sim in sims: + addTests(tests, sim) + addTests(tests64gc_nofp, sim) + addTests(tests64gc_fp, sim) + # run derivative configurations in nightly regression + if (nightly): + addTests(derivconfigtests, defaultsim) + +# testfloat tests +if (testfloat): configs = [] - softfloatconfigs = [ + testfloatconfigs = [ "fdh_ieee_div_2_1_rv32gc", "fdh_ieee_div_2_1_rv64gc", "fdh_ieee_div_2_2_rv32gc", "fdh_ieee_div_2_2_rv64gc", "fdh_ieee_div_2_4_rv32gc", "fdh_ieee_div_2_4_rv64gc", "fdh_ieee_div_4_1_rv32gc", "fdh_ieee_div_4_1_rv64gc", "fdh_ieee_div_4_2_rv32gc", @@ -335,7 +324,7 @@ if (softfloat): "f_ieee_div_4_1_rv32gc", "f_ieee_div_4_1_rv64gc", "f_ieee_div_4_2_rv32gc", "f_ieee_div_4_2_rv64gc", "f_ieee_div_4_4_rv32gc", "f_ieee_div_4_4_rv64gc" ] - for config in softfloatconfigs: + for config in testfloatconfigs: # div test case divtest = TestCase( name="div", @@ -378,45 +367,16 @@ if (softfloat): configs.append(cvtfptest) - - -import os -from multiprocessing import Pool, TimeoutError - -def search_log_for_text(text, logfile): - """Search through the given log file for text, returning True if it is found or False if it is not""" - grepcmd = "grep -e '%s' '%s' > /dev/null" % (text, logfile) - return os.system(grepcmd) == 0 - -def run_test_case(config): - """Run the given test case, and return 0 if the test suceeds and 1 if it fails""" - logname = "logs/"+config.variant+"_"+config.name+".log" - cmd = config.cmd.format(logname) -# print(cmd) - os.chdir(regressionDir) - os.system(cmd) - if search_log_for_text(config.grepstr, logname): - print(f"{bcolors.OKGREEN}%s_%s: Success{bcolors.ENDC}" % (config.variant, config.name)) - return 0 - else: - print(f"{bcolors.FAIL}%s_%s: Failures detected in output{bcolors.ENDC}" % (config.variant, config.name)) - print(" Check %s" % logname) - return 1 def main(): """Run the tests and count the failures""" global configs, coverage - try: - os.chdir(regressionDir) - os.mkdir("logs") - except: - pass - try: - shutil.rmtree("wkdir") - except: - pass - finally: - os.mkdir("wkdir") + os.chdir(regressionDir) + for d in ["questa/logs", "questa/wkdir", "verilator/logs", "verilator/wkdir", "vcs/logs", "vcs/wkdir"]: + try: + os.mkdir(d) + except: + pass if '-makeTests' in sys.argv: os.chdir(regressionDir) @@ -437,7 +397,7 @@ def main(): elif '-nightly' in sys.argv: TIMEOUT_DUR = 60*1440 # 1 day configs.append(getBuildrootTC(boot=False)) - elif '-softfloat' in sys.argv: + elif '-testfloat' in sys.argv: TIMEOUT_DUR = 60*60 # seconds else: TIMEOUT_DUR = 10*60 # seconds diff --git a/sim/wsim b/sim/wsim index 723fb644b..c11ee51f3 100755 --- a/sim/wsim +++ b/sim/wsim @@ -19,12 +19,15 @@ parser.add_argument("config", help="Configuration file") parser.add_argument("testsuite", help="Test suite or ELF file") parser.add_argument("--sim", "-s", help="Simulator", choices=["questa", "verilator", "vcs"], default="questa") parser.add_argument("--gui", "-g", help="Simulate with GUI", action="store_true") +parser.add_argument("--coverage", "-c", help="Code & Functional Coverage", action="store_true") args = parser.parse_args() print("Config: " + args.config + " tests " + args.testsuite + " sim " + args.sim + " gui " + str(args.gui)) if (args.sim == "questa"): cmd = "do wally-batch.do " + args.config + " " + args.testsuite - os.system("cd questa; vsim -c -do \"" + cmd + "\"") + if (args.coverage): + cmd += " -coverage" + os.system("cd $WALLY/sim/questa; vsim -c -do \"" + cmd + "\"") elif (args.sim == "verilator"): print("Running Verilator") elif (args.sim == "vcs"): From 4b19f6d5421c1c058af8e0f358d730c03eb69770 Mon Sep 17 00:00:00 2001 From: David Harris Date: Sat, 6 Apr 2024 08:22:39 -0700 Subject: [PATCH 05/13] testfloat running through wsim; moved lint, regression, wsim to bin directory so we don't need ./ --- {sim => bin}/lint-wally | 0 {sim => bin}/regression-wally | 8 +++ {sim => bin}/wsim | 28 ++++++--- sim/questa/testfloat-batch.do | 2 +- sim/questa/testfloat.do | 4 +- sim/questa/wally-batch.do | 16 ++--- sim/questa/wave-fpu.do | 58 +++++++++---------- .../{testbench-fp.sv => testbench_fp.sv} | 24 ++++---- testbench/{tests-fp.vh => tests_fp.vh} | 4 +- 9 files changed, 84 insertions(+), 60 deletions(-) rename {sim => bin}/lint-wally (100%) rename {sim => bin}/regression-wally (99%) rename {sim => bin}/wsim (63%) rename testbench/{testbench-fp.sv => testbench_fp.sv} (99%) rename testbench/{tests-fp.vh => tests_fp.vh} (99%) diff --git a/sim/lint-wally b/bin/lint-wally similarity index 100% rename from sim/lint-wally rename to bin/lint-wally diff --git a/sim/regression-wally b/bin/regression-wally similarity index 99% rename from sim/regression-wally rename to bin/regression-wally index b8d15632e..8819518e6 100755 --- a/sim/regression-wally +++ b/bin/regression-wally @@ -168,6 +168,10 @@ bpredtests = [ ["bpred_GSHARE_10_10_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"] ] +################################## +# Data Types & Functions +################################## + TestCase = namedtuple("TestCase", ['name', 'variant', 'cmd', 'grepstr']) # name: the name of this test configuration (used in printing human-readable # output and picking logfile names) @@ -248,6 +252,10 @@ def run_test_case(config): print(" Check %s" % logname) return 1 +################################## +# Main body +################################## + regressionDir = os.path.dirname(os.path.abspath(__file__)) os.chdir(regressionDir) diff --git a/sim/wsim b/bin/wsim similarity index 63% rename from sim/wsim rename to bin/wsim index c11ee51f3..4fc1355f0 100755 --- a/sim/wsim +++ b/bin/wsim @@ -7,31 +7,43 @@ # example: wsim rv64gc arch64i # example: wsim rv64gc tests/riscof/work/riscv-arch-test/rv64i_m/I/src/ref/ref.elf # example: wsim rv32i arch32i -s verilator +# example: wsim fdqh_ieee_rv64gc add -t testbench_fp # run TestFloat # # SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1 import argparse import os -# Read arguments +# Parse arguments parser = argparse.ArgumentParser() parser.add_argument("config", help="Configuration file") parser.add_argument("testsuite", help="Test suite or ELF file") parser.add_argument("--sim", "-s", help="Simulator", choices=["questa", "verilator", "vcs"], default="questa") +parser.add_argument("--tb", "-t", help="Testbench", choices=["testbench", "testbench_fp"], default="testbench") parser.add_argument("--gui", "-g", help="Simulate with GUI", action="store_true") parser.add_argument("--coverage", "-c", help="Code & Functional Coverage", action="store_true") args = parser.parse_args() print("Config: " + args.config + " tests " + args.testsuite + " sim " + args.sim + " gui " + str(args.gui)) +# Validate arguments +if (args.gui): + if (args.sim != "questa"): + print("GUI option only supported for Questa") + exit(1) + +if (args.coverage): + if (args.sim != "questa"): + print("Coverage option only available for Questa") + exit(1) + +# Launch selected simulator +cd = "cd $WALLY/sim/" +args.sim if (args.sim == "questa"): - cmd = "do wally-batch.do " + args.config + " " + args.testsuite + cmd = "do wally-batch.do " + args.config + " " + args.testsuite + " " + args.tb if (args.coverage): cmd += " -coverage" - os.system("cd $WALLY/sim/questa; vsim -c -do \"" + cmd + "\"") + os.system(cd + "; vsim -c -do \"" + cmd + "\"") elif (args.sim == "verilator"): - print("Running Verilator") + print("Running Verilator on %s %s", args.config, args.testsuite) elif (args.sim == "vcs"): - print("Running VCS") -else: - print("Unknown simulator") - exit(1) \ No newline at end of file + print("Running VCS on %s %s", args.config, args.testsuite) diff --git a/sim/questa/testfloat-batch.do b/sim/questa/testfloat-batch.do index f20867ddc..e266b7e0f 100644 --- a/sim/questa/testfloat-batch.do +++ b/sim/questa/testfloat-batch.do @@ -49,7 +49,7 @@ if {$WAV eq 0} { # Change TEST_SIZE to only test certain FP width # values are QP, DP, SP, HP or all for all tests -vopt +acc wkdir/work_${1}_${2}.testbenchfp -work wkdir/work_${1}_${2} -G TEST=$2 -G TEST_SIZE="all" -o testbenchopt +vopt +acc wkdir/work_${1}_${2}.testbench-fp -work wkdir/work_${1}_${2} -G TEST=$2 -G TEST_SIZE="all" -o testbenchopt vsim -lib wkdir/work_${1}_${2} testbenchopt -fatal 7 -suppress 3829 #-- Run the Simulation run -all diff --git a/sim/questa/testfloat.do b/sim/questa/testfloat.do index 796b540f3..dbfb85583 100644 --- a/sim/questa/testfloat.do +++ b/sim/questa/testfloat.do @@ -25,11 +25,11 @@ vlib work # start and run simulation # remove +acc flag for faster sim during regressions if there is no need to access internal signals # $num = the added words after the call -vlog +incdir+../config/deriv/$1 +incdir+../config/$1 +incdir+../config/shared ../src/cvw.sv ../testbench/testbench-fp.sv ../src/fpu/*.sv ../src/fpu/*/*.sv ../src/generic/*.sv ../src/generic/flop/*.sv -suppress 2583,7063,8607,2697 +vlog +incdir+../../config/deriv/$1 +incdir+../../config/$1 +incdir+../../config/shared ../../src/cvw.sv ../../testbench/testbench_fp.sv ../../src/fpu/*.sv ../../src/fpu/*/*.sv ../../src/generic/*.sv ../../src/generic/flop/*.sv -suppress 2583,7063,8607,2697 # Change TEST_SIZE to only test certain FP width # values are QP, DP, SP, HP or all for all tests -vsim -voptargs=+acc work.testbenchfp -GTEST=$2 -GTEST_SIZE="all" +vsim -voptargs=+acc work.testbench_fp -GTEST=$2 -GTEST_SIZE="all" # Set WAV variable to avoid having any output to wave (to limit disk space) quietly set WAV 1; diff --git a/sim/questa/wally-batch.do b/sim/questa/wally-batch.do index 5a69c906d..98ca5cba6 100644 --- a/sim/questa/wally-batch.do +++ b/sim/questa/wally-batch.do @@ -8,8 +8,8 @@ # # Takes 1:10 to run RV64IC tests using gui -# Usage: do wally-batch.do -# Example: do wally-batch.do rv32imc imperas-32i +# Usage: do wally-batch.do +# Example: do wally-batch.do rv64gc arch64i testbench # Use this wally-batch.do file to run this example. # Either bring up ModelSim and type the following at the "ModelSim>" prompt: @@ -22,8 +22,12 @@ onbreak {resume} set CFG ${1} set TESTSUITE ${2} +set TESTBENCH ${3} set WKDIR wkdir/${CFG}_${TESTSUITE} set WALLY $::env(WALLY) +set CONFIG ${WALLY}/config +set SRC ${WALLY}/src +set TB ${WALLY}/testbench # create library if [file exists ${WKDIR}] { @@ -68,15 +72,11 @@ if {$argc >= 3} { # "Extra checking for conflicts with always_comb done at vopt time" # because vsim will run vopt -set CONFIG ${WALLY}/config -set SRC ${WALLY}/src -set TB ${WALLY}/testbench - -vlog -lint -work ${WKDIR} +incdir+${CONFIG}/$1 +incdir+${CONFIG}/deriv/$1 +incdir+${CONFIG}/shared ${SRC}/cvw.sv ${TB}/testbench.sv ${TB}/common/*.sv ${SRC}/*/*.sv ${SRC}/*/*/*.sv -suppress 2583 -suppress 7063,2596,13286 +vlog -lint -work ${WKDIR} +incdir+${CONFIG}/$1 +incdir+${CONFIG}/deriv/$1 +incdir+${CONFIG}/shared ${SRC}/cvw.sv ${TB}/${TESTBENCH}.sv ${TB}/common/*.sv ${SRC}/*/*.sv ${SRC}/*/*/*.sv -suppress 2583 -suppress 7063,2596,13286 # start and run simulation # remove +acc flag for faster sim during regressions if there is no need to access internal signals -vopt wkdir/${CFG}_${TESTSUITE}.testbench -work ${WKDIR} -G TEST=$2 ${configOptions} -o testbenchopt ${CoverageVoptArg} +vopt wkdir/${CFG}_${TESTSUITE}.${TESTBENCH} -work ${WKDIR} -G TEST=$2 ${configOptions} -o testbenchopt ${CoverageVoptArg} vsim -lib ${WKDIR} testbenchopt -fatal 7 -suppress 3829 ${CoverageVsimArg} # vsim -lib wkdir/work_${1}_${2} testbenchopt -fatal 7 -suppress 3829 diff --git a/sim/questa/wave-fpu.do b/sim/questa/wave-fpu.do index 08b6b3378..f4da1e8a2 100644 --- a/sim/questa/wave-fpu.do +++ b/sim/questa/wave-fpu.do @@ -1,30 +1,30 @@ -add wave -noupdate /testbenchfp/clk -add wave -noupdate -radix decimal /testbenchfp/VectorNum -add wave -noupdate /testbenchfp/FrmNum -add wave -noupdate /testbenchfp/X -add wave -noupdate /testbenchfp/Y -add wave -noupdate /testbenchfp/Z -add wave -noupdate /testbenchfp/Res -add wave -noupdate /testbenchfp/Ans -add wave -noupdate /testbenchfp/reset -add wave -noupdate /testbenchfp/DivStart -add wave -noupdate /testbenchfp/FDivBusyE -add wave -noupdate /testbenchfp/CheckNow -add wave -noupdate /testbenchfp/DivDone -add wave -noupdate /testbenchfp/ResMatch -add wave -noupdate /testbenchfp/FlagMatch -add wave -noupdate /testbenchfp/CheckNow -add wave -noupdate /testbenchfp/NaNGood -add wave -group {PostProc} -noupdate /testbenchfp/postprocess/* -add wave -group {PostProc} -noupdate /testbenchfp/postprocess/specialcase/* -add wave -group {PostProc} -noupdate /testbenchfp/postprocess/flags/* -add wave -group {PostProc} -noupdate /testbenchfp/postprocess/normshift/* -add wave -group {PostProc} -noupdate /testbenchfp/postprocess/shiftcorrection/* -add wave -group {PostProc} -noupdate /testbenchfp/postprocess/resultsign/* -add wave -group {PostProc} -noupdate /testbenchfp/postprocess/round/* -add wave -group {PostProc} -noupdate /testbenchfp/postprocess/fmashiftcalc/* -add wave -group {PostProc} -noupdate /testbenchfp/postprocess/divshiftcalc/* -add wave -group {PostProc} -noupdate /testbenchfp/postprocess/cvtshiftcalc/* -add wave -group {Testbench} -noupdate /testbenchfp/* -add wave -group {Testbench} -noupdate /testbenchfp/readvectors/* +add wave -noupdate /testbench_fp/clk +add wave -noupdate -radix decimal /testbench_fp/VectorNum +add wave -noupdate /testbench_fp/FrmNum +add wave -noupdate /testbench_fp/X +add wave -noupdate /testbench_fp/Y +add wave -noupdate /testbench_fp/Z +add wave -noupdate /testbench_fp/Res +add wave -noupdate /testbench_fp/Ans +add wave -noupdate /testbench_fp/reset +add wave -noupdate /testbench_fp/DivStart +add wave -noupdate /testbench_fp/FDivBusyE +add wave -noupdate /testbench_fp/CheckNow +add wave -noupdate /testbench_fp/DivDone +add wave -noupdate /testbench_fp/ResMatch +add wave -noupdate /testbench_fp/FlagMatch +add wave -noupdate /testbench_fp/CheckNow +add wave -noupdate /testbench_fp/NaNGood +add wave -group {PostProc} -noupdate /testbench_fp/postprocess/* +add wave -group {PostProc} -noupdate /testbench_fp/postprocess/specialcase/* +add wave -group {PostProc} -noupdate /testbench_fp/postprocess/flags/* +add wave -group {PostProc} -noupdate /testbench_fp/postprocess/normshift/* +add wave -group {PostProc} -noupdate /testbench_fp/postprocess/shiftcorrection/* +add wave -group {PostProc} -noupdate /testbench_fp/postprocess/resultsign/* +add wave -group {PostProc} -noupdate /testbench_fp/postprocess/round/* +add wave -group {PostProc} -noupdate /testbench_fp/postprocess/fmashiftcalc/* +add wave -group {PostProc} -noupdate /testbench_fp/postprocess/divshiftcalc/* +add wave -group {PostProc} -noupdate /testbench_fp/postprocess/cvtshiftcalc/* +add wave -group {Testbench} -noupdate /testbench_fp/* +add wave -group {Testbench} -noupdate /testbench_fp/readvectors/* diff --git a/testbench/testbench-fp.sv b/testbench/testbench_fp.sv similarity index 99% rename from testbench/testbench-fp.sv rename to testbench/testbench_fp.sv index 474b54a89..21772cc48 100644 --- a/testbench/testbench-fp.sv +++ b/testbench/testbench_fp.sv @@ -23,15 +23,17 @@ //////////////////////////////////////////////////////////////////////////////////////////////// `include "config.vh" -`include "tests-fp.vh" +`include "tests_fp.vh" import cvw::*; -module testbenchfp; +module testbench_fp; // Two parameters TEST, TEST_SIZE used with testfloat.do in sim dir // to run specific precisions (e.g., quad or all) - parameter string TEST="none"; - parameter string TEST_SIZE="none"; +// parameter string TEST="none"; +// parameter string TEST_SIZE="none"; + parameter string TEST="add"; + parameter string TEST_SIZE="all"; `include "parameter-defs.vh" @@ -662,12 +664,14 @@ module testbenchfp; TestNum = 0; end - // set a the signals for all tests - always_comb UnitVal = Unit[TestNum]; - always_comb FmtVal = Fmt[TestNum]; - always_comb OpCtrlVal = OpCtrl[OpCtrlNum]; - always_comb WriteIntVal = WriteInt[OpCtrlNum]; - always_comb FrmVal = Frm[FrmNum]; + // set the signals for all tests + always_ff @(posedge clk) begin + UnitVal = Unit[TestNum]; + FmtVal = Fmt[TestNum]; + OpCtrlVal = OpCtrl[OpCtrlNum]; + WriteIntVal = WriteInt[OpCtrlNum]; + FrmVal = Frm[FrmNum]; + end // modify the format signal if only 2 percisions supported // - 1 for the larger precision diff --git a/testbench/tests-fp.vh b/testbench/tests_fp.vh similarity index 99% rename from testbench/tests-fp.vh rename to testbench/tests_fp.vh index e29cc8447..4c0e9cda5 100644 --- a/testbench/tests-fp.vh +++ b/testbench/tests_fp.vh @@ -1,5 +1,5 @@ /////////////////////////////////////////// -// tests0fo.vh +// tests_fp.vh // // Written: Katherine Parry 2022 // Modified: @@ -24,7 +24,7 @@ // and limitations under the License. //////////////////////////////////////////////////////////////////////////////////////////////// -`define PATH "../tests/fp/vectors/" +`define PATH "../../tests/fp/vectors/" `define ADD_OPCTRL 3'b110 `define MUL_OPCTRL 3'b100 `define SUB_OPCTRL 3'b111 From 9ee7544d3c8bb1b62607e719a7b5e14fb6aa6dbb Mon Sep 17 00:00:00 2001 From: David Harris Date: Sat, 6 Apr 2024 09:28:07 -0700 Subject: [PATCH 06/13] TestFloat running; normal testbench broken --- bin/regression-wally | 10 ++++------ bin/wsim | 5 +++-- sim/questa/wally-batch.do | 2 +- testbench/testbench_fp.sv | 4 ++-- 4 files changed, 10 insertions(+), 11 deletions(-) diff --git a/bin/regression-wally b/bin/regression-wally index 8819518e6..58a8384c9 100755 --- a/bin/regression-wally +++ b/bin/regression-wally @@ -29,9 +29,7 @@ tests = [ "arch32zba", "arch32zbb", "arch32zbc", "arch32zbs", "arch32zfh", "arch32zfh_fma", "arch32zfh_divsqrt", "arch32zfaf", "wally32a", "wally32priv", "wally32periph", "arch32zbkb", "arch32zbkc", "arch32zbkx", "arch32zknd", "arch32zkne", "arch32zknh"]], # "arch32zcb", "arch32zfad", - ["rv64e", ["arch64e"]], ["rv64i", ["arch64i"]], - ["rv64imc", ["arch64i", "arch64c", "arch64m", "wally64periph"]], ] # Separate out floating-point tests for RV64 to speed up coverage @@ -214,15 +212,15 @@ def getBuildrootTC(boot): def addTests(tests, sim): for test in tests: config = test[0]; - tests = test[1]; + suites = test[1]; if(len(test) >= 4 and test[2] == "configOptions"): configOptions = test[3] cmdPrefix = "vsim > {} -c < {} -c < " + logname print(cmd) diff --git a/bin/wsim b/bin/wsim index 4fc1355f0..ffd2e7ca3 100755 --- a/bin/wsim +++ b/bin/wsim @@ -22,8 +22,9 @@ parser.add_argument("--sim", "-s", help="Simulator", choices=["questa", "verilat parser.add_argument("--tb", "-t", help="Testbench", choices=["testbench", "testbench_fp"], default="testbench") parser.add_argument("--gui", "-g", help="Simulate with GUI", action="store_true") parser.add_argument("--coverage", "-c", help="Code & Functional Coverage", action="store_true") +parser.add_argument("--arg", "-a", help="Optional arguments passed to simulator via $value$plusargs", default="") args = parser.parse_args() -print("Config: " + args.config + " tests " + args.testsuite + " sim " + args.sim + " gui " + str(args.gui)) +print("Config=" + args.config + " tests=" + args.testsuite + " sim=" + args.sim + " gui=" + str(args.gui) + " arg='" + args.arg + "'") # Validate arguments if (args.gui): @@ -39,7 +40,7 @@ if (args.coverage): # Launch selected simulator cd = "cd $WALLY/sim/" +args.sim if (args.sim == "questa"): - cmd = "do wally-batch.do " + args.config + " " + args.testsuite + " " + args.tb + cmd = "do wally-batch.do " + args.config + " " + args.testsuite + " " + args.tb + " " + args.arg if (args.coverage): cmd += " -coverage" os.system(cd + "; vsim -c -do \"" + cmd + "\"") diff --git a/sim/questa/wally-batch.do b/sim/questa/wally-batch.do index 98ca5cba6..1c580919d 100644 --- a/sim/questa/wally-batch.do +++ b/sim/questa/wally-batch.do @@ -77,7 +77,7 @@ vlog -lint -work ${WKDIR} +incdir+${CONFIG}/$1 +incdir+${CONFIG}/deriv/$1 +incdi # start and run simulation # remove +acc flag for faster sim during regressions if there is no need to access internal signals vopt wkdir/${CFG}_${TESTSUITE}.${TESTBENCH} -work ${WKDIR} -G TEST=$2 ${configOptions} -o testbenchopt ${CoverageVoptArg} -vsim -lib ${WKDIR} testbenchopt -fatal 7 -suppress 3829 ${CoverageVsimArg} +vsim -lib ${WKDIR} testbenchopt -fatal 7 -suppress 3829 ${CoverageVsimArg} # vsim -lib wkdir/work_${1}_${2} testbenchopt -fatal 7 -suppress 3829 # power add generates the logging necessary for said generation. diff --git a/testbench/testbench_fp.sv b/testbench/testbench_fp.sv index 21772cc48..dac8055b7 100644 --- a/testbench/testbench_fp.sv +++ b/testbench/testbench_fp.sv @@ -32,7 +32,7 @@ module testbench_fp; // to run specific precisions (e.g., quad or all) // parameter string TEST="none"; // parameter string TEST_SIZE="none"; - parameter string TEST="add"; + parameter string TEST="none"; parameter string TEST_SIZE="all"; `include "parameter-defs.vh" @@ -156,7 +156,7 @@ module testbench_fp; // $display("This simulation for TEST is %s", TEST); // $display("This simulation for TEST is of the operand size of %s", TEST_SIZE); - if (P.Q_SUPPORTED & (TEST_SIZE == "QP" | TEST_SIZE == "all")) begin // if Quad percision is supported + if (P.Q_SUPPORTED & (TEST_SIZE == "QP" | TEST_SIZE == "all")) begin // if Quad percision is supported if (TEST === "cvtint" | TEST === "all") begin // if testing integer conversion // add the 128-bit cvtint tests to the to-be-tested list Tests = {Tests, f128rv32cvtint}; From 347df26713319407e6c85516b329cdc2e49835a3 Mon Sep 17 00:00:00 2001 From: David Harris Date: Sat, 6 Apr 2024 09:46:56 -0700 Subject: [PATCH 07/13] Fixed regression running; buildroot pending --- bin/regression-wally | 15 ++++++++++---- sim/questa/sim-buildroot | 33 ------------------------------- sim/questa/sim-buildroot-batch | 36 ---------------------------------- 3 files changed, 11 insertions(+), 73 deletions(-) delete mode 100755 sim/questa/sim-buildroot delete mode 100755 sim/questa/sim-buildroot-batch diff --git a/bin/regression-wally b/bin/regression-wally index 58a8384c9..32a88e77d 100755 --- a/bin/regression-wally +++ b/bin/regression-wally @@ -232,15 +232,20 @@ def addTests(tests, sim): def search_log_for_text(text, logfile): """Search through the given log file for text, returning True if it is found or False if it is not""" grepcmd = "grep -e '%s' '%s' > /dev/null" % (text, logfile) +# print(" search_log_for_text invoking %s" % grepcmd) return os.system(grepcmd) == 0 def run_test_case(config): """Run the given test case, and return 0 if the test suceeds and 1 if it fails""" - logname = "$WALLY/sim/questa/logs/"+config.variant+"_"+config.name+".log" -# cmd = config.cmd.format(logname) - cmd = config.cmd + " > " + logname + logname = WALLY + "/sim/questa/logs/"+config.variant+"_"+config.name+".log" ### *** fix hardwiring to questa log + #cmd = config.cmd + " > " + logname + if ("lint-wally" in config.cmd): + cmd = config.cmd + " | tee " + logname + else: + cmd = config.cmd + " > " + logname print(cmd) os.chdir(regressionDir) + #print(" run_test_case invoking %s" % cmd) os.system(cmd) if search_log_for_text(config.grepstr, logname): print(f"{bcolors.OKGREEN}%s_%s: Success{bcolors.ENDC}" % (config.variant, config.name)) @@ -257,6 +262,8 @@ def run_test_case(config): regressionDir = os.path.dirname(os.path.abspath(__file__)) os.chdir(regressionDir) +WALLY = os.environ.get('WALLY') + coveragesim = "questa" # Questa is required for code/functional coverage defaultsim = "questa" # Default simulator for all other tests; change to Verilator when flow is ready @@ -283,7 +290,7 @@ configs = [ TestCase( name="lints", variant="all", - cmd="./lint-wally " + nightMode + " | tee {}", + cmd="lint-wally " + nightMode, grepstr="lints run with no errors or warnings" ) ] diff --git a/sim/questa/sim-buildroot b/sim/questa/sim-buildroot deleted file mode 100755 index 530e33386..000000000 --- a/sim/questa/sim-buildroot +++ /dev/null @@ -1,33 +0,0 @@ -#!/bin/bash - -# Defaults -INSTR_LIMIT=0 -INSTR_WAVEON=1 -CHECKPOINT=0 - -# Arg Parsing -for i in "$@"; do - case $i in - --INSTR_LIMIT=*) - INSTR_LIMIT="${i#*=}" - shift # past argument=value - ;; - --INSTR_WAVEON=*) - INSTR_WAVEON="${i#*=}" - shift # past argument=value - ;; - --CHECKPOINT=*) - CHECKPOINT="${i#*=}" - shift # past argument=value - ;; - *) - # unknown option - ;; - esac -done - -echo "INSTR_LIMIT = ${INSTR_LIMIT}" -echo "INSTR_WAVEON = ${INSTR_WAVEON}" -echo "CHECKPOINT = ${CHECKPOINT}" - -vsim -do "do ./wally.do buildroot buildroot $RISCV $INSTR_LIMIT $INSTR_WAVEON $CHECKPOINT" diff --git a/sim/questa/sim-buildroot-batch b/sim/questa/sim-buildroot-batch deleted file mode 100755 index 81a6fac1e..000000000 --- a/sim/questa/sim-buildroot-batch +++ /dev/null @@ -1,36 +0,0 @@ -#!/bin/bash - -# Defaults -INSTR_LIMIT=0 -INSTR_WAVEON=1 -CHECKPOINT=0 - -# Arg Parsing -for i in "$@"; do - case $i in - --INSTR_LIMIT=*) - INSTR_LIMIT="${i#*=}" - shift # past argument=value - ;; - --INSTR_WAVEON=*) - INSTR_WAVEON="${i#*=}" - shift # past argument=value - ;; - --CHECKPOINT=*) - CHECKPOINT="${i#*=}" - shift # past argument=value - ;; - *) - # unknown option - ;; - esac -done - -echo "INSTR_LIMIT = ${INSTR_LIMIT}" -echo "INSTR_WAVEON = ${INSTR_WAVEON}" -echo "CHECKPOINT = ${CHECKPOINT}" - -# *** change config from buildroot to rv64gc -vsim -c < Date: Sat, 6 Apr 2024 10:34:21 -0700 Subject: [PATCH 08/13] Pass TEST to testbench with +TEST= rather than -G TEST= so that we don't have to recompile for every new test --- bin/wsim | 8 +- sim/questa/wally-batch.do | 99 ---------------------- sim/questa/wally.do | 158 ++++++++++++++++-------------------- testbench/common/loggers.sv | 53 ++++++++---- testbench/testbench.sv | 12 +-- 5 files changed, 121 insertions(+), 209 deletions(-) delete mode 100644 sim/questa/wally-batch.do diff --git a/bin/wsim b/bin/wsim index ffd2e7ca3..f03d152a8 100755 --- a/bin/wsim +++ b/bin/wsim @@ -40,10 +40,14 @@ if (args.coverage): # Launch selected simulator cd = "cd $WALLY/sim/" +args.sim if (args.sim == "questa"): - cmd = "do wally-batch.do " + args.config + " " + args.testsuite + " " + args.tb + " " + args.arg + cmd = "do wally.do " + args.config + " " + args.testsuite + " " + args.tb + " " + args.arg if (args.coverage): cmd += " -coverage" - os.system(cd + "; vsim -c -do \"" + cmd + "\"") + if (args.gui): # launch Questa with GUI; add +acc to keep variables accessible + cmd = cd + "; vsim -do \"" + cmd + " +acc\"" + else: # launch Questa in batch mode + cmd = cd + "; vsim -c -do \"" + cmd + "\"" + os.system(cmd) elif (args.sim == "verilator"): print("Running Verilator on %s %s", args.config, args.testsuite) elif (args.sim == "vcs"): diff --git a/sim/questa/wally-batch.do b/sim/questa/wally-batch.do deleted file mode 100644 index 1c580919d..000000000 --- a/sim/questa/wally-batch.do +++ /dev/null @@ -1,99 +0,0 @@ -# wally-batch.do -# SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1 -# -# Modification by Oklahoma State University & Harvey Mudd College -# Use with Testbench -# James Stine, 2008; David Harris 2021 -# Go Cowboys!!!!!! -# -# Takes 1:10 to run RV64IC tests using gui - -# Usage: do wally-batch.do -# Example: do wally-batch.do rv64gc arch64i testbench - -# Use this wally-batch.do file to run this example. -# Either bring up ModelSim and type the following at the "ModelSim>" prompt: -# do wally-batch.do -# or, to run from a shell, type the following at the shell prompt: -# vsim -do wally-batch.do -c -# (omit the "-c" to see the GUI while running from the shell) - -onbreak {resume} - -set CFG ${1} -set TESTSUITE ${2} -set TESTBENCH ${3} -set WKDIR wkdir/${CFG}_${TESTSUITE} -set WALLY $::env(WALLY) -set CONFIG ${WALLY}/config -set SRC ${WALLY}/src -set TB ${WALLY}/testbench - -# create library -if [file exists ${WKDIR}] { - vdel -lib ${WKDIR} -all -} -vlib ${WKDIR} -# Create directory for coverage data -mkdir -p cov - -set coverage 0 -set CoverageVoptArg "" -set CoverageVsimArg "" - -# Need to be able to pass arguments to vopt. Unforunately argv does not work because -# it takes on different values if vsim and the do file are called from the command line or -# if the do file isd called from questa sim directly. This chunk of code uses the $4 through $n -# variables and compacts into a single list for passing to vopt. -set configOptions "" -set from 4 -set step 1 -set lst {} -for {set i 0} true {incr i} { - set x [expr {$i*$step + $from}] - if {$x > $argc} break - set arg [expr "$$x"] - lappend lst $arg -} - -if {$argc >= 3} { - if {$3 eq "-coverage" || ($argc >= 7 && $7 eq "-coverage")} { - set coverage 1 - set CoverageVoptArg "+cover=sbecf" - set CoverageVsimArg "-coverage" - } elseif {$3 eq "configOptions"} { - set configOptions $lst - puts $configOptions - } -} - -# compile source files -# suppress spurious warnngs about -# "Extra checking for conflicts with always_comb done at vopt time" -# because vsim will run vopt - -vlog -lint -work ${WKDIR} +incdir+${CONFIG}/$1 +incdir+${CONFIG}/deriv/$1 +incdir+${CONFIG}/shared ${SRC}/cvw.sv ${TB}/${TESTBENCH}.sv ${TB}/common/*.sv ${SRC}/*/*.sv ${SRC}/*/*/*.sv -suppress 2583 -suppress 7063,2596,13286 - -# start and run simulation -# remove +acc flag for faster sim during regressions if there is no need to access internal signals -vopt wkdir/${CFG}_${TESTSUITE}.${TESTBENCH} -work ${WKDIR} -G TEST=$2 ${configOptions} -o testbenchopt ${CoverageVoptArg} -vsim -lib ${WKDIR} testbenchopt -fatal 7 -suppress 3829 ${CoverageVsimArg} - -# vsim -lib wkdir/work_${1}_${2} testbenchopt -fatal 7 -suppress 3829 -# power add generates the logging necessary for said generation. -# power add -r /dut/core/* -run -all -# power off -r /dut/core/* - - -if {$coverage} { - set UCDB cov/${CFG}_${TESTSUITE}.ucdb - echo "Saving coverage to ${UCDB}" - do coverage-exclusions-rv64gc.do # beware: this assumes testing the rv64gc configuration - coverage save -instance /testbench/dut/core ${UCDB} -} - -# These aren't doing anything helpful -#profile report -calltree -file wally-calltree.rpt -cutoff 2 -#power report -all -bsaif power.saif -quit diff --git a/sim/questa/wally.do b/sim/questa/wally.do index 430146d39..b60360c1e 100644 --- a/sim/questa/wally.do +++ b/sim/questa/wally.do @@ -1,4 +1,4 @@ -# wally.do +# wally-batch.do # SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1 # # Modification by Oklahoma State University & Harvey Mudd College @@ -8,113 +8,93 @@ # # Takes 1:10 to run RV64IC tests using gui -# run with vsim -do "do wally-pipelined.do rv64ic riscvarchtest-64m" +# Usage: do wally-batch.do [-coverage] [+acc] [any number of +value] [any number of -G VAR=VAL] +# Example: do wally-batch.do rv64gc arch64i testbench -# Use this wally-pipelined.do file to run this example. +# Use this wally-batch.do file to run this example. # Either bring up ModelSim and type the following at the "ModelSim>" prompt: -# do wally.do +# do wally-batch.do # or, to run from a shell, type the following at the shell prompt: -# vsim -do wally.do -c +# vsim -do wally-batch.do -c # (omit the "-c" to see the GUI while running from the shell) onbreak {resume} +set CFG ${1} +set TESTSUITE ${2} +set TESTBENCH ${3} +set WKDIR wkdir/${CFG}_${TESTSUITE} +set WALLY $::env(WALLY) +set CONFIG ${WALLY}/config +set SRC ${WALLY}/src +set TB ${WALLY}/testbench + # create library -if [file exists work] { - vdel -all +if [file exists ${WKDIR}] { + vdel -lib ${WKDIR} -all +} +vlib ${WKDIR} +# Create directory for coverage data +mkdir -p cov + +set coverage 0 +set CoverageVoptArg "" +set CoverageVsimArg "" + +# Need to be able to pass arguments to vopt. Unforunately argv does not work because +# it takes on different values if vsim and the do file are called from the command line or +# if the do file isd called from questa sim directly. This chunk of code uses the $4 through $n +# variables and compacts into a single list for passing to vopt. +set configOptions "" +set from 4 +set step 1 +set lst {} +for {set i 0} true {incr i} { + set x [expr {$i*$step + $from}] + if {$x > $argc} break + set arg [expr "$$x"] + lappend lst $arg +} + +if {$argc >= 3} { + if {$3 eq "-coverage" || ($argc >= 7 && $7 eq "-coverage")} { + set coverage 1 + set CoverageVoptArg "+cover=sbecf" + set CoverageVsimArg "-coverage" + } elseif {$3 eq "configOptions"} { + set configOptions $lst + puts $configOptions + } } -vlib work # compile source files # suppress spurious warnngs about # "Extra checking for conflicts with always_comb done at vopt time" # because vsim will run vopt +vlog -lint -work ${WKDIR} +incdir+${CONFIG}/$1 +incdir+${CONFIG}/deriv/$1 +incdir+${CONFIG}/shared ${SRC}/cvw.sv ${TB}/${TESTBENCH}.sv ${TB}/common/*.sv ${SRC}/*/*.sv ${SRC}/*/*/*.sv -suppress 2583 -suppress 7063,2596,13286 + # start and run simulation # remove +acc flag for faster sim during regressions if there is no need to access internal signals -if {$2 eq "buildroot" || $2 eq "buildroot-checkpoint"} { - vlog -lint -work work_${1}_${2} +incdir+../config/$1 +incdir+../config/deriv/$1 +incdir+../config/shared ../src/cvw.sv ../testbench/testbench-linux.sv ../testbench/common/*.sv ../src/*/*.sv ../src/*/*/*.sv -suppress 2583 - # start and run simulation - vopt +acc work_${1}_${2}.testbench -work work_${1}_${2} -G RISCV_DIR=$3 -G INSTR_LIMIT=$4 -G INSTR_WAVEON=$5 -G CHECKPOINT=$6 -G NO_SPOOFING=0 -o testbenchopt - vsim -lib work_${1}_${2} testbenchopt -suppress 8852,12070,3084,3829,13286 -fatal 7 +#vopt wkdir/${CFG}_${TESTSUITE}.${TESTBENCH} -work ${WKDIR} -G TEST=$2 ${configOptions} -o testbenchopt ${CoverageVoptArg} +vopt wkdir/${CFG}_${TESTSUITE}.${TESTBENCH} -work ${WKDIR} ${configOptions} -o testbenchopt ${CoverageVoptArg} +vsim -lib ${WKDIR} testbenchopt +TEST=${TESTSUITE} -fatal 7 -suppress 3829 ${CoverageVsimArg} - #-- Run the Simulation - #run -all - add log -recursive /* - do linux-wave.do - run -all +# vsim -lib wkdir/work_${1}_${2} testbenchopt -fatal 7 -suppress 3829 +# power add generates the logging necessary for said generation. +# power add -r /dut/core/* +run -all +# power off -r /dut/core/* - exec ./slack-notifier/slack-notifier.py - -} elseif {$2 eq "buildroot-no-trace"} { - vlog -lint -work work_${1}_${2} +incdir+../config/deriv/$1 +incdir+../config/$1 +incdir+../config/shared ../src/cvw.sv ../testbench/testbench-linux.sv ../testbench/common/*.sv ../src/*/*.sv ../src/*/*/*.sv -suppress 2583 - # start and run simulation - vopt +acc work_${1}_${2}.testbench -work work_${1}_${2} -G RISCV_DIR=$3 -G INSTR_LIMIT=0 -G INSTR_WAVEON=0 -G CHECKPOINT=0 -G NO_SPOOFING=1 -o testbenchopt - vsim -lib work_${1}_${2} testbenchopt -suppress 8852,12070,3084,3829,13286 -fatal 7 - #-- Run the Simulation - echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!" - echo "Don't forget to change DEBUG_LEVEL = 0." - echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!" - #run 100 ns - #force -deposit testbench/dut/core/priv/priv/csr/csri/IE_REGW 16'h2aa - #force -deposit testbench/dut/uncore/uncore/clint/clint/MTIMECMP 64'h1000 - run 14000 ms - #add log -recursive /* - #do linux-wave.do - #run -all - - exec ./slack-notifier/slack-notifier.py - -} elseif {$2 eq "fpga"} { - echo "hello" - vlog -work work +incdir+../config/fpga +incdir+../config/deriv/$1 +incdir+../config/shared ../src/cvw.sv ../testbench/testbench.sv ../testbench/sdc/*.sv ../testbench/common/*.sv ../src/*/*.sv ../src/*/*/*.sv ../../fpga/sim/*.sv -suppress 8852,12070,3084,3829,2583,7063,13286 - vopt +acc work.testbench -G TEST=$2 -G DEBUG=0 -o workopt - vsim workopt +nowarn3829 -fatal 7 - - do fpga-wave.do - add log -r /* - run 20 ms - -} else { - vlog +incdir+../config/$1 +incdir+../config/deriv/$1 +incdir+../config/shared ../src/cvw.sv ../testbench/testbench.sv ../testbench/common/*.sv ../src/*/*.sv ../src/*/*/*.sv -suppress 2583,13286 -suppress 7063 - vopt +acc work.testbench -G TEST=$2 -G DEBUG=1 -o workopt - - vsim workopt +nowarn3829 -fatal 7 - - view wave - #-- display input and output signals as hexidecimal values - #do ./wave-dos/peripheral-waves.do - add log -recursive /* - do wave.do - #do wave-bus.do - - # power add generates the logging necessary for saif generation. - #power add -r /dut/core/* - #-- Run the Simulation - - run -all - #power off -r /dut/core/* - #power report -all -bsaif power.saif - noview ../testbench/testbench.sv - view wave +if {$coverage} { + set UCDB cov/${CFG}_${TESTSUITE}.ucdb + echo "Saving coverage to ${UCDB}" + do coverage-exclusions-rv64gc.do # beware: this assumes testing the rv64gc configuration + coverage save -instance /testbench/dut/core ${UCDB} } - - -#elseif {$2 eq "buildroot-no-trace""} { -# vlog -lint -work work_${1}_${2} +incdir+../config/deriv/$1 +incdir+../config/$1 +incdir+../config/shared ../testbench/testbench-linux.sv ../testbench/common/*.sv ../src/*/*.sv ../src/*/*/*.sv -suppress 2583 - # start and run simulation -# vopt +acc work_${1}_${2}.testbench -work work_${1}_${2} -G RISCV_DIR=$3 -G INSTR_LIMIT=470350800 -G INSTR_WAVEON=470350800 -G CHECKPOINT=470350800 -G DEBUG_TRACE=0 -o testbenchopt -# vsim -lib work_${1}_${2} testbenchopt -suppress 8852,12070,3084,3829 - - #-- Run the Simulation -# run 100 ns -# force -deposit testbench/dut/core/priv/priv/csr/csri/IE_REGW 16'h2aa -# force -deposit testbench/dut/uncore/uncore/clint/clint/MTIMECMP 64'h1000 -# add log -recursive /* -# do linux-wave.do -# run -all - -# exec ./slack-notifier/slack-notifier.py -#} +# These aren't doing anything helpful +#profile report -calltree -file wally-calltree.rpt -cutoff 2 +#power report -all -bsaif power.saif +quit diff --git a/testbench/common/loggers.sv b/testbench/common/loggers.sv index e4dd1e4fe..4104bd0ec 100644 --- a/testbench/common/loggers.sv +++ b/testbench/common/loggers.sv @@ -27,7 +27,7 @@ //////////////////////////////////////////////////////////////////////////////////////////////// module loggers import cvw::*; #(parameter cvw_t P, - parameter string TEST, + parameter PrintHPMCounters, parameter I_CACHE_ADDR_LOGGER, parameter D_CACHE_ADDR_LOGGER, @@ -39,7 +39,8 @@ module loggers import cvw::*; #(parameter cvw_t P, // input logic BeginSample, // input logic StartSample, // input logic EndSample, - input string memfilename + input string memfilename, + input string TEST ); // performance counter logging @@ -79,40 +80,64 @@ module loggers import cvw::*; #(parameter cvw_t P, "Divide Cycles" }; + always_comb + if (TEST == "embench") begin + StartSampleFirst = FunctionName.FunctionName.FunctionName == "start_trigger"; + EndSampleFirst = FunctionName.FunctionName.FunctionName == "stop_trigger"; + end else if (TEST == "coremark") begin + StartSampleFirst = FunctionName.FunctionName.FunctionName == "start_time"; + EndSampleFirst = FunctionName.FunctionName.FunctionName == "stop_time"; + end else begin + StartSampleFirst = reset; + EndSample = DCacheFlushStart & ~DCacheFlushDone; + end + + /* if(TEST == "embench") begin // embench runs warmup then runs start_trigger // embench end with stop_trigger. - assign StartSampleFirst = FunctionName.FunctionName.FunctionName == "start_trigger"; - flopr #(1) StartSampleReg(clk, reset, StartSampleFirst, StartSampleDelayed); - assign StartSample = StartSampleFirst & ~ StartSampleDelayed; + //assign StartSampleFirst = FunctionName.FunctionName.FunctionName == "start_trigger"; + //flopr #(1) StartSampleReg(clk, reset, StartSampleFirst, StartSampleDelayed); + //assign StartSample = StartSampleFirst & ~ StartSampleDelayed; - assign EndSampleFirst = FunctionName.FunctionName.FunctionName == "stop_trigger"; + //assign EndSampleFirst = FunctionName.FunctionName.FunctionName == "stop_trigger"; flopr #(1) EndSampleReg(clk, reset, EndSampleFirst, EndSampleDelayed); assign EndSample = EndSampleFirst & ~ EndSampleDelayed; end else if(TEST == "coremark") begin // embench runs warmup then runs start_trigger // embench end with stop_trigger. - assign StartSampleFirst = FunctionName.FunctionName.FunctionName == "start_time"; - flopr #(1) StartSampleReg(clk, reset, StartSampleFirst, StartSampleDelayed); - assign StartSample = StartSampleFirst & ~ StartSampleDelayed; + //assign StartSampleFirst = FunctionName.FunctionName.FunctionName == "start_time"; + //flopr #(1) StartSampleReg(clk, reset, StartSampleFirst, StartSampleDelayed); + //assign StartSample = StartSampleFirst & ~ StartSampleDelayed; - assign EndSampleFirst = FunctionName.FunctionName.FunctionName == "stop_time"; + //assign EndSampleFirst = FunctionName.FunctionName.FunctionName == "stop_time"; flopr #(1) EndSampleReg(clk, reset, EndSampleFirst, EndSampleDelayed); assign EndSample = EndSampleFirst & ~ EndSampleDelayed; end else begin // default start condiction is reset // default end condiction is end of test (DCacheFlushDone) - assign StartSampleFirst = reset; - flopr #(1) StartSampleReg(clk, reset, StartSampleFirst, StartSampleDelayed); - assign StartSample = StartSampleFirst & ~ StartSampleDelayed; - assign EndSample = DCacheFlushStart & ~DCacheFlushDone; + //assign StartSampleFirst = reset; + //flopr #(1) StartSampleReg(clk, reset, StartSampleFirst, StartSampleDelayed); + //assign StartSample = StartSampleFirst & ~ StartSampleDelayed; + //assign EndSample = DCacheFlushStart & ~DCacheFlushDone; flop #(1) BeginReg(clk, StartSampleFirst, BeginDelayed); assign BeginSample = StartSampleFirst & ~BeginDelayed; end + + */ + + flopr #(1) StartSampleReg(clk, reset, StartSampleFirst, StartSampleDelayed); + assign StartSample = StartSampleFirst & ~StartSampleDelayed; + flopr #(1) EndSampleReg(clk, reset, EndSampleFirst, EndSampleDelayed); + assign EndSample = EndSampleFirst & ~ EndSampleDelayed; + flop #(1) BeginReg(clk, StartSampleFirst, BeginDelayed); // ** is this redundant with StartSampleReg? + assign BeginSample = StartSampleFirst & ~BeginDelayed; + + always @(negedge clk) begin if(StartSample) begin for(HPMCindex = 0; HPMCindex < 32; HPMCindex += 1) begin diff --git a/testbench/testbench.sv b/testbench/testbench.sv index d126a9ef6..93d862587 100644 --- a/testbench/testbench.sv +++ b/testbench/testbench.sv @@ -39,7 +39,6 @@ module testbench; /* verilator lint_off WIDTHTRUNC */ /* verilator lint_off WIDTHEXPAND */ parameter DEBUG=0; - parameter string TEST="arch64m"; parameter PrintHPMCounters=0; parameter BPRED_LOGGER=0; parameter I_CACHE_ADDR_LOGGER=0; @@ -58,6 +57,7 @@ module testbench; logic clk; logic reset_ext, reset; logic ResetMem; + string TEST; // DUT signals logic [P.AHBW-1:0] HRDATAEXT; @@ -101,7 +101,9 @@ module testbench; // pick tests based on modes supported initial begin - $display("TEST is %s", TEST); + TEST = "none"; + if ($value$plusargs("TEST=%s", TEST)) + $display("TEST is %s", TEST); //tests = '{}; if (P.XLEN == 64) begin // RV64 case (TEST) @@ -309,7 +311,7 @@ module testbench; // Verify the test ran correctly by checking the memory against a known signature. //////////////////////////////////////////////////////////////////////////////// if(TestBenchReset) test = 1; - if (TEST == "coremark") + if (P.ZICSR_SUPPORTED & TEST == "coremark") if (dut.core.priv.priv.EcallFaultM) begin $display("Benchmark: coremark is done."); $stop; @@ -559,8 +561,8 @@ module testbench; ramxdetector #(P.XLEN, P.LLEN) ramxdetector(clk, dut.core.lsu.MemRWM[1], dut.core.lsu.LSULoadAccessFaultM, dut.core.lsu.ReadDataM, dut.core.ifu.PCM, InstrM, dut.core.lsu.IEUAdrM, InstrMName); riscvassertions #(P) riscvassertions(); // check assertions for a legal configuration - loggers #(P, TEST, PrintHPMCounters, I_CACHE_ADDR_LOGGER, D_CACHE_ADDR_LOGGER, BPRED_LOGGER) - loggers (clk, reset, DCacheFlushStart, DCacheFlushDone, memfilename); + loggers #(P, PrintHPMCounters, I_CACHE_ADDR_LOGGER, D_CACHE_ADDR_LOGGER, BPRED_LOGGER) + loggers (clk, reset, DCacheFlushStart, DCacheFlushDone, memfilename, TEST); // track the current function or global label if (DEBUG == 1 | ((PrintHPMCounters | BPRED_LOGGER) & P.ZICNTR_SUPPORTED)) begin : FunctionName From b3f007ec7f151c2c2a2e14e362f8cca9967c1c40 Mon Sep 17 00:00:00 2001 From: David Harris Date: Sat, 6 Apr 2024 11:11:22 -0700 Subject: [PATCH 09/13] Working on buildroot in regression --- bin/regression-wally | 128 +++++++++++++++++++++-------------------- testbench/testbench.sv | 25 +++++--- 2 files changed, 84 insertions(+), 69 deletions(-) diff --git a/bin/regression-wally b/bin/regression-wally index 32a88e77d..ec4650725 100755 --- a/bin/regression-wally +++ b/bin/regression-wally @@ -30,6 +30,7 @@ tests = [ "arch32zfh_divsqrt", "arch32zfaf", "wally32a", "wally32priv", "wally32periph", "arch32zbkb", "arch32zbkc", "arch32zbkx", "arch32zknd", "arch32zkne", "arch32zknh"]], # "arch32zcb", "arch32zfad", ["rv64i", ["arch64i"]], + ["buildroot", ["buildroot"], "+INSTR_LIMIT=1000000"] ] # Separate out floating-point tests for RV64 to speed up coverage @@ -119,51 +120,51 @@ derivconfigtests = [ ] bpredtests = [ - ["bpred_TWOBIT_6_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_8_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_10_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_12_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_14_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_16_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_6_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_8_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_10_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_12_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_14_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_TWOBIT_16_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_6_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_8_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_10_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_12_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_14_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_16_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_6_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_8_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_10_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_12_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_14_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_TWOBIT_16_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], - ["bpred_GSHARE_6_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_6_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_8_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_8_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_12_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_12_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_14_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_14_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_16_16_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_16_16_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_6_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_6_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_8_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_8_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_12_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_12_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_14_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_14_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_16_16_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_16_16_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], # btb - ["bpred_GSHARE_10_16_6_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_16_6_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_16_8_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_16_8_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_16_12_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_16_12_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_6_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_6_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_8_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_8_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_12_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_16_12_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], # ras - ["bpred_GSHARE_10_2_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_2_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_3_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_3_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_4_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_4_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_6_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_6_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_10_10_0_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"], - ["bpred_GSHARE_10_10_10_1_rv32gc", ["embench"], "configOptions", "-GPrintHPMCounters=1"] + ["bpred_GSHARE_10_2_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_2_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_3_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_3_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_4_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_4_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_6_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_6_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_10_10_0_rv32gc", ["embench"], "-GPrintHPMCounters=1"], + ["bpred_GSHARE_10_10_10_1_rv32gc", ["embench"], "-GPrintHPMCounters=1"] ] ################################## @@ -190,23 +191,28 @@ class bcolors: BOLD = '\033[1m' UNDERLINE = '\033[4m' -def getBuildrootTC(boot): - INSTR_LIMIT = 1000000 # multiple of 100000; 4M is interesting because it gets into the kernel and enabling VM - MAX_EXPECTED = 246000000 # *** TODO: replace this with a search for the login prompt. - if boot: - name="buildrootboot" - BRcmd="vsim > {} -c < {} -c < {} -c < {} -c < {} -c < {} -c < {} -c < 0) begin + if((Minstret != 0) && (Minstret % 'd100000 == 0)) $display("Reached %d instructions", Minstret); + if((Minstret == INSTR_LIMIT) & (INSTR_LIMIT!=0)) begin $stop; $stop; end + end end end From 3c855e3e90a97dd292a38589a93b24f867476546 Mon Sep 17 00:00:00 2001 From: David Harris Date: Sat, 6 Apr 2024 11:42:41 -0700 Subject: [PATCH 10/13] Passing arguments to buildroot, not yet checking result correctly --- bin/regression-wally | 18 +++++++++++++----- bin/wsim | 6 +++--- sim/questa/wally.do | 20 +++++++++++--------- testbench/testbench.sv | 2 +- 4 files changed, 28 insertions(+), 18 deletions(-) diff --git a/bin/regression-wally b/bin/regression-wally index ec4650725..80a884de3 100755 --- a/bin/regression-wally +++ b/bin/regression-wally @@ -219,19 +219,27 @@ def addTests(tests, sim): for test in tests: config = test[0]; suites = test[1]; - if(len(test) >= 4 and test[2] == "configOptions"): - configOptions = test[3] - cmdPrefix = "vsim > {} -c < 2): + args = " ".join(test[2::]) + #args = str(test[2]) + print("args = ", args) + args = " --args " + args + #cmdPrefix = "wsim -s " + sim + " " + config + " --args " + args + #if(len(test) >= 4 and test[2] == "configOptions"): + # configOptions = test[3] + # cmdPrefix = "vsim > {} -c < {} -c <= 3} { - if {$3 eq "-coverage" || ($argc >= 7 && $7 eq "-coverage")} { - set coverage 1 - set CoverageVoptArg "+cover=sbecf" - set CoverageVsimArg "-coverage" - } elseif {$3 eq "configOptions"} { - set configOptions $lst - puts $configOptions - } + set configOptions $lst + puts $configOptions + #if {$3 eq "-coverage" || ($argc >= 7 && $7 eq "-coverage")} { + # set coverage 1 + # set CoverageVoptArg "+cover=sbecf" + # set CoverageVsimArg "-coverage" + #} elseif {$3 eq "configOptions"} { + # set configOptions $lst + # puts $configOptions + #} } # compile source files @@ -78,7 +80,7 @@ vlog -lint -work ${WKDIR} +incdir+${CONFIG}/$1 +incdir+${CONFIG}/deriv/$1 +incdi # remove +acc flag for faster sim during regressions if there is no need to access internal signals #vopt wkdir/${CFG}_${TESTSUITE}.${TESTBENCH} -work ${WKDIR} -G TEST=$2 ${configOptions} -o testbenchopt ${CoverageVoptArg} vopt wkdir/${CFG}_${TESTSUITE}.${TESTBENCH} -work ${WKDIR} ${configOptions} -o testbenchopt ${CoverageVoptArg} -vsim -lib ${WKDIR} testbenchopt +TEST=${TESTSUITE} -fatal 7 -suppress 3829 ${CoverageVsimArg} +vsim -lib ${WKDIR} testbenchopt +TEST=${TESTSUITE} ${configOptions} -fatal 7 -suppress 3829 ${CoverageVsimArg} # vsim -lib wkdir/work_${1}_${2} testbenchopt -fatal 7 -suppress 3829 # power add generates the logging necessary for said generation. diff --git a/testbench/testbench.sv b/testbench/testbench.sv index d87de27b2..1f0f21a6b 100644 --- a/testbench/testbench.sv +++ b/testbench/testbench.sv @@ -44,7 +44,6 @@ module testbench; parameter I_CACHE_ADDR_LOGGER=0; parameter D_CACHE_ADDR_LOGGER=0; parameter RISCV_DIR = "/opt/riscv"; -// parameter INSTR_LIMIT = 0; `ifdef USE_IMPERAS_DV import idvPkg::*; @@ -108,6 +107,7 @@ module testbench; TEST = "none"; if (!$value$plusargs("INSTR_LIMIT=%d", INSTR_LIMIT)) INSTR_LIMIT = 0; + $display("INSTR_LIMIT = ", INSTR_LIMIT); // pick tests based on modes supported From d3d39d39d08c93562c6ad0867870578811f879e3 Mon Sep 17 00:00:00 2001 From: David Harris Date: Sat, 6 Apr 2024 11:50:25 -0700 Subject: [PATCH 11/13] Buildroot regression passing --- bin/regression-wally | 22 ++++++++-------------- 1 file changed, 8 insertions(+), 14 deletions(-) diff --git a/bin/regression-wally b/bin/regression-wally index 80a884de3..49333107c 100755 --- a/bin/regression-wally +++ b/bin/regression-wally @@ -20,6 +20,7 @@ from multiprocessing import Pool, TimeoutError # Define lists of configurations and tests to run on each configuration ################################## +INSTR_LIMIT = 1000000 # multiple of 100000; 4M is interesting because it gets into the kernel and enabling VM tests = [ ["rv32e", ["arch32e"]], ["rv32i", ["arch32i"]], @@ -30,7 +31,7 @@ tests = [ "arch32zfh_divsqrt", "arch32zfaf", "wally32a", "wally32priv", "wally32periph", "arch32zbkb", "arch32zbkc", "arch32zbkx", "arch32zknd", "arch32zkne", "arch32zknh"]], # "arch32zcb", "arch32zfad", ["rv64i", ["arch64i"]], - ["buildroot", ["buildroot"], "+INSTR_LIMIT=1000000"] + ["buildroot", ["buildroot"], [f"+INSTR_LIMIT={INSTR_LIMIT}"], str(INSTR_LIMIT)+" instructions"] ] # Separate out floating-point tests for RV64 to speed up coverage @@ -220,27 +221,20 @@ def addTests(tests, sim): config = test[0]; suites = test[1]; if (len(test) > 2): - args = " ".join(test[2::]) - #args = str(test[2]) - print("args = ", args) - args = " --args " + args - #cmdPrefix = "wsim -s " + sim + " " + config + " --args " + args - #if(len(test) >= 4 and test[2] == "configOptions"): - # configOptions = test[3] - # cmdPrefix = "vsim > {} -c < {} -c < 3): + gs = test[3] + else: + gs = "All tests ran without failures" cmdPrefix="wsim -s " + sim + " " + config for t in suites: tc = TestCase( name=t, variant=config, - #cmd=cmdPrefix+" "+t+" configOptions "+configOptions+"\n!", cmd=cmdPrefix + " " + t + args, - grepstr="All tests ran without failures") + grepstr=gs) configs.append(tc) def search_log_for_text(text, logfile): From 6b844a2e6e9c87ad0decdb6263d5ac7c70bb8732 Mon Sep 17 00:00:00 2001 From: David Harris Date: Sat, 6 Apr 2024 13:43:06 -0700 Subject: [PATCH 12/13] Added GUI support and removed unused wave files --- bin/regression-wally | 86 +- bin/wsim | 6 + sim/questa/linux-wave.do | 357 ------- sim/questa/sim-testfloat-batch | 6 +- sim/questa/testfloat-batch.do | 55 -- sim/questa/testfloat.do | 52 -- sim/questa/wally.do | 40 +- sim/questa/wave-all.do | 1606 -------------------------------- testbench/testbench.sv | 3 +- testbench/testbench_fp.sv | 2 - 10 files changed, 61 insertions(+), 2152 deletions(-) delete mode 100644 sim/questa/linux-wave.do delete mode 100644 sim/questa/testfloat-batch.do delete mode 100644 sim/questa/testfloat.do delete mode 100644 sim/questa/wave-all.do diff --git a/bin/regression-wally b/bin/regression-wally index 49333107c..0cd195db7 100755 --- a/bin/regression-wally +++ b/bin/regression-wally @@ -20,6 +20,10 @@ from multiprocessing import Pool, TimeoutError # Define lists of configurations and tests to run on each configuration ################################## +# The tests are a list with one element for each configuration +# The element consists of the configuration name, a list of test suites to run, +# optionally a string to pass to the simulator, and optionally a nonstandard grep string to check for success + INSTR_LIMIT = 1000000 # multiple of 100000; 4M is interesting because it gets into the kernel and enabling VM tests = [ ["rv32e", ["arch32e"]], @@ -192,43 +196,19 @@ class bcolors: BOLD = '\033[1m' UNDERLINE = '\033[4m' -#def getBuildrootTC(boot): -# INSTR_LIMIT = 1000000 # multiple of 100000; 4M is interesting because it gets into the kernel and enabling VM - - -# BRcmd="vsim > {} -c < {} -c < {} -c < {} -c < 2): + if (len(test) >= 3): args = " --args " + " ".join(test[2]) else: args = "" - if (len(test) > 3): + if (len(test) >= 4): gs = test[3] else: gs = "All tests ran without failures" - cmdPrefix="wsim -s " + sim + " " + config + cmdPrefix="wsim --sim " + sim + " " + config for t in suites: tc = TestCase( name=t, @@ -251,9 +231,8 @@ def run_test_case(config): cmd = config.cmd + " | tee " + logname else: cmd = config.cmd + " > " + logname - print(cmd) os.chdir(regressionDir) - #print(" run_test_case invoking %s" % cmd) +# print(" run_test_case invoking %s" % cmd) os.system(cmd) if search_log_for_text(config.grepstr, logname): print(f"{bcolors.OKGREEN}%s_%s: Success{bcolors.ENDC}" % (config.variant, config.name)) @@ -347,46 +326,17 @@ if (testfloat): ] for config in testfloatconfigs: # div test case - divtest = TestCase( - name="div", - variant=config, - cmd="vsim > {} -c < {} -c < {} -c < {} -c < $argc} break @@ -57,15 +58,20 @@ for {set i 0} true {incr i} { } if {$argc >= 3} { - set configOptions $lst - puts $configOptions + set tbArgs $lst + puts $tbArgs + + if {[lindex $lst [expr { [llength $lst] -1 } ]] eq "+acc"} { + set GUI 1 + } + #if {$3 eq "-coverage" || ($argc >= 7 && $7 eq "-coverage")} { # set coverage 1 # set CoverageVoptArg "+cover=sbecf" # set CoverageVsimArg "-coverage" - #} elseif {$3 eq "configOptions"} { - # set configOptions $lst - # puts $configOptions + #} elseif {$3 eq "tbArgs"} { + # set tbArgs $lst + # puts $tbArgs #} } @@ -78,13 +84,22 @@ vlog -lint -work ${WKDIR} +incdir+${CONFIG}/$1 +incdir+${CONFIG}/deriv/$1 +incdi # start and run simulation # remove +acc flag for faster sim during regressions if there is no need to access internal signals -#vopt wkdir/${CFG}_${TESTSUITE}.${TESTBENCH} -work ${WKDIR} -G TEST=$2 ${configOptions} -o testbenchopt ${CoverageVoptArg} -vopt wkdir/${CFG}_${TESTSUITE}.${TESTBENCH} -work ${WKDIR} ${configOptions} -o testbenchopt ${CoverageVoptArg} -vsim -lib ${WKDIR} testbenchopt +TEST=${TESTSUITE} ${configOptions} -fatal 7 -suppress 3829 ${CoverageVsimArg} +vopt wkdir/${CFG}_${TESTSUITE}.${TESTBENCH} -work ${WKDIR} ${tbArgs} -o testbenchopt ${CoverageVoptArg} +# *** tbArgs producees a warning that TEST not found in design when running sim-testfloat-batch. Need to separate -G and + arguments to pass separately to vopt and vsim +vsim -lib ${WKDIR} testbenchopt +TEST=${TESTSUITE} ${tbArgs} -fatal 7 -suppress 3829 ${CoverageVsimArg} # vsim -lib wkdir/work_${1}_${2} testbenchopt -fatal 7 -suppress 3829 # power add generates the logging necessary for said generation. # power add -r /dut/core/* +if { ${GUI} } { + add log -recursive /* + if { ${TESTBENCH} eq "testbench_fp" } { + do wave-fpu.do + } else { + do wave.do + } +} + run -all # power off -r /dut/core/* @@ -99,4 +114,9 @@ if {$coverage} { # These aren't doing anything helpful #profile report -calltree -file wally-calltree.rpt -cutoff 2 #power report -all -bsaif power.saif -quit + +# terminate simulation unless we need to keep the GUI running +if { ${GUI} == 0} { + quit +} + diff --git a/sim/questa/wave-all.do b/sim/questa/wave-all.do deleted file mode 100644 index f151680f3..000000000 --- a/sim/questa/wave-all.do +++ /dev/null @@ -1,1606 +0,0 @@ -onerror {resume} -quietly WaveActivateNextPane {} 0 -add wave -noupdate /testbench/clk -add wave -noupdate /testbench/reset -add wave -noupdate /testbench/memfilename -add wave -noupdate -expand -group {Execution Stage} /testbench/dut/core/ifu/PCE -add wave -noupdate -expand -group {Execution Stage} /testbench/InstrEName -add wave -noupdate -expand -group {Execution Stage} /testbench/dut/core/ifu/InstrE -add wave -noupdate -divider -add wave -noupdate /testbench/dut/core/ebu/ebu/IReadF -add wave -noupdate /testbench/dut/core/DataStall -add wave -noupdate /testbench/dut/core/InstrStall -add wave -noupdate /testbench/dut/core/StallF -add wave -noupdate /testbench/dut/core/StallD -add wave -noupdate /testbench/dut/core/FlushD -add wave -noupdate /testbench/dut/core/FlushE -add wave -noupdate /testbench/dut/core/FlushM -add wave -noupdate /testbench/dut/core/FlushW -add wave -noupdate -divider -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrF -add wave -noupdate /testbench/InstrFName -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrD -add wave -noupdate /testbench/InstrDName -add wave -noupdate -divider -add wave -noupdate -expand -group {Decode Stage} /testbench/dut/core/ieu/InstrD -add wave -noupdate -expand -group {Decode Stage} /testbench/dut/core/ieu/dp/RdD -add wave -noupdate -expand -group {Decode Stage} /testbench/dut/core/ieu/dp/Rs1D -add wave -noupdate -expand -group {Decode Stage} /testbench/dut/core/ieu/dp/Rs2D -add wave -noupdate -expand -group RegFile /testbench/dut/core/ieu/dp/regf/rf -add wave -noupdate -expand -group RegFile /testbench/dut/core/ieu/dp/regf/a1 -add wave -noupdate -expand -group RegFile /testbench/dut/core/ieu/dp/regf/a2 -add wave -noupdate -expand -group RegFile /testbench/dut/core/ieu/dp/regf/a3 -add wave -noupdate -expand -group RegFile /testbench/dut/core/ieu/dp/regf/rd1 -add wave -noupdate -expand -group RegFile /testbench/dut/core/ieu/dp/regf/rd2 -add wave -noupdate -expand -group RegFile /testbench/dut/core/ieu/dp/regf/wd3 -add wave -noupdate -expand -group RegFile /testbench/dut/core/ieu/dp/regf/we3 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcBE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultE -add wave -noupdate /testbench/dut/core/ieu/dp/PCSrcE -add wave -noupdate -divider -add wave -noupdate /testbench/InstrMName -add wave -noupdate /testbench/dut/uncore/uncore/ram/memwrite -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HWDATA -add wave -noupdate -divider -add wave -noupdate -radix hexadecimal /testbench/PCW -add wave -noupdate /testbench/InstrWName -add wave -noupdate /testbench/dut/core/ieu/dp/RegWriteW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ResultW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdW -add wave -noupdate -divider -add wave -noupdate -radix hexadecimal /testbench/clk -add wave -noupdate -radix hexadecimal /testbench/reset -add wave -noupdate -radix hexadecimal /testbench/test -add wave -noupdate -radix hexadecimal /testbench/i -add wave -noupdate -radix hexadecimal /testbench/errors -add wave -noupdate -radix hexadecimal /testbench/totalerrors -add wave -noupdate -radix hexadecimal /testbench/testadr -add wave -noupdate -radix hexadecimal /testbench/InstrW -add wave -noupdate -radix hexadecimal /testbench/meminit -add wave -noupdate -radix hexadecimal /testbench/HRDATAEXT -add wave -noupdate -radix hexadecimal /testbench/HREADYEXT -add wave -noupdate -radix hexadecimal /testbench/HRESPEXT -add wave -noupdate -radix hexadecimal /testbench/HADDR -add wave -noupdate -radix hexadecimal /testbench/HWDATA -add wave -noupdate -radix hexadecimal /testbench/HWRITE -add wave -noupdate -radix hexadecimal /testbench/HSIZE -add wave -noupdate -radix hexadecimal /testbench/HBURST -add wave -noupdate -radix hexadecimal /testbench/HPROT -add wave -noupdate -radix hexadecimal /testbench/HTRANS -add wave -noupdate -radix hexadecimal /testbench/HMASTLOCK -add wave -noupdate -radix hexadecimal /testbench/HCLK -add wave -noupdate -radix hexadecimal /testbench/HRESETn -add wave -noupdate -radix hexadecimal /testbench/GPIOPinsIn -add wave -noupdate -radix hexadecimal /testbench/GPIOPinsOut -add wave -noupdate -radix hexadecimal /testbench/GPIOPinsEn -add wave -noupdate -radix hexadecimal /testbench/UARTSin -add wave -noupdate -radix hexadecimal /testbench/UARTSout -add wave -noupdate -radix hexadecimal /testbench/dut/clk -add wave -noupdate -radix hexadecimal /testbench/dut/reset -add wave -noupdate -radix hexadecimal /testbench/dut/HRDATAEXT -add wave -noupdate -radix hexadecimal /testbench/dut/HREADYEXT -add wave -noupdate -radix hexadecimal /testbench/dut/HRESPEXT -add wave -noupdate -radix hexadecimal /testbench/dut/HCLK -add wave -noupdate -radix hexadecimal /testbench/dut/HRESETn -add wave -noupdate -radix hexadecimal /testbench/dut/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/HWDATA -add wave -noupdate -radix hexadecimal /testbench/dut/HWRITE -add wave -noupdate -radix hexadecimal /testbench/dut/HSIZE -add wave -noupdate -radix hexadecimal /testbench/dut/HBURST -add wave -noupdate -radix hexadecimal /testbench/dut/HPROT -add wave -noupdate -radix hexadecimal /testbench/dut/HTRANS -add wave -noupdate -radix hexadecimal /testbench/dut/HMASTLOCK -add wave -noupdate -radix hexadecimal /testbench/dut/GPIOPinsIn -add wave -noupdate -radix hexadecimal /testbench/dut/GPIOPinsOut -add wave -noupdate -radix hexadecimal /testbench/dut/GPIOPinsEn -add wave -noupdate -radix hexadecimal /testbench/dut/UARTSin -add wave -noupdate -radix hexadecimal /testbench/dut/UARTSout -add wave -noupdate -radix hexadecimal /testbench/dut/PCF -add wave -noupdate -radix hexadecimal /testbench/dut/InstrF -add wave -noupdate -radix hexadecimal /testbench/dut/HRDATA -add wave -noupdate -radix hexadecimal /testbench/dut/HREADY -add wave -noupdate -radix hexadecimal /testbench/dut/HRESP -add wave -noupdate -radix hexadecimal /testbench/dut/InstrAccessFaultF -add wave -noupdate -radix hexadecimal /testbench/dut/DataAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/TimerIntM -add wave -noupdate -radix hexadecimal /testbench/dut/SwIntM -add wave -noupdate -radix hexadecimal /testbench/dut/ExtIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/PCF -add wave -noupdate -radix hexadecimal /testbench/dut/core/InstrF -add wave -noupdate -radix hexadecimal /testbench/dut/core/TimerIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ExtIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/SwIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/InstrAccessFaultF -add wave -noupdate -radix hexadecimal /testbench/dut/core/DataAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/HRDATA -add wave -noupdate -radix hexadecimal /testbench/dut/core/HREADY -add wave -noupdate -radix hexadecimal /testbench/dut/core/HRESP -add wave -noupdate -radix hexadecimal /testbench/dut/core/HCLK -add wave -noupdate -radix hexadecimal /testbench/dut/core/HRESETn -add wave -noupdate -radix hexadecimal /testbench/dut/core/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/core/HWDATA -add wave -noupdate -radix hexadecimal /testbench/dut/core/HWRITE -add wave -noupdate -radix hexadecimal /testbench/dut/core/HSIZE -add wave -noupdate -radix hexadecimal /testbench/dut/core/HBURST -add wave -noupdate -radix hexadecimal /testbench/dut/core/HPROT -add wave -noupdate -radix hexadecimal /testbench/dut/core/HTRANS -add wave -noupdate -radix hexadecimal /testbench/dut/core/HMASTLOCK -add wave -noupdate -radix hexadecimal /testbench/dut/core/ForwardAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ForwardBE -add wave -noupdate -radix hexadecimal /testbench/dut/core/StallF -add wave -noupdate -radix hexadecimal /testbench/dut/core/StallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/FlushD -add wave -noupdate -radix hexadecimal /testbench/dut/core/FlushE -add wave -noupdate -radix hexadecimal /testbench/dut/core/FlushM -add wave -noupdate -radix hexadecimal /testbench/dut/core/FlushW -add wave -noupdate -radix hexadecimal /testbench/dut/core/RetM -add wave -noupdate -radix hexadecimal /testbench/dut/core/TrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/CSRWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/PrivilegedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/SrcAM -add wave -noupdate -radix hexadecimal /testbench/dut/core/InstrD -add wave -noupdate -radix hexadecimal /testbench/dut/core/InstrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/PCE -add wave -noupdate -radix hexadecimal /testbench/dut/core/PCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/PCLinkW -add wave -noupdate -radix hexadecimal /testbench/dut/core/PCTargetE -add wave -noupdate -radix hexadecimal /testbench/dut/core/CSRReadValW -add wave -noupdate -radix hexadecimal /testbench/dut/core/PrivilegedNextPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/MemRWM -add wave -noupdate -radix hexadecimal /testbench/dut/core/InstrValidM -add wave -noupdate -radix hexadecimal /testbench/dut/core/InstrMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/DataMisalignedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/IllegalBaseInstrFaultD -add wave -noupdate -radix hexadecimal /testbench/dut/core/IllegalIEUInstrFaultD -add wave -noupdate -radix hexadecimal /testbench/dut/core/LoadMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/LoadAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/StoreAmoMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/StoreAmoAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/InstrMisalignedAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/zero -add wave -noupdate -radix hexadecimal /testbench/dut/core/PCSrcE -add wave -noupdate -radix hexadecimal /testbench/dut/core/CSRWritePendingDEM -add wave -noupdate -radix hexadecimal /testbench/dut/core/LoadStallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/SetFflagsM -add wave -noupdate -radix hexadecimal /testbench/dut/core/FRM_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/FRegWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/MemRWAlignedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/Funct3M -add wave -noupdate -radix hexadecimal /testbench/dut/core/MemAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/MemPAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/WriteDataM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ReadDataM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ReadDataW -add wave -noupdate -radix hexadecimal /testbench/dut/core/InstrPAdrF -add wave -noupdate -radix hexadecimal /testbench/dut/core/DataStall -add wave -noupdate -radix hexadecimal /testbench/dut/core/InstrStall -add wave -noupdate -radix hexadecimal /testbench/dut/core/InstrAckD -add wave -noupdate -radix hexadecimal /testbench/dut/core/MemAckW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/StallF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/StallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/FlushD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/FlushE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/FlushM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/FlushW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrPAdrF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrStall -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCSrcE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCTargetE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/RetM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/TrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PrivilegedNextPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCLinkW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/IllegalBaseInstrFaultD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/IllegalIEUInstrFaultD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMisalignedAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/UnalignedPCNextF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCNextF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/misaligned -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/BranchMisalignedFaultE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/BranchMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/TrapMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/StallExceptResolveBranchesF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PrivilegedChangePCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/IllegalCompInstrD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPlusUpperF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPlus2or4F -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCD -add wave -noupdate -radix hexadecimal /testbench/PCW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCLinkD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCLinkE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCLinkM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/CompressedF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrRawD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/nop -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcmux/d0 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcmux/d1 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcmux/d2 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcmux/s -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcmux/y -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcreg/load -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcreg/val -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/pcreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrDReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrDReg/load -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrDReg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrDReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrDReg/val -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrDReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCDReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCDReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCDReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCDReg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCDReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCDReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/InstrRawD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/InstrD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/IllegalCompInstrD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/instr16 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/rds1 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/rs2 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/rs1p -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/rs2p -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/rds1p -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/rdp -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCILSP -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCILSPD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCSS -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCSSD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCL -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCLD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCI -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCS -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCSD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCB -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCIASP -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCIW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCJ -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immCILUI -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/immSH -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/decomp/op -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMisalginedReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMisalginedReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMisalginedReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMisalginedReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMisalignedAdrReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMisalignedAdrReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMisalignedAdrReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMisalignedAdrReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrEReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrEReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrEReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrEReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrMReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCEReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCEReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCEReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCEReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCMReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCMReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCMReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCMReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCWReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCWReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCWReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCWReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPDReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPDReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPDReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPDReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPEReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPEReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPEReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPEReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPMReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPMReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPMReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPMReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPWReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPWReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPWReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCPWReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/InstrD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/IllegalIEUInstrFaultD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/IllegalBaseInstrFaultD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/PCE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/PCTargetE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/DataMisalignedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/DataAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/MemRWM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/MemAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/WriteDataM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/SrcAM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/Funct3M -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/ReadDataW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/CSRReadValW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/PCLinkW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/InstrValidM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/StallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/FlushD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/FlushE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/FlushM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/FlushW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/RetM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/TrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/LoadStallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/PCSrcE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/CSRWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/PrivilegedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/CSRWritePendingDEM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/ImmSrcD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/FlagsE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/ALUControlE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/ALUSrcAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/ALUSrcBE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/ResultSrcW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/TargetSrcE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/Rs1D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/Rs2D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/Rs1E -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/Rs2E -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/RdE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/RdM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/RdW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/ForwardAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/ForwardBE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/RegWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/RegWriteW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/MemReadE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/OpD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/Funct3D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/Funct7b5D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ImmSrcD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/StallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/FlushD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/IllegalIEUInstrFaultD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/IllegalBaseInstrFaultD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/FlushE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/FlagsE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/PCSrcE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ALUControlE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ALUSrcAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ALUSrcBE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/TargetSrcE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/MemReadE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/FlushM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/DataMisalignedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/MemRWM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/CSRWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/PrivilegedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/Funct3M -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/RegWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/FlushW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/RegWriteW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ResultSrcW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/InstrValidM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/CSRWritePendingDEM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/RegWriteD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/RegWriteE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ResultSrcD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ResultSrcE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ResultSrcM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/MemRWD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/MemRWE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/JumpD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/JumpE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/BranchD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/BranchE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ALUOpD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ALUControlD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ALUSrcAD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ALUSrcBD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/TargetSrcD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/W64D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/CSRWriteD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/CSRWriteE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/Funct3E -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/InstrValidE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/InstrValidM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/PrivilegedD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/PrivilegedE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ControlsD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/aluc3D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/subD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/sraD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/sltD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/sltuD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/BranchTakenE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/zeroE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ltE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/ltuE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregE/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregE/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregE/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregE/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregE/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregM/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregM/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregM/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregM/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregM/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregW/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregW/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregW/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregW/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/controlregW/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/StallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/FlushD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ImmSrcD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/InstrD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/FlushE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ForwardAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ForwardBE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/PCSrcE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUControlE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUSrcAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUSrcBE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/TargetSrcE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/PCE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/FlagsE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/PCTargetE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/FlushM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Funct3M -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/CSRReadValW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ReadDataW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RetM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/TrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcAM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/WriteDataM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/MemAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/FlushW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RegWriteW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ResultSrcW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/PCLinkW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs1D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs2D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs1E -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs2E -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD1D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD2D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ImmExtD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD1E -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD2E -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ImmExtE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ForwardedSrcAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcBE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/WriteDataE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/TargetBaseE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/IntResultW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ResultW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/regf/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/regf/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/regf/we3 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/regf/a1 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/regf/a2 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/regf/a3 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/regf/wd3 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/regf/rd1 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/regf/rd2 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/regf/i -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ext/InstrD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ext/ImmSrcD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ext/ImmExtD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD1EReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD1EReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD1EReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD1EReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD1EReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD2EReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD2EReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD2EReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD2EReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RD2EReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ImmExtEReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ImmExtEReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ImmExtEReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ImmExtEReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ImmExtEReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs1EReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs1EReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs1EReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs1EReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs1EReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs2EReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs2EReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs2EReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs2EReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/Rs2EReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdEReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdEReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdEReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdEReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdEReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/faemux/d0 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/faemux/d1 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/faemux/d2 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/faemux/s -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/faemux/y -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/fbemux/d0 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/fbemux/d1 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/fbemux/d2 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/fbemux/s -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/fbemux/y -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/srcamux/d0 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/srcamux/d1 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/srcamux/s -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/srcamux/y -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/srcbmux/d0 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/srcbmux/d1 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/srcbmux/s -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/srcbmux/y -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/A -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/B -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/ALUControl -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/Result -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/FlagsE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/a -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/amt -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/right -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/arith -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/w64 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/y -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/genblk1/z -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/genblk1/zshift -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/genblk1/ylower -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/genblk1/yupper -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/genblk1/offset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/alu/sh/genblk1/amt6 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/targetsrcmux/d0 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/targetsrcmux/d1 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/targetsrcmux/s -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/targetsrcmux/y -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcAMReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcAMReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcAMReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcAMReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcAMReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultMReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultMReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultMReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultMReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultMReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/WriteDataMReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/WriteDataMReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/WriteDataMReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/WriteDataMReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/WriteDataMReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdMEg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdMEg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdMEg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdMEg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdMEg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultWReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultWReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultWReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultWReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultWReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdWEg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdWEg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdWEg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdWEg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/RdWEg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/resultmux/d0 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/resultmux/d1 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/resultmux/d2 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/resultmux/d3 -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/resultmux/s -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/resultmux/y -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/Rs1D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/Rs2D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/Rs1E -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/Rs2E -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/RdE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/RdM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/RdW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/MemReadE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/RegWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/RegWriteW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/ForwardAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/ForwardBE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/fw/LoadStallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/FlushW -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/DataStall -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/MemRWM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/MemAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/Funct3M -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/ReadDataM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/WriteDataM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/MemPAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/MemRWAlignedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/DataMisalignedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/MemAckW -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/ReadDataW -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/DataAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/LoadMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/LoadAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/StoreAmoMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/StoreAmoAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/ReadDataWReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/ReadDataWReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/ReadDataWReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/ReadDataWReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/dmem/ReadDataWReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/UnsignedLoadM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/InstrPAdrF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/IReadF -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/IRData -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/MemPAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/DReadM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/DWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/WriteDataM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/DSizeM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/DRData -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HRDATA -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HREADY -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HRESP -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HCLK -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HRESETn -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HWDATA -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HWRITE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HSIZE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HBURST -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HPROT -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HTRANS -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HMASTLOCK -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/InstrAckD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/MemAckW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/GrantData -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/ISize -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/HRDATAMasked -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/IReady -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/DReady -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/swr/HRDATA -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/swr/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/swr/UnsignedLoadM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/swr/HSIZE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/swr/HRDATAMasked -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/swr/ByteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/swr/HalfwordM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ebu/ebu/swr/genblk1/WordM -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/PCSrcE -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/CSRWritePendingDEM -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/RetM -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/TrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/LoadStallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/InstrStall -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/DataStall -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/StallF -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/StallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/FlushD -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/FlushE -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/FlushM -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/FlushW -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/BranchFlushDE -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/StallDCause -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/StallFCause -add wave -noupdate -radix hexadecimal /testbench/dut/core/hzu/StallWCause -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/FlushW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/CSRWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/SrcAM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/InstrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/PCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/CSRReadValW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/PrivilegedNextPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/RetM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/TrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/InstrValidM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/FRegWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/LoadStallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/PrivilegedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/InstrMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/InstrAccessFaultF -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/IllegalIEUInstrFaultD -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/LoadMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/LoadAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/StoreAmoMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/StoreAmoAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/TimerIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/ExtIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/SwIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/InstrMisalignedAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/MemAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/SetFflagsM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/FRM_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/FlushD -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/FlushE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/FlushM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/StallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/NextPrivilegeModeM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/PrivilegeModeW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/CauseM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/NextFaultMtvalM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/MEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/SEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/UEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/UTVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/STVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/MTVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/MEDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/MIDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/SEDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/SIDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/uretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/sretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/mretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/ecallM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/ebreakM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/wfiM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/sfencevmaM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/IllegalCSRAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/IllegalIEUInstrFaultE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/IllegalIEUInstrFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/InstrAccessFaultD -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/InstrAccessFaultE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/InstrAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/IllegalInstrFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/BreakpointFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/EcallFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/InstrPageFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/LoadPageFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/StorePageFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/MTrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/STrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/UTrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/STATUS_MPP -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/STATUS_SPP -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/STATUS_TSR -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/STATUS_MIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/STATUS_SIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/MIP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/MIE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/md -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/sd -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/privmodereg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/privmodereg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/privmodereg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/InstrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/PrivilegedM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/IllegalIEUInstrFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/IllegalCSRAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/PrivilegeModeW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/STATUS_TSR -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/IllegalInstrFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/uretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/sretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/mretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/ecallM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/ebreakM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/wfiM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/sfencevmaM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/pmd/IllegalPrivilegedInstrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/FlushW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/InstrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/PCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/SrcAM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/TrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/MTrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/STrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/UTrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/mretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/sretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/uretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/TimerIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/ExtIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/SwIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/InstrValidM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/FRegWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/LoadStallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/NextPrivilegeModeM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/PrivilegeModeW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CauseM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/NextFaultMtvalM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/STATUS_MPP -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/STATUS_SPP -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/STATUS_TSR -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/MEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/SEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/UEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/UTVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/STVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/MTVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/MEDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/MIDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/SEDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/SIDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/MIP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/MIE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/STATUS_MIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/STATUS_SIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/SetFflagsM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/FRM_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRReadValW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/IllegalCSRAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRMReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRSReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRUReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRNReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRCReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRSrcM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRRWM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRRSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRRCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRWriteValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/MSTATUS_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/SSTATUS_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/USTATUS_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/MCOUNTINHIBIT_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/MCOUNTEREN_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/SCOUNTEREN_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/WriteMSTATUSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/WriteSSTATUSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/WriteUSTATUSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRMWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRSWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSRUWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/UnalignedNextEPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/NextEPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/NextCauseM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/NextMtvalM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/CSCAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/SIP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/SIE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/UIP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/UIE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/IllegalCSRCAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/IllegalCSRMAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/IllegalCSRSAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/IllegalCSRUAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/IllegalCSRNAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/InsufficientCSRPrivilegeM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/CSRMWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/CSRSWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/CSCAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/ExtIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/TimerIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/SwIntM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/MIDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/MIP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/MIE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/SIP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/SIE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/CSRWriteValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/IntInM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/IP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/IE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/MIP_WRITE_MASK -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/SIP_WRITE_MASK -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/WriteMIPM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/WriteMIEM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/WriteSIPM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/WriteSIEM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/WriteMSTATUSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/WriteSSTATUSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/WriteUSTATUSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/TrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/FRegWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/NextPrivilegeModeM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/PrivilegeModeW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/mretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/sretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/uretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/CSRWriteValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/MSTATUS_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/SSTATUS_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/USTATUS_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_MPP -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_SPP -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_TSR -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_MIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_SIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_SD -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_TW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_TVM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_MXR -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_SUM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_SUM_INT -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_MPRV -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_MPRV_INT -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_SXL -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_UXL -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_XS -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_FS -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_FS_INT -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_MPP_NEXT -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_MPIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_SPIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_UPIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrsr/STATUS_UIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/InstrValidM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/LoadStallD -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/CSRMWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/CSCAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/PrivilegeModeW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/CSRWriteValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/MCOUNTINHIBIT_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/MCOUNTEREN_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/SCOUNTEREN_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/CSRCReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/IllegalCSRCAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/CYCLE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/INSTRET_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/HPMCOUNTER3_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/HPMCOUNTER4_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/CYCLEPlusM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/INSTRETPlusM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/HPMCOUNTER3PlusM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/HPMCOUNTER4PlusM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/NextCYCLEM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/NextINSTRETM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/NextHPMCOUNTER3M -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/NextHPMCOUNTER4M -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/WriteCYCLEM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/WriteINSTRETM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/WriteHPMCOUNTER3M -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/WriteHPMCOUNTER4M -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/CounterNumM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/CYCLEreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/CYCLEreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/CYCLEreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/CYCLEreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/INSTRETreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/INSTRETreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/INSTRETreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/INSTRETreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/HPMCOUNTER3reg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/HPMCOUNTER3reg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/HPMCOUNTER3reg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/HPMCOUNTER3reg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/HPMCOUNTER4reg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/HPMCOUNTER4reg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/HPMCOUNTER4reg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/counters/genblk1/genblk1/HPMCOUNTER4reg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/CSRMWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/CSCAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/NextEPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/NextCauseM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/NextMtvalM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MSTATUS_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/CSRWriteValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/CSRMReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTEREN_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTINHIBIT_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MEDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MIDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MIP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MIE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WriteMSTATUSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/IllegalCSRMAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MISA_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MSCRATCH_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCAUSE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVAL_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/PMPCFG01_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/PMPCFG23_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/PMPADDR0_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/zero -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/allones -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MEDELEG_MASK -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MIDELEG_MASK -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WriteMTVECM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WriteMEDELEGM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WriteMIDELEGM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WriteMSCRATCHM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WriteMEPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WriteMCAUSEM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WriteMTVALM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WriteMCOUNTERENM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WriteMCOUNTINHIBITM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WritePMPCFG0M -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WritePMPCFG2M -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/WritePMPADDR0M -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MISAbits -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk2/PMPCFG01reg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk2/PMPCFG01reg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk2/PMPCFG01reg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk2/PMPCFG01reg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk2/PMPCFG01reg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk2/PMPCFG23reg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk2/PMPCFG23reg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk2/PMPCFG23reg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk2/PMPCFG23reg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk2/PMPCFG23reg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MEDELEGreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MEDELEGreg/load -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MEDELEGreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MEDELEGreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MEDELEGreg/val -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MEDELEGreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MIDELEGreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MIDELEGreg/load -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MIDELEGreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MIDELEGreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MIDELEGreg/val -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/genblk1/MIDELEGreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVECreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVECreg/load -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVECreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVECreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVECreg/val -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVECreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MSCRATCHreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MSCRATCHreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MSCRATCHreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MSCRATCHreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MSCRATCHreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MEPCreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MEPCreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MEPCreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MEPCreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MEPCreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCAUSEreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCAUSEreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCAUSEreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCAUSEreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCAUSEreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVALreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVALreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVALreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVALreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVALreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTERENreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTERENreg/load -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTERENreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTERENreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTERENreg/val -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTERENreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTINHIBITreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTINHIBITreg/load -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTINHIBITreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTINHIBITreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTINHIBITreg/val -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTINHIBITreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/PMPADDR0reg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/PMPADDR0reg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/PMPADDR0reg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/PMPADDR0reg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/PMPADDR0reg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/CSRSWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/STrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/CSCAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/NextEPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/NextCauseM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/NextMtvalM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SSTATUS_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/CSRWriteValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/CSRSReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/STVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SCOUNTEREN_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SEDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SIDELEG_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SIP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SIE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/WriteSSTATUSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/IllegalCSRSAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/zero -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/allones -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SEDELEG_MASK -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/WriteSTVECM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/WriteSEDELEGM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/WriteSIDELEGM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/WriteSSCRATCHM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/WriteSEPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/WriteSCAUSEM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/WriteSTVALM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/WriteSATPM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/WriteSCOUNTERENM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SSCRATCH_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCAUSE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVAL_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SATP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVECreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVECreg/load -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVECreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVECreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVECreg/val -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVECreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SSCRATCHreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SSCRATCHreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SSCRATCHreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SSCRATCHreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SSCRATCHreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SEPCreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SEPCreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SEPCreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SEPCreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SEPCreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCAUSEreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCAUSEreg/load -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCAUSEreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCAUSEreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCAUSEreg/val -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCAUSEreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVALreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVALreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVALreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVALreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/STVALreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SATPreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SATPreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SATPreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SATPreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SATPreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCOUNTERENreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCOUNTERENreg/load -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCOUNTERENreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCOUNTERENreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCOUNTERENreg/val -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/genblk1/SCOUNTERENreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/CSRNWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/UTrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/CSCAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/NextEPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/NextCauseM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/NextMtvalM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/USTATUS_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/CSRWriteValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/CSRNReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/UEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/UTVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/UIP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/UIE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/WriteUSTATUSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/IllegalCSRNAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/CSRUWriteM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/CSCAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/CSRWriteValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/CSRUReadValM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/SetFflagsM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/FRM_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/IllegalCSRUAccessM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/FFLAGS_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/WriteFFLAGSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/WriteFRMM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/WriteFCSRM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/NextFRMM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/NextFFLAGSM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/FRMreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/FRMreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/FRMreg/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/FRMreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/FRMreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/FFLAGSreg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/FFLAGSreg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/FFLAGSreg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/genblk1/FFLAGSreg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/CSRValWReg/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/CSRValWReg/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/CSRValWReg/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/CSRValWReg/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/CSRValWReg/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregD/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregD/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregD/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregD/en -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregD/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregD/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregE/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregE/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregE/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregE/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregE/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregM/clk -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregM/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregM/clear -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregM/d -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/faultregM/q -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/reset -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/InstrMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/InstrAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/IllegalInstrFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/BreakpointFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/LoadMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/StoreAmoMisalignedFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/LoadAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/StoreAmoAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/EcallFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/InstrPageFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/LoadPageFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/StorePageFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/mretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/sretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/uretM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/PrivilegeModeW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/NextPrivilegeModeM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/MEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/SEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/UEPC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/UTVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/STVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/MTVEC_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/MIP_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/MIE_REGW -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/STATUS_MIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/STATUS_SIE -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/InstrMisalignedAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/MemAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/InstrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/TrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/MTrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/STrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/UTrapM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/RetM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/PrivilegedNextPCM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/CauseM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/NextFaultMtvalM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/MIntGlobalEnM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/SIntGlobalEnM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/PendingIntsM -add wave -noupdate -radix hexadecimal /testbench/dut/core/priv/trap/InterruptM -add wave -noupdate -radix hexadecimal /testbench/dut/imem/AdrF -add wave -noupdate -radix hexadecimal /testbench/dut/imem/InstrF -add wave -noupdate -radix hexadecimal /testbench/dut/imem/InstrAccessFaultF -add wave -noupdate -radix hexadecimal /testbench/dut/imem/adrbits -add wave -noupdate -radix hexadecimal /testbench/dut/imem/rd -add wave -noupdate -radix hexadecimal /testbench/dut/imem/rd2 -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HCLK -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HRESETn -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HWDATAIN -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HWRITE -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HSIZE -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HBURST -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HPROT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HTRANS -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HMASTLOCK -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HRDATAEXT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HREADYEXT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HRESPEXT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HRDATA -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HREADY -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HRESP -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/DataAccessFaultM -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/TimerIntM -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/SwIntM -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/GPIOPinsIn -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/GPIOPinsOut -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/GPIOPinsEn -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/UARTSin -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/UARTSout -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HWDATA -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HREADTim -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HREADCLINT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HREADGPIO -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HREADUART -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HSELTim -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HSELCLINT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HSELGPIO -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/PreHSELUART -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HSELUART -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HRESPTim -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HRESPCLINT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HRESPGPIO -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HRESPUART -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HREADYTim -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HREADYCLINT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HREADYGPIO -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/HREADYUART -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/MemRW -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/MemRWtim -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/MemRWclint -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/MemRWgpio -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/MemRWuart -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/UARTIntr -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/timdec/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/timdec/Base -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/timdec/Range -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/timdec/HSEL -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/timdec/match -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clintdec/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clintdec/Base -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clintdec/Range -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clintdec/HSEL -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clintdec/match -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpiodec/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpiodec/Base -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpiodec/Range -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpiodec/HSEL -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpiodec/match -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uartdec/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uartdec/Base -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uartdec/Range -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uartdec/HSEL -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uartdec/match -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/sww/HRDATA -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/sww/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/sww/HSIZE -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/sww/HWDATAIN -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/sww/HWDATA -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/sww/ByteM -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/sww/HalfwordM -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/sww/WriteDataSubwordDuplicated -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/sww/ByteMaskM -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/HCLK -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/HRESETn -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/MemRWtim -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/HWDATA -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/HSELTim -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/HREADTim -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/HRESPTim -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/HREADYTim -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/entry -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/memread -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/memwrite -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/ram/busycount -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/HCLK -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/HRESETn -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/MemRWclint -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/HWDATA -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/HREADCLINT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/HRESPCLINT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/HREADYCLINT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/TimerIntM -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/SwIntM -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/MTIMECMP -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/MTIME -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/MSIP -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/entry -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/memread -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/clint/memwrite -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/HCLK -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/HRESETn -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/MemRWgpio -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/HWDATA -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/HREADGPIO -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/HRESPGPIO -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/HREADYGPIO -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/GPIOPinsIn -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/GPIOPinsOut -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/GPIOPinsEn -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/INPUT_VAL -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/INPUT_EN -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/OUTPUT_EN -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/OUTPUT_VAL -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/entry -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/memread -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/gpio/memwrite -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/HCLK -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/HRESETn -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/MemRWuart -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/HADDR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/HWDATA -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/HREADUART -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/HRESPUART -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/HREADYUART -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/SIN -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/DSRb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/DCDb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/CTSb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/RIb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/SOUT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/RTSb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/DTRb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/OUT1b -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/OUT2b -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/INTR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/TXRDYb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/RXRDYb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/A -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/MEMRb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/MEMWb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/Din -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/Dout -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/BAUDOUTb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/HCLK -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/HRESETn -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/A -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/Din -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/Dout -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/MEMRb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/MEMWb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/INTR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/TXRDYb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/RXRDYb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/BAUDOUTb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/RCLK -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/SIN -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DSRb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DCDb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/CTSb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/RIb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/SOUT -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/RTSb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DTRb -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/OUT1b -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/OUT2b -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/RBR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/FCR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/LCR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/LSR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/SCR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DLL -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DLM -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/IER -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/MSR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/MCR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/SINd -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DSRbd -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DCDbd -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/CTSbd -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/RIbd -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/SINsync -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DSRbsync -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DCDbsync -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/CTSbsync -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/RIbsync -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DSRb2 -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DCDb2 -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/CTSb2 -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/RIb2 -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/SOUTbit -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/loop -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/DLAB -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/baudpulse -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txbaudpulse -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxbaudpulse -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/baudcount -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxoversampledcnt -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txoversampledcnt -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxbitsreceived -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txbitssent -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxstate -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txstate -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxshiftreg -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxfifohead -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxfifotail -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txfifohead -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txfifotail -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxfifotriggerlevel -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxfifoentries -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txfifoentries -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxbitsexpected -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txbitsexpected -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/RXBR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxtimeoutcnt -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxcentered -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxparity -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxparitybit -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxstopbit -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxparityerr -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxoverrunerr -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxframingerr -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxbreak -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxfifohaserr -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxdataready -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxfifoempty -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxfifotriggered -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxfifotimeout -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxfifodmaready -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxdata9 -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxdata -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxerrbit -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxfullbit -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/TXHR -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txdata -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/nexttxdata -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txsr -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txnextbit -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txhrfull -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txsrfull -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txparity -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txfifoempty -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txfifofull -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txfifodmaready -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/fifoenabled -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/fifodmamodesel -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/evenparitysel -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxlinestatusintr -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/rxdataavailintr -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/txhremptyintr -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/modemstatusintr -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/intrpending -add wave -noupdate -radix hexadecimal /testbench/dut/uncore/uncore/uart/u/intrid -add wave -noupdate -radix hexadecimal /testbench/it/clk -add wave -noupdate -radix hexadecimal /testbench/it/reset -add wave -noupdate -radix hexadecimal /testbench/it/FlushE -add wave -noupdate -radix hexadecimal /testbench/it/InstrD -add wave -noupdate -radix hexadecimal /testbench/it/InstrE -add wave -noupdate -radix hexadecimal /testbench/it/InstrM -add wave -noupdate -radix hexadecimal /testbench/it/InstrW -add wave -noupdate -radix hexadecimal /testbench/it/InstrWReg/clk -add wave -noupdate -radix hexadecimal /testbench/it/InstrWReg/reset -add wave -noupdate -radix hexadecimal /testbench/it/InstrWReg/d -add wave -noupdate -radix hexadecimal /testbench/it/InstrWReg/q -add wave -noupdate -radix hexadecimal /testbench/it/ddec/instr -add wave -noupdate -radix hexadecimal /testbench/it/ddec/op -add wave -noupdate -radix hexadecimal /testbench/it/ddec/funct3 -add wave -noupdate -radix hexadecimal /testbench/it/ddec/funct7 -add wave -noupdate -radix hexadecimal /testbench/it/ddec/imm -add wave -noupdate -radix hexadecimal /testbench/it/edec/instr -add wave -noupdate -radix hexadecimal /testbench/it/edec/op -add wave -noupdate -radix hexadecimal /testbench/it/edec/funct3 -add wave -noupdate -radix hexadecimal /testbench/it/edec/funct7 -add wave -noupdate -radix hexadecimal /testbench/it/edec/imm -add wave -noupdate -radix hexadecimal /testbench/it/mdec/instr -add wave -noupdate -radix hexadecimal /testbench/it/mdec/op -add wave -noupdate -radix hexadecimal /testbench/it/mdec/funct3 -add wave -noupdate -radix hexadecimal /testbench/it/mdec/funct7 -add wave -noupdate -radix hexadecimal /testbench/it/mdec/imm -add wave -noupdate -radix hexadecimal /testbench/it/wdec/instr -add wave -noupdate -radix hexadecimal /testbench/it/wdec/op -add wave -noupdate -radix hexadecimal /testbench/it/wdec/funct3 -add wave -noupdate -radix hexadecimal /testbench/it/wdec/funct7 -add wave -noupdate -radix hexadecimal /testbench/it/wdec/imm -TreeUpdate [SetDefaultTree] -WaveRestoreCursors {{Cursor 2} {330314 ns} 0} {{Cursor 3} {330384 ns} 0} -quietly wave cursor active 2 -configure wave -namecolwidth 250 -configure wave -valuecolwidth 168 -configure wave -justifyvalue left -configure wave -signalnamewidth 1 -configure wave -snapdistance 10 -configure wave -datasetprefix 0 -configure wave -rowmargin 4 -configure wave -childrowmargin 2 -configure wave -gridoffset 0 -configure wave -gridperiod 1 -configure wave -griddelta 40 -configure wave -timeline 0 -configure wave -timelineunits ns -update -WaveRestoreZoom {330283 ns} {330427 ns} diff --git a/testbench/testbench.sv b/testbench/testbench.sv index 1f0f21a6b..8587e227a 100644 --- a/testbench/testbench.sv +++ b/testbench/testbench.sv @@ -34,6 +34,7 @@ `endif import cvw::*; +import "DPI-C" function string getenv(input string env_name); module testbench; /* verilator lint_off WIDTHTRUNC */ @@ -43,7 +44,6 @@ module testbench; parameter BPRED_LOGGER=0; parameter I_CACHE_ADDR_LOGGER=0; parameter D_CACHE_ADDR_LOGGER=0; - parameter RISCV_DIR = "/opt/riscv"; `ifdef USE_IMPERAS_DV import idvPkg::*; @@ -60,6 +60,7 @@ module testbench; // Variables that can be overwritten with $value$plusargs at start of simulation string TEST; integer INSTR_LIMIT; + string RISCV_DIR = getenv("RISCV"); // "/opt/riscv"; // DUT signals logic [P.AHBW-1:0] HRDATAEXT; diff --git a/testbench/testbench_fp.sv b/testbench/testbench_fp.sv index dac8055b7..ed58a9992 100644 --- a/testbench/testbench_fp.sv +++ b/testbench/testbench_fp.sv @@ -30,8 +30,6 @@ import cvw::*; module testbench_fp; // Two parameters TEST, TEST_SIZE used with testfloat.do in sim dir // to run specific precisions (e.g., quad or all) -// parameter string TEST="none"; -// parameter string TEST_SIZE="none"; parameter string TEST="none"; parameter string TEST_SIZE="all"; From c73a48cf221466cce55d4c5459c80caebed042d6 Mon Sep 17 00:00:00 2001 From: David Harris Date: Sat, 6 Apr 2024 13:52:13 -0700 Subject: [PATCH 13/13] Removed unused wave-dos --- sim/questa/wave-dos/ahb-muldiv.do | 100 ------------ sim/questa/wave-dos/ahb-waves.do | 89 ---------- sim/questa/wave-dos/cache-waves.do | 76 --------- sim/questa/wave-dos/default-waves.do | 65 -------- sim/questa/wave-dos/generic.do | 23 --- sim/questa/wave-dos/linux-waves.do | 207 ------------------------ sim/questa/wave-dos/peripheral-waves.do | 118 -------------- 7 files changed, 678 deletions(-) delete mode 100644 sim/questa/wave-dos/ahb-muldiv.do delete mode 100644 sim/questa/wave-dos/ahb-waves.do delete mode 100644 sim/questa/wave-dos/cache-waves.do delete mode 100644 sim/questa/wave-dos/default-waves.do delete mode 100644 sim/questa/wave-dos/generic.do delete mode 100644 sim/questa/wave-dos/linux-waves.do delete mode 100644 sim/questa/wave-dos/peripheral-waves.do diff --git a/sim/questa/wave-dos/ahb-muldiv.do b/sim/questa/wave-dos/ahb-muldiv.do deleted file mode 100644 index 3170bc969..000000000 --- a/sim/questa/wave-dos/ahb-muldiv.do +++ /dev/null @@ -1,100 +0,0 @@ -restart -f -delete wave /* -view wave - -add wave /testbench/clk -add wave /testbench/reset -add wave -divider - -# new -#add wave /testbench/dut/core/ebu/ebu/IReadF -add wave /testbench/dut/core/DataStall -add wave /testbench/dut/core/ICacheStallF -add wave /testbench/dut/core/StallF -add wave /testbench/dut/core/StallD - -add wave /testbench/dut/core/StallE -add wave /testbench/dut/core/StallM -add wave /testbench/dut/core/StallW -add wave /testbench/dut/core/FlushD -add wave /testbench/dut/core/FlushE -add wave /testbench/dut/core/FlushM -add wave /testbench/dut/core/FlushW - -add wave -noupdate -divider -height 32 "MulDiv" -add wave -hex /testbench/dut/core/mdu/* - -add wave -noupdate -divider -height 32 "Integer Divider" -add wave -hex /testbench/dut/core/mdu/genblk1/div/fsm1/CURRENT_STATE -add wave -hex /testbench/dut/core/mdu/genblk1/div/fsm1/NEXT_STATE -add wave -hex /testbench/dut/core/mdu/genblk1/div/* - -add wave -noupdate -divider -height 32 "RF" -add wave -hex /testbench/dut/core/ieu/dp/regf/* -add wave -hex /testbench/dut/core/ieu/dp/regf/rf - -add wave -divider -add wave -hex /testbench/dut/core/ifu/PCF -add wave -hex /testbench/dut/core/ifu/PCD -add wave -hex /testbench/dut/core/ifu/InstrD -add wave /testbench/InstrDName -add wave -divider - -add wave -hex /testbench/dut/core/ifu/PCE -add wave -hex /testbench/dut/core/ifu/InstrE -add wave /testbench/InstrEName -add wave -hex /testbench/dut/core/ieu/dp/SrcAE -add wave -hex /testbench/dut/core/ieu/dp/SrcBE -add wave -hex /testbench/dut/core/ieu/dp/ALUResultE -#add wave /testbench/dut/core/ieu/dp/PCSrcE -add wave -divider - -add wave -hex /testbench/dut/core/ifu/PCM -add wave -hex /testbench/dut/core/ifu/InstrM -add wave /testbench/InstrMName -add wave /testbench/dut/uncore/uncore/ram/memwrite -add wave -hex /testbench/dut/uncore/uncore/HADDR -add wave -hex /testbench/dut/uncore/uncore/HWDATA -add wave -divider - -add wave -hex /testbench/dut/core/ebu/ebu/MemReadM -add wave -hex /testbench/dut/core/ebu/ebu/InstrReadF -add wave -hex /testbench/dut/core/ebu/ebu/BusState -add wave -hex /testbench/dut/core/ebu/ebu/NextBusState -add wave -hex /testbench/dut/core/ebu/ebu/HADDR -add wave -hex /testbench/dut/core/ebu/ebu/HREADY -add wave -hex /testbench/dut/core/ebu/ebu/HTRANS -add wave -hex /testbench/dut/core/ebu/ebu/HRDATA -add wave -hex /testbench/dut/core/ebu/ebu/HWRITE -add wave -hex /testbench/dut/core/ebu/ebu/HWDATA -add wave -hex /testbench/dut/core/ebu/ebu/HBURST -add wave -hex /testbench/dut/core/ebu/ebu/CaptureDataM -add wave -divider - -add wave -hex /testbench/dut/uncore/uncore/ram/* -add wave -divider - -add wave -hex /testbench/dut/core/ifu/PCW -add wave -hex /testbench/dut/core/ifu/InstrW -add wave /testbench/InstrWName -add wave /testbench/dut/core/ieu/dp/RegWriteW -add wave -hex /testbench/dut/core/ebu/ebu/ReadDataW -add wave -hex /testbench/dut/core/ieu/dp/ResultW -add wave -hex /testbench/dut/core/ieu/dp/RdW -add wave -divider - -add wave -hex /testbench/dut/uncore/uncore/ram/* -add wave -divider - -# appearance -TreeUpdate [SetDefaultTree] -WaveRestoreZoom {0 ps} {100 ps} -configure wave -namecolwidth 350 -configure wave -valuecolwidth 250 -configure wave -justifyvalue left -configure wave -signalnamewidth 0 -configure wave -snapdistance 10 -configure wave -datasetprefix 0 -configure wave -rowmargin 4 -configure wave -childrowmargin 2 -set DefaultRadix hexadecimal diff --git a/sim/questa/wave-dos/ahb-waves.do b/sim/questa/wave-dos/ahb-waves.do deleted file mode 100644 index 37a397d04..000000000 --- a/sim/questa/wave-dos/ahb-waves.do +++ /dev/null @@ -1,89 +0,0 @@ -# ahb-waves.do -restart -f -delete wave /* -view wave - -add wave /testbench/clk -add wave /testbench/reset -add wave -divider - -#add wave /testbench/dut/core/ebu/ebu/IReadF -add wave /testbench/dut/core/DataStall -add wave /testbench/dut/core/ICacheStallF -add wave /testbench/dut/core/StallF -add wave /testbench/dut/core/StallD -add wave /testbench/dut/core/StallE -add wave /testbench/dut/core/StallM -add wave /testbench/dut/core/StallW -add wave /testbench/dut/core/FlushD -add wave /testbench/dut/core/FlushE -add wave /testbench/dut/core/FlushM -add wave /testbench/dut/core/FlushW - -add wave -divider -add wave -hex /testbench/dut/core/ifu/PCF -add wave -hex /testbench/dut/core/ifu/PCD -add wave -hex /testbench/dut/core/ifu/InstrD -add wave /testbench/InstrDName -add wave -hex /testbench/dut/core/ifu/ic/InstrRawD -add wave -divider - -add wave -hex /testbench/dut/core/ifu/PCE -add wave -hex /testbench/dut/core/ifu/InstrE -add wave /testbench/InstrEName -add wave -hex /testbench/dut/core/ieu/dp/SrcAE -add wave -hex /testbench/dut/core/ieu/dp/SrcBE -add wave -hex /testbench/dut/core/ieu/dp/ALUResultE -#add wave /testbench/dut/core/ieu/dp/PCSrcE -add wave -divider - -add wave -hex /testbench/dut/core/ifu/PCM -add wave -hex /testbench/dut/core/ifu/InstrM -add wave /testbench/InstrMName -add wave /testbench/dut/uncore/uncore/ram/memwrite -add wave -hex /testbench/dut/uncore/uncore/HADDR -add wave -hex /testbench/dut/uncore/uncore/HWDATA -add wave -divider - -add wave -hex /testbench/dut/core/ebu/ebu/MemReadM -add wave -hex /testbench/dut/core/ebu/ebu/InstrReadF -add wave -hex /testbench/dut/core/ebu/ebu/BusState -add wave -hex /testbench/dut/core/ebu/ebu/NextBusState -add wave -hex /testbench/dut/core/ebu/ebu/HADDR -add wave -hex /testbench/dut/core/ebu/ebu/HREADY -add wave -hex /testbench/dut/core/ebu/ebu/HTRANS -add wave -hex /testbench/dut/core/ebu/ebu/HRDATA -add wave -hex /testbench/dut/core/ebu/ebu/HWRITE -add wave -hex /testbench/dut/core/ebu/ebu/HWDATA -add wave -hex /testbench/dut/core/ebu/ebu/CaptureDataM -add wave -divider - -add wave -hex /testbench/dut/uncore/uncore/ram/* -add wave -divider - -add wave -hex /testbench/dut/core/ifu/PCW -add wave -hex /testbench/dut/core/ifu/InstrW -add wave /testbench/InstrWName -add wave /testbench/dut/core/ieu/dp/RegWriteW -add wave -hex /testbench/dut/core/ebu/ebu/ReadDataW -add wave -hex /testbench/dut/core/ieu/dp/ResultW -add wave -hex /testbench/dut/core/ieu/dp/RdW -add wave -divider - -add wave -hex /testbench/dut/uncore/uncore/ram/* -add wave -divider - -add wave -hex -r /testbench/* - -# appearance -TreeUpdate [SetDefaultTree] -WaveRestoreZoom {0 ps} {100 ps} -configure wave -namecolwidth 250 -configure wave -valuecolwidth 150 -configure wave -justifyvalue left -configure wave -signalnamewidth 0 -configure wave -snapdistance 10 -configure wave -datasetprefix 0 -configure wave -rowmargin 4 -configure wave -childrowmargin 2 -set DefaultRadix hexadecimal diff --git a/sim/questa/wave-dos/cache-waves.do b/sim/questa/wave-dos/cache-waves.do deleted file mode 100644 index ff6e855ec..000000000 --- a/sim/questa/wave-dos/cache-waves.do +++ /dev/null @@ -1,76 +0,0 @@ -add wave /testbench/clk -add wave /testbench/reset -add wave -divider - -#add wave /testbench/dut/core/ebu/ebu/IReadF -add wave /testbench/dut/core/DataStall -add wave /testbench/dut/core/ICacheStallF -add wave /testbench/dut/core/StallF -add wave /testbench/dut/core/StallD -add wave /testbench/dut/core/StallE -add wave /testbench/dut/core/StallM -add wave /testbench/dut/core/StallW -add wave /testbench/dut/core/FlushD -add wave /testbench/dut/core/FlushE -add wave /testbench/dut/core/FlushM -add wave /testbench/dut/core/FlushW - -add wave -divider -add wave -hex /testbench/dut/core/ifu/PCF -add wave -hex /testbench/dut/core/ifu/PCD -add wave -hex /testbench/dut/core/ifu/InstrD - -add wave /testbench/InstrDName -add wave -divider - - -add wave -hex /testbench/dut/core/ifu/PCE -add wave -hex /testbench/dut/core/ifu/InstrE -add wave /testbench/InstrEName -add wave -hex /testbench/dut/core/ieu/dp/SrcAE -add wave -hex /testbench/dut/core/ieu/dp/SrcBE -add wave -hex /testbench/dut/core/ieu/dp/ALUResultE -#add wave /testbench/dut/core/ieu/dp/PCSrcE -add wave -divider - -add wave -hex /testbench/dut/core/ifu/PCM -add wave -hex /testbench/dut/core/ifu/InstrM -add wave /testbench/InstrMName -add wave /testbench/dut/uncore/uncore/ram/memwrite -add wave -hex /testbench/dut/uncore/uncore/HADDR -add wave -hex /testbench/dut/uncore/uncore/HWDATA -add wave -divider - -add wave -hex /testbench/dut/core/ebu/ebu/MemReadM -add wave -hex /testbench/dut/core/ebu/ebu/InstrReadF -add wave -hex /testbench/dut/core/ebu/ebu/BusState -add wave -hex /testbench/dut/core/ebu/ebu/NextBusState -add wave -hex /testbench/dut/core/ebu/ebu/HADDR -add wave -hex /testbench/dut/core/ebu/ebu/HREADY -add wave -hex /testbench/dut/core/ebu/ebu/HTRANS -add wave -hex /testbench/dut/core/ebu/ebu/HRDATA -add wave -hex /testbench/dut/core/ebu/ebu/HWRITE -add wave -hex /testbench/dut/core/ebu/ebu/HWDATA -add wave -hex /testbench/dut/core/ebu/ebu/ReadDataM -add wave -divider - -add wave /testbench/dut/core/ebu/ebu/CaptureDataM -add wave /testbench/dut/core/ebu/ebu/CapturedDataAvailable -add wave /testbench/dut/core/StallW -add wave -hex /testbench/dut/core/ebu/ebu/CapturedData -add wave -hex /testbench/dut/core/ebu/ebu/ReadDataWnext -add wave -hex /testbench/dut/core/ebu/ebu/ReadDataW -add wave -hex /testbench/dut/core/ifu/PCW -add wave -hex /testbench/dut/core/ifu/InstrW -add wave /testbench/InstrWName -add wave /testbench/dut/core/ieu/dp/RegWriteW -add wave -hex /testbench/dut/core/ebu/ebu/ReadDataW -add wave -hex /testbench/dut/core/ieu/dp/ResultW -add wave -hex /testbench/dut/core/ieu/dp/RdW -add wave -divider - -add wave -hex /testbench/dut/core/dmem/* -add wave -hex /testbench/dut/core/dmem/genblk1/* -add wave -divider - -add wave -hex -r /testbench/* diff --git a/sim/questa/wave-dos/default-waves.do b/sim/questa/wave-dos/default-waves.do deleted file mode 100644 index 2c7f0f755..000000000 --- a/sim/questa/wave-dos/default-waves.do +++ /dev/null @@ -1,65 +0,0 @@ -# default-waves.do -restart -f -delete wave /* -view wave - -# Diplays All Signals recursively -add wave /testbench/clk -add wave /testbench/reset -add wave -divider -#add wave /testbench/dut/core/ebu/ebu/IReadF -#add wave /testbench/dut/core/DataStall -add wave /testbench/dut/core/ICacheStallF -add wave /testbench/dut/core/StallF -add wave /testbench/dut/core/StallD -add wave /testbench/dut/core/StallE -add wave /testbench/dut/core/StallM -add wave /testbench/dut/core/StallW -add wave /testbench/dut/core/FlushD -add wave /testbench/dut/core/FlushE -add wave /testbench/dut/core/FlushM -add wave /testbench/dut/core/FlushW - -add wave -divider -add wave -hex /testbench/dut/core/ifu/PCF -add wave -hex /testbench/dut/core/ifu/PCD -add wave -hex /testbench/dut/core/ifu/InstrD -add wave /testbench/InstrDName -add wave -divider -add wave -hex /testbench/dut/core/ifu/PCE -add wave -hex /testbench/dut/core/ifu/InstrE -add wave /testbench/InstrEName -add wave -hex /testbench/dut/core/ieu/dp/SrcAE -add wave -hex /testbench/dut/core/ieu/dp/SrcBE -add wave -hex /testbench/dut/core/ieu/dp/ALUResultE -#add wave /testbench/dut/core/ieu/dp/PCSrcE -add wave -divider -add wave -hex /testbench/dut/core/ifu/PCM -add wave -hex /testbench/dut/core/ifu/InstrM -add wave /testbench/InstrMName -add wave /testbench/dut/uncore/uncore/ram/memwrite -add wave -hex /testbench/dut/uncore/uncore/HADDR -add wave -hex /testbench/dut/uncore/uncore/HWDATA -add wave -divider -add wave -hex /testbench/PCW -add wave -hex /testbench/InstrW -add wave /testbench/InstrWName -add wave /testbench/dut/core/ieu/dp/RegWriteW -add wave -hex /testbench/dut/core/ieu/dp/ResultW -add wave -hex /testbench/dut/core/ieu/dp/RdW -add wave -divider - -add wave -hex -r /testbench/* - -# appearance -TreeUpdate [SetDefaultTree] -WaveRestoreZoom {0 ps} {100 ps} -configure wave -namecolwidth 250 -configure wave -valuecolwidth 150 -configure wave -justifyvalue left -configure wave -signalnamewidth 0 -configure wave -snapdistance 10 -configure wave -datasetprefix 0 -configure wave -rowmargin 4 -configure wave -childrowmargin 2 -set DefaultRadix hexadecimal diff --git a/sim/questa/wave-dos/generic.do b/sim/questa/wave-dos/generic.do deleted file mode 100644 index 1d59f3fbe..000000000 --- a/sim/questa/wave-dos/generic.do +++ /dev/null @@ -1,23 +0,0 @@ -# default-waves.do -restart -f -delete wave /* -view wave - -# Diplays All Signals recursively -add wave /testbench/clk -add wave /testbench/reset -add wave -divider -add wave -hex -r /testbench/* - -# appearance -TreeUpdate [SetDefaultTree] -WaveRestoreZoom {0 ps} {300 ps} -configure wave -namecolwidth 350 -configure wave -valuecolwidth 150 -configure wave -justifyvalue left -configure wave -signalnamewidth 0 -configure wave -snapdistance 10 -configure wave -datasetprefix 0 -configure wave -rowmargin 4 -configure wave -childrowmargin 2 -set DefaultRadix hexadecimal diff --git a/sim/questa/wave-dos/linux-waves.do b/sim/questa/wave-dos/linux-waves.do deleted file mode 100644 index 102cfe24f..000000000 --- a/sim/questa/wave-dos/linux-waves.do +++ /dev/null @@ -1,207 +0,0 @@ -onerror {resume} -quietly WaveActivateNextPane {} 0 -add wave -noupdate -divider -add wave -noupdate /testbench/clk -add wave -noupdate /testbench/reset -add wave -noupdate -radix decimal /testbench/errorCount -add wave -noupdate -radix decimal /testbench/InstrCountW -add wave -noupdate -divider Stalls_and_Flushes -add wave -noupdate /testbench/dut/core/StallF -add wave -noupdate /testbench/dut/core/StallD -add wave -noupdate /testbench/dut/core/StallE -add wave -noupdate /testbench/dut/core/StallM -add wave -noupdate /testbench/dut/core/StallW -add wave -noupdate /testbench/dut/core/FlushD -add wave -noupdate /testbench/dut/core/FlushE -add wave -noupdate /testbench/dut/core/FlushM -add wave -noupdate /testbench/dut/core/FlushW -add wave -noupdate -divider F -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCF -add wave -noupdate -divider D -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCD -add wave -noupdate /testbench/InstrDName -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrD -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/InstrValidD -add wave -noupdate -divider E -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCE -add wave -noupdate /testbench/InstrEName -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/InstrValidE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcAE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/SrcBE -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ALUResultE -add wave -noupdate -divider M -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/PCM -add wave -noupdate /testbench/InstrMName -add wave -noupdate /testbench/textM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ifu/InstrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/InstrValidM -add wave -noupdate -radix hexadecimal /testbench/dut/core/lsu.bus.dcache/MemPAdrM -add wave -noupdate -radix hexadecimal /testbench/dut/core/lsu.bus.dcache/MemRWM -add wave -noupdate /testbench/dut/core/lsu.bus.dcache/WriteDataM -add wave -noupdate -radix hexadecimal /testbench/dut/core/lsu.bus.dcache/ReadDataM -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/DTLBWalk -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/BasePageTablePPN -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/CurrentPPN -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/MemWrite -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/Executable -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/Writable -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/Readable -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/Valid -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/Misaligned -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/MegapageMisaligned -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/ValidPTE -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/LeafPTE -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/ValidLeafPTE -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/ValidNonLeafPTE -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/StartWalk -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/TLBMiss -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/PRegEn -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/NextPageType -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/SvMode -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/TranslationVAdr -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/WalkerState -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/NextWalkerState -add wave -noupdate -group Walker /testbench/dut/core/lsu/hptw/genblk1/InitialWalkerState -add wave -noupdate -group LSU -r /testbench/dut/core/lsu/* -add wave -noupdate -group DCache -r /testbench/dut/core/lsu.bus.dcache/* -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/clk -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/reset -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/StallW -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/UnsignedLoadM -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/AtomicMaskedM -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/Funct7M -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/InstrPAdrF -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/InstrReadF -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/InstrRData -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/InstrAckF -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/DCtoAHBPAdrM -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/DCtoAHBReadM -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/DCtoAHBWriteM -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/DCtoAHBWriteData -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/DCfromAHBReadData -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/MemSizeM -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/DCfromAHBAck -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HRDATA -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HREADY -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HRESP -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HCLK -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HRESETn -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HADDR -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HWDATA -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HWRITE -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HSIZE -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HBURST -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HPROT -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HTRANS -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HMASTLOCK -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HADDRD -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HSIZED -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HWRITED -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/GrantData -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/AccessAddress -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/ISize -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HRDATAMasked -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/ReadDataM -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/HRDATANext -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/CapturedHRDATAMasked -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/WriteData -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/IReady -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/DReady -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/CaptureDataM -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/CapturedDataAvailable -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/BusState -add wave -noupdate -group EBU /testbench/dut/core/ebu/ebu/NextBusState -add wave -noupdate -divider W -add wave -noupdate -radix hexadecimal /testbench/PCW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/c/InstrValidW -add wave -noupdate /testbench/textM -add wave -noupdate /testbench/dut/core/ieu/dp/ReadDataW -add wave -noupdate -radix hexadecimal /testbench/dut/core/ieu/dp/ResultW -add wave -noupdate -group RF /testbench/dut/core/ieu/dp/RegWriteW -add wave -noupdate -group RF -radix unsigned /testbench/dut/core/ieu/dp/RdW -add wave -noupdate -group RF /testbench/dut/core/ieu/dp/regf/wd3 -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[2]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[3]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[4]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[5]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[6]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[7]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[8]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[9]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[10]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[11]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[12]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[13]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[14]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[15]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[16]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[17]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[18]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[19]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[20]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[21]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[22]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[23]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[24]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[25]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[26]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[27]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[28]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[29]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[30]} -add wave -noupdate -group RF -radix hexadecimal {/testbench/dut/core/ieu/dp/regf/rf[31]} -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/MSTATUS_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/MCOUNTINHIBIT_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/MCOUNTEREN_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/MIDELEG_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/MIP_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/MIE_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MEPC_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVEC_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTEREN_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCOUNTINHIBIT_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MEDELEG_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MIDELEG_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MSCRATCH_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MCAUSE_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MTVAL_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/SSTATUS_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/SCOUNTEREN_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/SIP_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csri/SIE_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SEPC_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/STVEC_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SCOUNTEREN_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SEDELEG_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SIDELEG_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrs/SATP_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/USTATUS_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/UEPC_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/UTVEC_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/UIP_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrn/UIE_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/PMPCFG_ARRAY_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/PMPADDR_ARRAY_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csrm/MISA_REGW -add wave -noupdate -group CSR -radix hexadecimal /testbench/dut/core/priv/csr/genblk1/csru/FRM_REGW -add wave -noupdate -divider -add wave -hex -r /testbench/* -TreeUpdate [SetDefaultTree] -WaveRestoreCursors {{Cursor 8} {42752672 ns} 1} {{Cursor 2} {42752634 ns} 0} -quietly wave cursor active 2 -configure wave -namecolwidth 250 -configure wave -valuecolwidth 297 -configure wave -justifyvalue left -configure wave -signalnamewidth 1 -configure wave -snapdistance 10 -configure wave -datasetprefix 0 -configure wave -rowmargin 4 -configure wave -childrowmargin 2 -configure wave -gridoffset 0 -configure wave -gridperiod 1 -configure wave -griddelta 40 -configure wave -timeline 0 -configure wave -timelineunits ns -update -WaveRestoreZoom {42752559 ns} {42752771 ns} diff --git a/sim/questa/wave-dos/peripheral-waves.do b/sim/questa/wave-dos/peripheral-waves.do deleted file mode 100644 index 3f3974dc2..000000000 --- a/sim/questa/wave-dos/peripheral-waves.do +++ /dev/null @@ -1,118 +0,0 @@ -# peripheral-waves.do - -restart -f -delete wave /* -view wave - -# general stuff -add wave /testbench/clk -add wave /testbench/reset -add wave -divider - -#add wave /testbench/dut/core/DataStall -add wave /testbench/dut/core/StallF -add wave /testbench/dut/core/StallD -add wave /testbench/dut/core/StallE -add wave /testbench/dut/core/StallM -add wave /testbench/dut/core/StallW -add wave /testbench/dut/core/FlushD -add wave /testbench/dut/core/FlushE -add wave /testbench/dut/core/FlushM -add wave /testbench/dut/core/FlushW -add wave -divider - -add wave -hex /testbench/dut/core/ifu/PCF -add wave -hex /testbench/dut/core/ifu/PCD -add wave -hex /testbench/dut/core/ifu/InstrD -add wave -hex /testbench/dut/core/ieu/c/InstrValidD -add wave /testbench/InstrDName -add wave -divider -add wave -hex /testbench/dut/core/ifu/PCE -add wave -hex /testbench/dut/core/ifu/InstrE -add wave -hex /testbench/dut/core/ieu/c/InstrValidE -add wave /testbench/InstrEName -add wave -hex /testbench/dut/core/ieu/dp/SrcAE -add wave -hex /testbench/dut/core/ieu/dp/SrcBE -add wave -hex /testbench/dut/core/ieu/dp/ALUResultE -#add wave /testbench/dut/core/ieu/dp/PCSrcE -add wave /testbench/dut/core/mdu/genblk1/div/DivStartE -add wave /testbench/dut/core/mdu/DivBusyE -add wave -hex /testbench/dut/core/mdu/genblk1/div/RemM -add wave -hex /testbench/dut/core/mdu/genblk1/div/QuotM - -add wave -divider -add wave -hex /testbench/dut/core/ifu/PCM -add wave -hex /testbench/dut/core/ifu/InstrM -add wave -hex /testbench/dut/core/ieu/c/InstrValidM -add wave /testbench/InstrMName -add wave /testbench/dut/uncore/uncore/ram/memwrite -add wave -hex /testbench/dut/core/WriteDataM -add wave -hex /testbench/dut/core/lsu.bus.dcache/MemPAdrM -add wave -hex /testbench/dut/core/lsu.bus.dcache/WriteDataM -add wave -hex /testbench/dut/core/lsu.bus.dcache/ReadDataM -add wave -divider -add wave -hex /testbench/PCW -#add wave -hex /testbench/InstrW -#add wave -hex /testbench/dut/core/ieu/c/InstrValidW -#add wave /testbench/InstrWName -add wave -hex /testbench/dut/core/ReadDataW -add wave -hex /testbench/dut/core/ieu/dp/ResultW -add wave -hex /testbench/dut/core/ieu/dp/RegWriteW -add wave -hex /testbench/dut/core/ieu/dp/WriteDataW -add wave -hex /testbench/dut/core/ieu/dp/RdW -add wave -divider -add wave -hex /testbench/dut/core/priv/csr/TrapM -add wave -hex /testbench/dut/core/priv/csr/UnalignedNextEPCM -add wave -hex /testbench/dut/core/priv/csr/genblk1/csrm/WriteMEPCM -add wave -hex /testbench/dut/core/priv/csr/genblk1/csrm/MEPC_REGW - -add wave -divider RegFile -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[1] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[2] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[3] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[4] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[5] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[6] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[7] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[8] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[9] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[10] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[11] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[12] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[13] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[14] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[15] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[16] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[17] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[18] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[19] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[20] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[21] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[22] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[23] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[24] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[25] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[26] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[27] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[28] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[29] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[30] -add wave -hex /testbench/dut/core/ieu/dp/regf/rf[31] - -# peripherals -add wave -divider PLIC -add wave -hex /testbench/dut/core/priv/csr/TrapM -add wave -hex /testbench/dut/uncore/uncore/plic/plic/* -add wave -hex /testbench/dut/uncore/uncore/plic/plic/intPriority -add wave -hex /testbench/dut/uncore/uncore/plic/plic/pendingArray -add wave -divider UART -add wave -hex /testbench/dut/uncore/uncore/uart/uart/u/* -add wave -divider GPIO -add wave -hex /testbench/dut/uncore/uncore/gpio/gpio/* -#add wave -divider -#add wave -hex /testbench/dut/core/ebu/ebu/* -#add wave -divider -#add wave -divider - -# everything else -add wave -hex -r /testbench/*