Add marchid, mhartid and mimpid registers
This commit is contained in:
parent
1e514648fd
commit
cf9008492a
3
asm.S
3
asm.S
@ -40,6 +40,9 @@ REG_READ_WRITE(mstatus, 0x300)
|
|||||||
REG_SET_CLEAR(mstatus, 0x300)
|
REG_SET_CLEAR(mstatus, 0x300)
|
||||||
REG_READ_WRITE(mtvec, 0x305)
|
REG_READ_WRITE(mtvec, 0x305)
|
||||||
REG_READ(mvendorid, 0xF11)
|
REG_READ(mvendorid, 0xF11)
|
||||||
|
REG_READ(marchid, 0xF12)
|
||||||
|
REG_READ(mimpid, 0xF13)
|
||||||
|
REG_READ(mhartid, 0xF14)
|
||||||
|
|
||||||
// S-mode registers
|
// S-mode registers
|
||||||
REG_READ_WRITE(satp, 0x180)
|
REG_READ_WRITE(satp, 0x180)
|
||||||
|
27
src/register/marchid.rs
Normal file
27
src/register/marchid.rs
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
//! marchid register
|
||||||
|
|
||||||
|
use core::num::NonZeroUsize;
|
||||||
|
|
||||||
|
/// marchid register
|
||||||
|
#[derive(Clone, Copy, Debug)]
|
||||||
|
pub struct Marchid {
|
||||||
|
bits: NonZeroUsize,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Marchid {
|
||||||
|
/// Returns the contents of the register as raw bits
|
||||||
|
pub fn bits(&self) -> usize {
|
||||||
|
self.bits.get()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
read_csr!(0xF11, __read_marchid);
|
||||||
|
|
||||||
|
/// Reads the CSR
|
||||||
|
#[inline]
|
||||||
|
pub fn read() -> Option<Marchid> {
|
||||||
|
let r = unsafe{ _read() };
|
||||||
|
// When marchid is hardwired to zero it means that the marchid
|
||||||
|
// csr isn't implemented.
|
||||||
|
NonZeroUsize::new(r).map(|bits| Marchid { bits })
|
||||||
|
}
|
3
src/register/mhartid.rs
Normal file
3
src/register/mhartid.rs
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
//! mhartid register
|
||||||
|
|
||||||
|
read_csr_as_usize!(0xf14, __read_mhartid);
|
27
src/register/mimpid.rs
Normal file
27
src/register/mimpid.rs
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
//! mimpid register
|
||||||
|
|
||||||
|
use core::num::NonZeroUsize;
|
||||||
|
|
||||||
|
/// mimpid register
|
||||||
|
#[derive(Clone, Copy, Debug)]
|
||||||
|
pub struct Mimpid {
|
||||||
|
bits: NonZeroUsize,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Mimpid {
|
||||||
|
/// Returns the contents of the register as raw bits
|
||||||
|
pub fn bits(&self) -> usize {
|
||||||
|
self.bits.get()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
read_csr!(0xF11, __read_mimpid);
|
||||||
|
|
||||||
|
/// Reads the CSR
|
||||||
|
#[inline]
|
||||||
|
pub fn read() -> Option<Mimpid> {
|
||||||
|
let r = unsafe{ _read() };
|
||||||
|
// When mimpid is hardwired to zero it means that the mimpid
|
||||||
|
// csr isn't implemented.
|
||||||
|
NonZeroUsize::new(r).map(|bits| Mimpid { bits })
|
||||||
|
}
|
@ -15,14 +15,17 @@ mod macros;
|
|||||||
|
|
||||||
pub mod fcsr;
|
pub mod fcsr;
|
||||||
|
|
||||||
|
pub mod marchid;
|
||||||
pub mod mcause;
|
pub mod mcause;
|
||||||
pub mod mcycle;
|
pub mod mcycle;
|
||||||
pub mod mcycleh;
|
pub mod mcycleh;
|
||||||
pub mod mepc;
|
pub mod mepc;
|
||||||
|
pub mod mhartid;
|
||||||
pub mod mie;
|
pub mod mie;
|
||||||
pub mod mip;
|
pub mod mimpid;
|
||||||
pub mod minstret;
|
pub mod minstret;
|
||||||
pub mod minstreth;
|
pub mod minstreth;
|
||||||
|
pub mod mip;
|
||||||
pub mod misa;
|
pub mod misa;
|
||||||
pub mod mstatus;
|
pub mod mstatus;
|
||||||
pub mod mtvec;
|
pub mod mtvec;
|
||||||
|
Loading…
Reference in New Issue
Block a user