YARS - Yet Another RISC-V Simulator
What is YARS
Yars is a RISC-V ISA Simulator, implements a functional model of one
(currently) RISC-V processor. The development is currently focusing on
RV64I extension only.
Why am I writing this simulator?
The golden reference, spike, has its source code complicated and
difficult to read mainly because it is written in C++ which contains
a lot of magical macros. Uhh... I know it's for performance, but it
also makes someone who wants to know how a RISC-V cpu works confused.
So, I'm teaching myself to understand the ISA by reinventing the wheel.
Why Golang?
Isn't it exciting to write a big project in a new language? Okay it's
just a joke... Here are the reasons why I decided to use Golang:
- Golang has no classes, no macros, no automatic type conversions,
which means no magic is happening, everything you see does the most
obvious thing as it should. It's a "Code Readers Friendly Language".
- It compiles REALLY fast, which saves you a lot of time from waiting
the project recompiled.
- It generates code that runs fairly fast, enough to simulate small
code segments like 50~100 lines of asm in a reasonable time.
About Documentation
My goal is to annotate every important line so I don't have to keep
switching between the codes and the docs. But this is not done yet...
Features Implemented
- A functional memory.
- An elf loader which can load program from an elf file.
- Very limited HTIF support for running
riscv-tests,
can resolve 'fromhost' and 'tohost' symbols. Writing a 1 to memory
address indicated by 'tohost' will cause YARC print "PASS!!!" and
exit with code 0, write numbers other than 1 will cause YARC exit
with 1.
- A processor that reads instructions and executes them.
- All unprivileged instructions.
- Control and Status Register function and related instructions (But
not all CSRs defined in the spec are implemented, see CSRs Section)
- Machine, Supervisor, and Machine Privileges
- Exceptions support
Features To Be Implemented
- Support interruption
- Detailed annotations
CSRs
Accessible CSRs
Access CSRs other than these will cause a panic.
- misa
- mvendorid
- marchid
- mimpid
- mhartid
- mstatus
- mtvec
- medeleg
- mideleg
- mie
- mcause
- mepc
- stvec
- sepc
- scause
- stval
- mtval
- satp
- pmpaddr0
- pmpcfg0
Really functional CSRs
- misa
- mvendorid
- marchid
- mimpid
- mhartid
- mstatus
- mtvec - only support direct mode
- medeleg
- mideleg
- mie
- mcause
- mepc
- stvec
- sepc
- scause
- stval
- mtval
References
- User-Level ISA Specification
and
Privileged ISA Specification
of RISC-V published by RISC-V Foundation Technical Committee.
- Spike, the official RISC-V
simulator.
- Documentation of Spike (partially)
The owner of this repo really has some good works in his other repos.
- FPGA開発日記 A blog of detailed illustrations of RISC-V in Japanese.
- riscv-sodor, an educational
processor collection written in Chisel by ucb-bar.