diff --git a/riscv/CHANGELOG.md b/riscv/CHANGELOG.md index 7cf701b6..da48a3f2 100644 --- a/riscv/CHANGELOG.md +++ b/riscv/CHANGELOG.md @@ -15,6 +15,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 ## [v0.12.1] - 2024-10-20 diff --git a/riscv/src/register/mcause.rs b/riscv/src/register/mcause.rs index fde22af4..26149e17 100644 --- a/riscv/src/register/mcause.rs +++ b/riscv/src/register/mcause.rs @@ -2,32 +2,41 @@ pub use crate::interrupt::Trap; -/// mcause register -#[derive(Clone, Copy, Debug)] -pub struct Mcause { - bits: usize, +read_only_csr! { + /// `mcause` register + Mcause: 0x342, + mask: 0xffff_ffff, } -impl From for Mcause { - #[inline] - fn from(bits: usize) -> Self { - Self { bits } - } +#[cfg(target_arch = "riscv32")] +read_only_csr_field! { + Mcause, + /// Returns the `code` field. + code: [0:30], } -impl Mcause { - /// Returns the contents of the register as raw bits - #[inline] - pub fn bits(&self) -> usize { - self.bits - } +#[cfg(not(target_arch = "riscv32"))] +read_only_csr_field! { + Mcause, + /// Returns the `code` field. + code: [0:62], +} - /// Returns the code field - #[inline] - pub fn code(&self) -> usize { - self.bits & !(1 << (usize::BITS as usize - 1)) - } +#[cfg(target_arch = "riscv32")] +read_only_csr_field! { + Mcause, + /// Is the trap cause an interrupt. + is_interrupt: 31, +} + +#[cfg(not(target_arch = "riscv32"))] +read_only_csr_field! { + Mcause, + /// Is the trap cause an interrupt. + is_interrupt: 63, +} +impl Mcause { /// Returns the trap cause represented by this register. /// /// # Note @@ -43,17 +52,9 @@ impl Mcause { } } - /// Is trap cause an interrupt. - #[inline] - pub fn is_interrupt(&self) -> bool { - self.bits & (1 << (usize::BITS as usize - 1)) != 0 - } - /// Is trap cause an exception. #[inline] pub fn is_exception(&self) -> bool { !self.is_interrupt() } } - -read_csr_as!(Mcause, 0x342);