Improve exception dumps and general debug info, make the emulator capable of running the riscv ISA tests, and perform some general fixes i found while making it pass the tests for RV64I

This commit is contained in:
2025-12-30 20:18:23 +01:00
parent 6a0e5e63c1
commit 5a383956c9
6 changed files with 36 additions and 7 deletions

View File

@@ -131,6 +131,7 @@ pub(crate) fn find_and_exec(instr: Instruction, core: &mut Core) -> Result<(), E
// FENCE is just implemented as a SeqCst fence always here
// I dont yet care about the potential performance issue this may bring
std::sync::atomic::fence(std::sync::atomic::Ordering::SeqCst);
core.advance_pc();
Ok(())
}
_ => illegal(instr),
@@ -142,7 +143,15 @@ pub(crate) fn find_and_exec(instr: Instruction, core: &mut Core) -> Result<(), E
Err(ExceptionType::EnvironmentCallFromMMode.with_no_value())
}
(0b000, 0b000000000001, 0, 0) => Err(ExceptionType::Breakpoint.with_no_value()),
_ => illegal(instr),
_ => {
// Temporarily allowing unrecognized instructions here to be able to run
// the official ISA tests, which perform CSR operations but work just fine
// without them
eprintln!("Unrecognized instruction within SYSTEM opcode");
dbg!(instr);
core.advance_pc();
Ok(())
}
},
_ => illegal(instr),
}