diff --git a/riscv/CHANGELOG.md b/riscv/CHANGELOG.md index da48a3f2..e43a01ad 100644 --- a/riscv/CHANGELOG.md +++ b/riscv/CHANGELOG.md @@ -16,6 +16,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/). - Use CSR helper macros to define `marchid` register - Re-use `try_*` functions in `mcountinhibit` - Use CSR helper macros to define `mcause` register +- Use CSR helper macros to define `medeleg` register ## [v0.12.1] - 2024-10-20 diff --git a/riscv/src/register/medeleg.rs b/riscv/src/register/medeleg.rs index 81de5baa..a23c28b4 100644 --- a/riscv/src/register/medeleg.rs +++ b/riscv/src/register/medeleg.rs @@ -1,98 +1,89 @@ //! medeleg register -/// medeleg register -#[derive(Clone, Copy, Debug)] -pub struct Medeleg { - bits: usize, +read_write_csr! { + /// `medeleg` register + Medeleg: 0x302, + mask: 0xb3ff, } -impl Medeleg { - /// Returns the contents of the register as raw bits - #[inline] - pub fn bits(&self) -> usize { - self.bits - } - +read_write_csr_field! { + Medeleg, /// Instruction Address Misaligned Delegate - #[inline] - pub fn instruction_misaligned(&self) -> bool { - self.bits & (1 << 0) != 0 - } + instruction_misaligned: 0, +} +read_write_csr_field! { + Medeleg, /// Instruction Access Fault Delegate - #[inline] - pub fn instruction_fault(&self) -> bool { - self.bits & (1 << 1) != 0 - } + instruction_fault: 1, +} +read_write_csr_field! { + Medeleg, /// Illegal Instruction Delegate - #[inline] - pub fn illegal_instruction(&self) -> bool { - self.bits & (1 << 2) != 0 - } + illegal_instruction: 2, +} +read_write_csr_field! { + Medeleg, /// Breakpoint Delegate - #[inline] - pub fn breakpoint(&self) -> bool { - self.bits & (1 << 3) != 0 - } + breakpoint: 3, +} +read_write_csr_field! { + Medeleg, /// Load Address Misaligned Delegate - #[inline] - pub fn load_misaligned(&self) -> bool { - self.bits & (1 << 4) != 0 - } + load_misaligned: 4, +} +read_write_csr_field! { + Medeleg, /// Load Access Fault Delegate - #[inline] - pub fn load_fault(&self) -> bool { - self.bits & (1 << 5) != 0 - } + load_fault: 5, +} +read_write_csr_field! { + Medeleg, /// Store/AMO Address Misaligned Delegate - #[inline] - pub fn store_misaligned(&self) -> bool { - self.bits & (1 << 6) != 0 - } + store_misaligned: 6, +} +read_write_csr_field! { + Medeleg, /// Store/AMO Access Fault Delegate - #[inline] - pub fn store_fault(&self) -> bool { - self.bits & (1 << 7) != 0 - } + store_fault: 7, +} +read_write_csr_field! { + Medeleg, /// Environment Call from U-mode Delegate - #[inline] - pub fn user_env_call(&self) -> bool { - self.bits & (1 << 8) != 0 - } + user_env_call: 8, +} +read_write_csr_field! { + Medeleg, /// Environment Call from S-mode Delegate - #[inline] - pub fn supervisor_env_call(&self) -> bool { - self.bits & (1 << 9) != 0 - } + supervisor_env_call: 9, +} +read_write_csr_field! { + Medeleg, /// Instruction Page Fault Delegate - #[inline] - pub fn instruction_page_fault(&self) -> bool { - self.bits & (1 << 12) != 0 - } + instruction_page_fault: 12, +} +read_write_csr_field! { + Medeleg, /// Load Page Fault Delegate - #[inline] - pub fn load_page_fault(&self) -> bool { - self.bits & (1 << 13) != 0 - } + load_page_fault: 13, +} +read_write_csr_field! { + Medeleg, /// Store/AMO Page Fault Delegate - #[inline] - pub fn store_page_fault(&self) -> bool { - self.bits & (1 << 15) != 0 - } + store_page_fault: 15, } -read_csr_as!(Medeleg, 0x302); set!(0x302); clear!(0x302); @@ -135,3 +126,41 @@ set_clear_csr!( set_clear_csr!( /// Store/AMO Page Fault Delegate , set_store_page_fault, clear_store_page_fault, 1 << 15); + +#[cfg(test)] +mod tests { + use super::*; + + macro_rules! test_field { + ($reg:ident, $field:ident) => {{ + $crate::paste! { + assert!(!$reg.$field()); + + $reg.[](true); + assert!($reg.$field()); + + $reg.[](false); + assert!(!$reg.$field()); + } + }}; + } + + #[test] + fn test_medeleg() { + let mut m = Medeleg::from_bits(0); + + test_field!(m, instruction_misaligned); + test_field!(m, instruction_fault); + test_field!(m, illegal_instruction); + test_field!(m, breakpoint); + test_field!(m, load_misaligned); + test_field!(m, load_fault); + test_field!(m, store_misaligned); + test_field!(m, store_fault); + test_field!(m, user_env_call); + test_field!(m, supervisor_env_call); + test_field!(m, instruction_page_fault); + test_field!(m, load_page_fault); + test_field!(m, store_page_fault); + } +}