13 releases (6 stable)

1.3.1 Dec 27, 2024
1.2.0 Oct 14, 2024
1.0.1 Sep 28, 2024
1.0.0-beta.3 Aug 16, 2024
0.1.3 Oct 17, 2023

#307 in Encoding

Download history 350/week @ 2024-09-24 391/week @ 2024-10-01 384/week @ 2024-10-08 194/week @ 2024-10-15 76/week @ 2024-10-22 428/week @ 2024-10-29 89/week @ 2024-11-05 125/week @ 2024-11-12 71/week @ 2024-11-19 64/week @ 2024-11-26 93/week @ 2024-12-03 242/week @ 2024-12-10 355/week @ 2024-12-17 720/week @ 2024-12-24 385/week @ 2024-12-31 375/week @ 2025-01-07

1,875 downloads per month
Used in l2r0-profiler-host

MIT license

140KB
3.5K SLoC

raki

Rust
RISC-V instruction decoder written in Rust.

  • Both 32/64bit support.
  • Support rv32/64imac, Zicsr, Zifencei extensions.
  • Implement Display trait for formatting.

Usage

Call the decode as u16/u32 method.

use raki::{BaseIOpcode, Decode, Instruction, Isa, OpcodeKind};

fn main() {
    let inst_bytes: u32 = 0b1110_1110_1100_0010_1000_0010_1001_0011;
    let inst: Instruction = match inst_bytes.decode(Isa::Rv32) {
        Ok(inst) => inst,
        Err(e) => panic!("decoding failed due to {e:?}"),
    };

    assert_eq!(inst.opc, OpcodeKind::BaseI(BaseIOpcode::ADDI));
    println!("{inst}");
}
// --output--
// addi t0, t0, -276

Support

  • BaseI (RV32I, RV64I)
  • M
  • A
  • D
  • Q
  • C
  • B
  • P
  • V
  • H
  • Zicsr
  • Zifencei
  • Zicntr
  • Zicfiss
  • Priv (Now only supports mret, sret, wfi, sfence.vma)

License

This crate is licensed under MIT.
See LICENSE for details.

Contribution

All contributions are welcome, including issues, pull requests, questions, etc... See CONTRIBUTING.md for details.

No runtime deps