Initial commit
This commit is contained in:
28
Libs/RiscV/NEORV32/sw/isa-test/port-neorv32/README.md
Normal file
28
Libs/RiscV/NEORV32/sw/isa-test/port-neorv32/README.md
Normal file
@@ -0,0 +1,28 @@
|
||||
# NEORV32 Port for running the RISC-V Architecture Tests
|
||||
|
||||
|
||||
The following tasks are executed by the device makefiles:
|
||||
|
||||
* replace the original processor's IMEM rtl file by a simulation-optimized IMEM (ROM!)
|
||||
* `sed` command is used to modify the default testbench (`neorv32/sim/neorv32_tb.simple.vhd`):
|
||||
* enable/disable the required `CPU_EXTENSION_RISCV_xxx` VHDL configuration generics in the testbench (`neorv32/sim/neorv32_tb.simple.vhd`)
|
||||
* set the processor memory configuration
|
||||
* compile test code and install application image to processor's `rtl/core` folder
|
||||
* compilation uses the `link.imem_rom.ld` linker script as default; code (the test code) is executed from simulation-optimized IMEM (which is read-only); data including signature is stored to DMEM
|
||||
* certain areas in the DMEM are initialized using port code in `model_test.h` (`RVTEST` = 0xbabecafe and `SIGNATURE` = 0xdeadbeef); can be disabled using `RISCV_TARGET_FLAGS=-DNEORV32_NO_DATA_INIT`
|
||||
* the processor is simulated using the default testbench
|
||||
* the results are dumped via the SIM_MODE feature of UART0
|
||||
* the according code can be found in the `RVMODEL_HALT` macro in `model_test.h`
|
||||
* data output (the "signature") is zero-padded to be always a multiple of 16 bytes
|
||||
|
||||
|
||||
**Notes**
|
||||
|
||||
:warning: The `Zifencei` test requires the r/w/e capabilities of the original IMEM rtl file.
|
||||
Hence, the original file is restored for this test. Also, this test uses `link.imem_ram.ld` as linker script since the
|
||||
IMEM is used as RAM to allow self-modifying code.
|
||||
|
||||
:information_source: The `RVMODEL_BOOT` macro in `model_test.h` provides a simple "dummy trap handler" that just advances
|
||||
to the next instruction. This trap handler is required for some `C` tests as the NEORV32 will raise an illegal instruction
|
||||
exception for **all** unimplemented instructions. The trap handler can be overriden (by changing `mtval` CSR) if a test
|
||||
uses the defualt trap handler of the test framework.
|
||||
Reference in New Issue
Block a user