Why did I start this? It's obvious - people need simple and inexpensive RISC-V computer to play with to know new RISC generation better - it's a future anyway :)
Project was started on November 18, 2018 when I played with very compact emulator of RV32I[MA] that @Frank Buss shared in Hackaday FPGA chat:
https://gist.github.com/FrankBuss/c974e59826d33e21d7cad54491ab50e8
it's based on RISC-V emulator from Fabrice Bellard ( https://bellard.org/tinyemu/ ) but supports only RV32I subsystem (with optional RV32M and RV32A subsystems) and turned into single text file with 1.5 thousand lines of C code. It's even able to pass all 55 compliance tests for RV32I and run Zephyr RTOS examples! So I started from this little emulator with the same MIT-license and converted it to pure C:
https://gitlab.com/nedopc/npc5
Then I wrote my own Verilog implementation of RV32I for UPDuino v2.0 board with iCE40UP5K FPGA:
data:image/s3,"s3://crabby-images/a0ec3/a0ec3c637c93a009037ec175a37bf89a21e55367" alt=""
Documentation has some mistakes, so I fix them as I find them:
data:image/s3,"s3://crabby-images/1cfb3/1cfb3e62fe28c8d5b7a1b28649e462acf4a1cfa0" alt=""
RV32I subset is only 1 page of instructions (captured from official spec):
data:image/s3,"s3://crabby-images/b4e29/b4e2980610edb5ae806aa515e9b3d34f7a7b106f" alt=""
As you can see opcode is in 7 lowest bits - as we can see bits 1 and 0 are always 1s because of interesting approach to instruction set extension:
data:image/s3,"s3://crabby-images/156cb/156cbd8890864346996f7c48db05a41dfb803350" alt=""
Also they have divided instructions to families this way (highlighted what was used for RV32I):
data:image/s3,"s3://crabby-images/2fe0f/2fe0f5dc000a206696c5ef0a54c5edddfe0d4ae9" alt=""