The same thing but in C
Find a file
Minecon724 52882cb6a6
All checks were successful
/ deploy (push) Successful in 1m17s
JAL fix and other stuff
2024-10-22 15:56:53 +02:00
.forgejo/workflows Add actions, support older gcc 2024-10-19 20:29:00 +02:00
include work 2024-10-21 19:42:27 +02:00
programs JAL fix and other stuff 2024-10-22 15:56:53 +02:00
src JAL fix and other stuff 2024-10-22 15:56:53 +02:00
.gitignore initial commit 2024-10-14 19:48:56 +02:00
Makefile Add actions, support older gcc 2024-10-19 20:29:00 +02:00
README.md Not a thing 2024-10-21 19:43:12 +02:00
remake.sh It now runs a program 2024-10-16 15:34:06 +02:00
unpriv-isa-asciidoc.html JAL fix and other stuff 2024-10-22 15:56:53 +02:00

RISC-V (rv32i) emulator in C
This is just for me to understand how all this works, and to learn something new.
So don't use it.

Example programs:

  • return.bin returns -1094647826 (puts it to register 10)
  • return2.elf returns a different value with more steps. if it returns DADD, something's wrong

Emulator exit codes:

  • -1 - reached end of address space
  • 0 - never happens
  • 1 - invalid opcode
  • 2 - illegal instruction argument (like funct3)

Compile:

  1. Dependencies: libelf
  2. make # should display no warnings
    
  3. Executable is build/criscv

Note: Prebuilts for x86_64 & aarch64 Linux are available here, pick the top one, download the artifact, and keep the one for your architecture.
Those are dynamic, meaning you still need the dependencies! See compile step 1 above.

Compile programs:

  1. Get the toolchain obviously
  2. riscv32-unknown-elf-gcc -ffreestanding -nostdlib -Ttext=0x0 -e main -O0 -o program.elf program.c
    
  3. program.bin is the binary file with the program, pass it as an argument

rv32i, ilp32 compatible toolchain for 64bit Linux: download adaa74f263dcba430da588b1109bc3b90bd90a84c67b06213bd03a7bbacd1a2a
Or just the stuff necessary to make a binary file: download 55e79dff7ba4093dedb8151461508fc157525ad89615d49d737845af03d1643f
Those were compiled with ./configure --prefix=$(pwd)/../toolchain --with-arch=rv32i --with-abi=ilp32 and make