Skip to content

simlar-0/risc-v-disassembler

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

RISC-V Disassembler

A RISC-V disassembler that translates machine code into a Rust enum, with the main purpose of being used in Symex symbolic execution engine.

Supported / Planned Instruction Sets

  • RV32I Base Integer Instruction Set
  • RV64I Base Integer Instruction Set
  • RV32E Base Integer Instruction Sets
  • RV64E Base Integer Instruction Sets
  • RV32C Compressed Extension

Output Format (Example)

pub enum ParsedInstruction32 {
    add {
        rd: String,
        rs1: String,
        rs2: String,
    },
    addi {
        rd: String,
        rs1: String,
        imm: i32,
    },
}

Example Usage

 use risc_v_disassembler::{
     parse,
     ParsedInstruction32,
     parsed_instructions::*
 };

 let bytes = [0x93, 0x00, 0x51, 0x00];
 let is_big_endian = false;
 let use_abi_register_names = false;
 let parsed_instruction = parse(&bytes, is_big_endian, use_abi_register_names).unwrap();

 assert_eq!(parsed_instruction, ParsedInstruction32::addi (addi {
     rd: "x1",
     rs1: "x2",
     imm: 5
 }));

Or using ABI register names:

 use risc_v_disassembler::{
     parse,
     ParsedInstruction32,
     parsed_instructions::*
 };

 let bytes = [0x93, 0x00, 0x41, 0x00];
 let is_big_endian = false;
 let use_abi_register_names = true;
 let parsed_instruction = parse(&bytes, is_big_endian, use_abi_register_names).unwrap();

 assert_eq!(parsed_instruction, ParsedInstruction32::addi (addi {
    rd: "ra",
    rs1: "sp",
    imm: 4
 }));

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 2

  •  
  •  

Languages