Directory | Description |
---|---|
.github | CI specifications in GitHub Actions language |
doc | Auxiliary documentation |
examples | C and Rust examples to run on device |
scripts | Renode & Shell scripts to run the virtual platform |
vp | The Renode virtual platform |
- Renode 1.14 (exactly 1.14), the high-level hardware simulator https://github.com/renode/renode
- For C-language validation tests:
- RISC-V GCC compiler toolchain
- CMake 3.10 or more recent
- For Rust-language validation tests & BSP:
- Rust https://rustup.rs/, MSRV 1.81
- Codegen backend for target cores
- HPC
rustup target add riscv64imac-unknown-none-elf
- SysCtrl (VP)
rustup target add riscv32im-unknown-none-elf
- SysCtrl (ASIC)
rustup target add riscv32imc-unknown-none-elf
- HPC
- For Renode & Rust command automation (optional):
- Install
just
, the command runner https://github.com/casey/just, a make-like command runner that is used to automate some of the more complicated workflows.
- Install
Requires GCC, CMake, Renode.
cd examples/hpc-c/hello-hpc
just run
If you're unable to use just
, you might review the Justfile
in that directory for the correct
set of CMake commands to run. File an issue if you run into a problem.
Requires Rust, Renode.
cd examples/headsail-bsp
cargo run --example uart0 -Fvp -Fhpc-rt -Fpanic-apb-uart0 --target riscv64imac-unknown-none-elf
or if you're a just
user:
just run uart0
Requires Rust, Renode.
cd examples/hpc/hello-dla
cargo run --example dla
You'll need to have built the binaries prior to running Robot Tests.
renode-test scripts/robot/hello_dla.robot
Requires Renode and an ELF file. You could probably run the OpenSBI firmware image with this process as well.
./scripts/run_on_hpc.sh $bin
./scripts/run_on_sysctrl.sh $bin
I've set up a relatively convenient build using OpenOCD scripts & Justfiles.
-
To boot HPC, you will need to be connected on SysCtrl via OpenOCD.
cd examples/headsail-bsp/openocd openocd -f sysctrl.cfg
-
On another terminal, use a
just
to run a bootloader to initialize HPC (remember to press 'c' to make the program run):cd examples/sysctrl/hello-sysctrl just asic init_hpc
-
Then disconnect OpenOCD from SysCtrl, and disconnect and re-connect the JTAG_TRST jumper cable.
-
Connect to HPC via OpenOCD (on the first terminal):
openocd -f hpc.cfg
Connection to HPC sometimes fails once before succeeding, so if at first you don't succeed, try again!
-
On a third terminal, run a program on HPC
cd examples/hpc/hello-dla just asic apb_uart0
GDB might report "load failed" but you might be able to just 'c' it. It seems to work most of the time ":D"
You can replace the final step with any GDB command of the general form:
riscv64-unknown-elf-gdb -x connect-and-load.gdb your_binary_here
GDB scripts such as connect-and-load.gdb
may be sprinkled wherever they've been found
convenient.