lc3_ensemble::sim::device

Struct TimerDevice

source
pub struct TimerDevice {
    pub vect: u8,
    pub priority: u8,
    pub enabled: bool,
    /* private fields */
}
Expand description

A timer device that triggers an interrupt after a configured number (or range) of instructions.

This is not part of LC-3 specification, so the design decision made (such as default interrupt vector, priority level) are not reflective of LC-3’s choices.

Fields§

§vect: u8

The interrupt vector.

§priority: u8

The priority.

Note that if this exceeds 7, it will be treated as though it is 7.

§enabled: bool

Whether this timer can trigger an interrupt.

Implementations§

source§

impl TimerDevice

source

pub fn new( seed: Option<u64>, range: impl RangeBounds<u32>, vect: u8, priority: u8, ) -> Self

Creates a new timer device.

  • seed: Sets the seed for the timer’s RNG. This can be None if RNG does not need to be deterministic or if range can only be exactly one value.
  • range: Sets the range of possible number of instructions before interrupt trigger.
  • vect and priority: Initializes the interrupt vector and priority values.
source

pub fn get_range(&self) -> impl RangeBounds<u32>

Gets the range of possible number of instructions before the interrupt is triggered.

source

pub fn set_range(&mut self, r: impl RangeBounds<u32>) -> &mut Self

Sets the number of instructions before the interrupt is triggered to a range of values.

source

pub fn set_exact(&mut self, n: u32) -> &mut Self

Sets the number of instructions before the interrupt is triggered to an exact number.

source

pub fn get_remaining(&self) -> u32

Gets the number of instructions remaining until the interrupt triggers.

source

pub fn reset_remaining(&mut self)

Resets the remaining time.

Trait Implementations§

source§

impl Debug for TimerDevice

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for TimerDevice

source§

fn default() -> Self

Creates a timer with default parameters.

The default parameters here are:

  • non-deterministic RNG
  • Triggers a timer interrupt every 50 instructions
  • Binds to interrupt vector 0x81
  • Interrupt priority 4
  • Disabled

(These are arbitrary.)

source§

impl ExternalDevice for TimerDevice

source§

fn io_read(&mut self, _addr: u16, _effectful: bool) -> Option<u16>

Reads the data at the given memory-mapped address. Read more
source§

fn io_write(&mut self, _addr: u16, _data: u16) -> bool

Writes the data to the given memory-mapped address. Read more
source§

fn io_reset(&mut self)

Resets device.
source§

fn poll_interrupt(&mut self) -> Option<Interrupt>

During each instruction cycle, this function is called once to see whether to trigger an interrupt. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

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

source§

fn into(self) -> U

Calls U::from(self).

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

source§

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

source§

type Error = Infallible

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

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

Performs the conversion.
source§

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

source§

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

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

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

Performs the conversion.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V