From the cva6 README:
CVA6 is a 6-stage, single issue, in-order CPU which implements the 64-bit RISC-V instruction set. It fully implements I, M, A and C extensions as specified in Volume I: User-Level ISA V 2.3 as well as the draft privilege extension 1.10. It implements three privilege levels M, S, U to fully support a Unix-like operating system. Furthermore it is compliant to the draft external debug spec 0.13.
CVA6 is an open-source CPU core, widely used in academia and industry. It is primarily written by Florian Zaruba, which makes its code style and organization very consistent.
This repository includes several labs aimed at teaching advanced architecture techniques. To use this repository, you will need to:
- Ensure you are on a Linux/WSL2 machine.
- Create an ssh key for GitHub and add it to GitHub.
- Follow the GitHub setup guide
All necessary tools have been installed to linux.engr.ucsb.edu. Therefore we recommend using those machines to expedite the setup. If you want to run CVA6 simulations using your local Linux/WSL2 machine, you will need to install everything yourself.
- Set
$RISCV
to wherever you want the tools to be installed to. i.e. runRISCV=~/riscv-tools
- Run
./cva6/ci/setup.sh
. (If you get an error, you may need to rerun parts of the script manually). - Install the OSS CAD Suite. You can do this by un-taring the latest release to a
"~/Utils/oss-cad-suite"
directory. - Add the following to your
"~/.bashrc"
, and replace the values of the 3 environment variables:
# ECE 154B local machine ~/.bashrc additions
# Author: Ethan Sifferman <[email protected]>
# Purpose: Configure riscv64-unknown-elf-gcc, fesvr, verilator-4.110, gtkwave, pip user
export RISCV_ROOT=<REPLACE THIS WITH YOUR RISCV ROOT>
export VERILATOR_ROOT=<REPLACE THIS WITH YOUR VERILATOR 4.110 ROOT>
export OSS_CAD_SUITE=<REPLACE THIS WITH YOUR OSS CAD SUITE ROOT>
export PATH=$RISCV_ROOT/bin:$VERILATOR_ROOT/bin:$PATH:$OSS_CAD_SUITE/bin:~/.local/bin
# end ECE 154B
Add the following to your "~/.bashrc"
:
# ECE 154B linux.engr ~/.bashrc additions
# Author: Ethan Sifferman <[email protected]>
# Purpose: Configure riscv64-unknown-elf-gcc, fesvr, verilator-4.110, gtkwave, modelsim, pip user
export RISCV_ROOT=/ece/riscv
export VERILATOR_ROOT=/ece/verilator-4.110
export MODEL_TECH=/ece/mentor/ModelSimSE-10.6e/modeltech/bin
export [email protected]
export PATH=$MODEL_TECH:$RISCV_ROOT/bin:$VERILATOR_ROOT/bin:$PATH:/ece/oss-cad-suite/bin:~/.local/bin
# end ECE 154B
Before starting CVA6 simulations on a new terminal session, ensure proper environment configuration by running source setup.sh
.
After setup is completed, you should be able to run CVA6 simulations. The primary way to run CVA6 simulations is to build and load an ELF file. An ELF file is the standard file format used for Linux executables, so this means we can write any C/C++/RISC-V assembly program, and gcc/g++ will output a binary readable by CVA6. (You can see how the Verilog processes the ELF file here and here).
You can see example programs in "./programs/examples"
. You can compile the program to an ELF file using the "./programs/Makefile"
. To use the Makefile, run cd programs
, then run make <PATH TO PROGRAM>.elf
, i.e. make examples/asm.elf
. (Be sure that you've run source setup.sh
first.)
- Ensure you've run
source setup.sh
cd cva6
make verilate DEBUG=1 TRACE_FAST=1
./work-ver/Variane_testharness -v dump.vcd <PATH TO ELF>
(You can change the vcd filename to whatever you want.)- To view the waves, run
gtkwave dump.vcd
. (This should probably be done in another terminal to not interfere with running more simulations.) - Navigate to TOP.ariane_testharness.i_ariane.i_cva6 to see all the logic for the core.
- Once you've selected all the waves necessary for your lab, be sure to save your workspace using "File->Write Save File", so next time you don't have to reopen all necessary waves again.