Struct Clint

Source
pub struct Clint {
    base_addr: usize,
    max_cpus: CpuId,
}
Expand description

RISC-V CLINT Implementation

Fields§

§base_addr: usize

Base address of the CLINT

§max_cpus: CpuId

Maximum number of CPUs this CLINT supports

Implementations§

Source§

impl Clint

Source

pub fn new(base_addr: usize, max_cpus: CpuId) -> Self

Create a new CLINT instance

§Arguments
  • base_addr - Physical base address of the CLINT
  • max_cpus - Maximum number of CPUs supported

The base address is used to calculate all register addresses using relative offsets defined in the CLINT specification.

Source

fn msip_addr(&self, cpu_id: CpuId) -> usize

Get the address of the software interrupt pending register for a CPU

Source

fn mtimecmp_addr(&self, cpu_id: CpuId) -> usize

Get the address of the timer compare register for a CPU

Source

fn mtime_addr(&self) -> usize

Get the address of the timer value register

Source

fn validate_cpu_id(&self, cpu_id: CpuId) -> InterruptResult<()>

Validate CPU ID

Trait Implementations§

Source§

impl LocalInterruptController for Clint

Source§

fn init(&mut self, cpu_id: CpuId) -> InterruptResult<()>

Initialize the CLINT for a specific CPU

Source§

fn enable_interrupt( &mut self, cpu_id: CpuId, interrupt_type: LocalInterruptType, ) -> InterruptResult<()>

Enable a specific local interrupt type for a CPU

Source§

fn disable_interrupt( &mut self, cpu_id: CpuId, interrupt_type: LocalInterruptType, ) -> InterruptResult<()>

Disable a specific local interrupt type for a CPU

Source§

fn is_pending(&self, cpu_id: CpuId, interrupt_type: LocalInterruptType) -> bool

Check if a specific local interrupt type is pending for a CPU

Source§

fn clear_interrupt( &mut self, cpu_id: CpuId, interrupt_type: LocalInterruptType, ) -> InterruptResult<()>

Clear a pending local interrupt for a CPU

Source§

fn send_software_interrupt(&mut self, target_cpu: CpuId) -> InterruptResult<()>

Send a software interrupt to a specific CPU

Source§

fn clear_software_interrupt(&mut self, cpu_id: CpuId) -> InterruptResult<()>

Clear a software interrupt for a specific CPU

Source§

fn set_timer(&mut self, cpu_id: CpuId, time: u64) -> InterruptResult<()>

Set timer interrupt for a specific CPU

Source§

fn get_time(&self) -> u64

Get current timer value

Source§

impl Send for Clint

Source§

impl Sync for Clint

Auto Trait Implementations§

§

impl Freeze for Clint

§

impl RefUnwindSafe for Clint

§

impl Unpin for Clint

§

impl UnwindSafe for Clint

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of [From]<T> for U chooses to do.

§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.