Skip to content

Latest commit

 

History

History
140 lines (95 loc) · 5.09 KB

README.md

File metadata and controls

140 lines (95 loc) · 5.09 KB

HEMU

HEMU 🚀 - A Rust Riscv Emulator

HEMU (HDU Emulator) is a RISCV64 processor simulator written in Rust. It draws inspiration from NEMU(NJU emulator)'s design philosophy and rewrites the logic of the processor using Rust, making the entire system more secure and efficient. Currently, it is an ISA-level simulator but has plans to expand into a cycle-level simulator in the future. At present, HEMU only supports the RISCV64IM instruction set architecture, but there are intentions to continue adding more instruction sets.

Installation ⚙️

To install HEMU, you will need to have Rust installed on your machine. You can download and install Rust using the official installer from rust-lang.org.

Once Rust is installed, you can clone the HEMU repository from Github:

git clone https://github.com/Clo91eaf/hemu.git

Runing

To run HEMU, you can use the following command:

cargo run -- -k <path_to_binary>

Where <path_to_binary> is the path to the binary file that you want to run. For example:

cargo run -- -k ./dependencies/tests/bin/am-tests/add

Difftest

Verilator file should be placed in the ./dependencies/rtl directory. then you can use the following command:

cargo clean && cargo run -- -k ./dependencies/tests/bin/am-tests/add --diff

To build the verilator file and ffi, cargo clean is necessary when you change the verilator file.

Difftest With Tui

if you want to run difftest with TUI, you can use the following command:

cargo clean && cargo run -- -k ./dependencies/tests/bin/am-tests/add --diff --tui

In Tui, you can press 'c' to continue, 's' to step, 'q' to quit.

CLI usage

Usage: hemu [OPTIONS] --kernel

Options: -k, --kernel A kernel ELF image without headers -f, --file A raw disk image -l, --log specify the log level. Including "error", "warn", "info", "debug", "trace" [default: info] -d, --diff Enable difftest --tui Enable tui --trace Enable wave trace -h, --help Print help -v, --version Print version

Run opensbi

You should run HEMU first to generate the dtb with whatever binary. Then you can run HEMU with opensbi, you can use the following command:

# prepare the opensbi
git clone https://github.com/riscv-software-src/opensbi.git
# build the opensbi
cd opensbi
make PLATFORM=generic CROSS_COMPILE=riscv64-unknown-elf- FW_FDT_PATH=<path/to>/hemu/dependencies/opensbi/hemu.dtb
# run the opensbi
cp build/platform/generic/firmware/fw_payload.elf <path/to>/hemu
cd <path/to>/hemu
cargo run -- -k ./resources/opensbi.bin

Testing

To test HEMU, you can use the following command:

cargo test --test <tests>

Where <tests> is the name of the test that you want to run. For example:

cargo test --test am-tests

Why rust ❓

There are several potential benefits to using Rust to rewrite Nemus's logic:

  1. Memory safety: Rust is designed to prevent memory-related bugs such as buffer overflows, null pointer dereferences, and use-after-free errors. By using Rust instead of C, the risk of these types of bugs is greatly reduced.

  2. Concurrency: Rust has excellent support for concurrency, which means that HEMU could potentially support running multiple threads or processes simultaneously.

  3. Performance: Rust is known for its performance, and code written in Rust can often be faster than equivalent code written in other languages. This could make HEMU faster than Nemus in some cases.

  4. Ecosystem: Rust has a growing ecosystem of libraries and tools that can be used to develop HEMU. Taking advantage of this ecosystem could make development faster and easier.

  5. Maintainability: Rust's syntax and features promote code that is easy to read, understand, and maintain. Writing HEMU in Rust may make it easier for future developers to modify and build upon the codebase.

Progress 📈

  • RISCV64IM instruction set architecture

  • Pass am-tests

  • RISCV64IMAZicsr instruction set architecture

  • Pass riscv-tests

  • Add CI

  • Support for opensbi

  • Add TUI for debugging

  • Added support for peripherals.

  • Added interrupt handling mechanisms.

  • Added support for TLB (Translation Lookaside Buffer).

  • Simulated a bus.

  • Support for Linux

  • LA32 instruction set architecture

  • MIPS32 instruction set architecture

  • Designed a cycle-level processor.

  • Simulated cache functionality.

  • Add some emoji to make it look better.

  • Write document.

Contributing 🤝

Contributions to HEMU are welcome! If you find a bug or have a feature request, please open an issue on Github. If you would like to contribute code, you can make a fork of the repository and submit a pull request.

Before submitting a pull request, please ensure that your code adheres to the project's coding standards and passes all tests.

License 📜

HEMU is released under the MIT license. See LICENSE for more information.