armv4t_emu

Struct Cpu

Source
pub struct Cpu { /* private fields */ }
Expand description

An emulated CPU which implements the ARMv4T instruction set.

Implementations§

Source§

impl Cpu

Source

pub fn new() -> Cpu

Construct a new ARMv4T Cpu, with registers set to default “cold-boot” values.

Specifically, PC is set to 0x00000000, and CPSR is set to 0xd3 (ARM state, Supervisor mode, FIQ and IRQ mask bits set). Technically, the ARM spec states that all other registers can have undefined values on-boot, but in this emulator, all registers are set to 0 on-boot.

Source

pub fn step(&mut self, mem: &mut impl Memory) -> bool

Step the CPU a single instruction with the given memory object.

As a testing convenience, this method returns false if a undefined instruction exception is triggered.

Source

pub fn exception(&mut self, exc: Exception)

Trigger a CPU exception.

Source

pub fn thumb_mode(&self) -> bool

Check if CPU is currently in Thumb mode.

Source

pub fn reg_set(&mut self, mode: Mode, reg: Reg, val: u32)

Manually set a register’s value.

Source

pub fn reg_get(&self, mode: Mode, reg: Reg) -> u32

Returns a register’s value.

Source

pub fn mode(&self) -> Mode

Returns the current processor mode.

Source

pub fn irq_enable(&self) -> bool

Check if IRQs are enabled.

Source

pub fn fiq_enable(&self) -> bool

Check if FIQs are enabled.

Trait Implementations§

Source§

impl Clone for Cpu

Source§

fn clone(&self) -> Cpu

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Cpu

Source§

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

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

impl Default for Cpu

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl PartialEq for Cpu

Source§

fn eq(&self, other: &Cpu) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for Cpu

Source§

impl Eq for Cpu

Source§

impl StructuralPartialEq for Cpu

Auto Trait Implementations§

§

impl Freeze for Cpu

§

impl RefUnwindSafe for Cpu

§

impl Send for Cpu

§

impl Sync for Cpu

§

impl Unpin for Cpu

§

impl UnwindSafe for Cpu

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
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.