#instructions #memory #risc-v #basic #arithmetic #cpu-memory #built

app riscv_simulator

A RISC-V simulator built in Rust, supporting basic arithmetic, memory, and control-flow instructions

8 stable releases

1.0.7 Dec 4, 2024
1.0.6 Dec 3, 2024
1.0.3 Dec 2, 2024
1.0.2 Dec 1, 2024

#3 in Simulation

31 downloads per month

MIT license

12KB
240 lines

RISC-V Simulator

Overview

A command-line tool that simulates the execution of basic RISC-V assembly instructions, allowing you to:

Simulate a CPU with 32 general-purpose registers. Manage memory operations, including loads and stores. Handle basic instructions such as arithmetic operations, jumps, and halts. Utilize a cache for improved performance. The project is built in Rust, showcasing modular design and efficient code structure.

Features

Instruction Support: Arithmetic (add, sub). Memory Access (load, store). Control Flow (jump, halt). Customizable Memory and Cache Sizes: Default: 1KB memory and 64-entry cache. Modular Architecture: CPU, Memory, Cache, and Instruction sets are modularized for clarity and scalability. Error Handling: Graceful handling of file read errors and invalid instructions.

Project Structure

riscv_sim/
├── Cargo.toml               # Project dependencies and metadata
└── src/
    ├── cache_mod/           # Cache module
    │   └── mod.rs           # Cache implementation
    ├── cpu_mod/             # CPU module
    │   └── mod.rs           # CPU implementation
    ├── instr_mod/           # Instruction module
    │   └── mod.rs           # Instruction enums
    ├── mem_mod/             # Memory module
    │   └── mod.rs           # Memory implementation
    └── main.rs              # Main entry point

Getting Started

Prerequisites Rust (Install via Rustup) Installation Clone the repository:

git clone https://github.com/yourusername/riscv_sim.git
cd riscv_sim

Build the project:

cargo build

###Usage Run the simulator with a RISC-V program file:

cargo run -- --file=<path_to_program_file>

Example

Given a program file example.riscv:

add 1 2 3       # x1 = x2 + x3
sub 4 5 6       # x4 = x5 - x6
load 7 10       # x7 = memory[10]
store 7 15      # memory[15] = x7
jump 20         # pc = 20
halt            # Stop execution

Run:

cargo run -- --file=example.riscv

Example Output

Executing instruction: add x1, x2, x3
Executing instruction: sub x4, x5, x6
Executing instruction: load x7, memory[10]
Executing instruction: store x7, memory[15]
Executing instruction: jump to address 20
CPU halted.

Customization

You can customize: Memory Size: Edit Memory::new(size) in main.rs. - and - Cache Size: Edit Cache::new(size) in main.rs.

License

This project is licensed under the MIT License. See LICENSE for details.

Author

Ben Santora - Cape Ann MA

Dependencies

~1–1.7MB
~31K SLoC