Trait Arch
pub trait Arch:
Copy
+ Clone
+ Debug
+ PartialEq
+ Eq
+ Hash
+ Default
+ PartialOrd
+ Ord
+ Send
+ Sync
+ 'staticwhere
Self: Sized,{
type CpuState: CpuState<Self> + Clone + PartialEq + Eq + Send + Sync + Debug + Display;
type Reg: Register + Copy + Clone + Debug + Display + Eq + Hash + PartialOrd + Ord + Serialize + DeserializeOwned + Send + Sync;
type GpReg: Register + NumberedRegister + Clone + Debug + Display + Eq + Hash + PartialOrd + Ord + Serialize + DeserializeOwned + Send + Sync;
type Flag: Flag + Clone + Debug + Display + PartialEq + Eq + Hash + PartialOrd + Ord + Serialize + DeserializeOwned + Send + Sync;
const PAGE_BITS: usize;
const PC: Self::GpReg;
const ZERO: Self::GpReg;
const INSTRUCTION_ALIGNMENT: usize = 1usize;
// Required methods
fn reg(reg: Self::GpReg) -> Self::Reg;
fn try_reg_to_gpreg(reg: Self::Reg) -> Option<Self::GpReg>;
fn flagreg_to_flags(
reg: Self::Reg,
start_byte: usize,
end_byte: usize,
) -> &'static [Self::Flag];
fn iter_gpregs() -> impl Iterator<Item = Self::GpReg>;
fn iter_regs() -> impl Iterator<Item = Self::Reg>;
}
Expand description
Represents a CPU architecture.
Required Associated Constants§
Provided Associated Constants§
const INSTRUCTION_ALIGNMENT: usize = 1usize
const INSTRUCTION_ALIGNMENT: usize = 1usize
The alignment of the instructions. Must be a multiple of 2.
Required Associated Types§
type CpuState: CpuState<Self> + Clone + PartialEq + Eq + Send + Sync + Debug + Display
type CpuState: CpuState<Self> + Clone + PartialEq + Eq + Send + Sync + Debug + Display
The CPU state representation.
type Reg: Register + Copy + Clone + Debug + Display + Eq + Hash + PartialOrd + Ord + Serialize + DeserializeOwned + Send + Sync
type Reg: Register + Copy + Clone + Debug + Display + Eq + Hash + PartialOrd + Ord + Serialize + DeserializeOwned + Send + Sync
The register representation.
type GpReg: Register + NumberedRegister + Clone + Debug + Display + Eq + Hash + PartialOrd + Ord + Serialize + DeserializeOwned + Send + Sync
type GpReg: Register + NumberedRegister + Clone + Debug + Display + Eq + Hash + PartialOrd + Ord + Serialize + DeserializeOwned + Send + Sync
The general-purpose register representation.
This should be equal to Self::Reg
, or be a subset.
General-purpose registers must be integers (see crate::value::ValueType
).
These are the only registers that are used in address computations.
type Flag: Flag + Clone + Debug + Display + PartialEq + Eq + Hash + PartialOrd + Ord + Serialize + DeserializeOwned + Send + Sync
type Flag: Flag + Clone + Debug + Display + PartialEq + Eq + Hash + PartialOrd + Ord + Serialize + DeserializeOwned + Send + Sync
The flag representation.
A flag should always be part of a flag register.
See also Arch::flagreg_to_flags
.
Required Methods§
fn reg(reg: Self::GpReg) -> Self::Reg
fn reg(reg: Self::GpReg) -> Self::Reg
Converts a general-purpose register into a generic register. This must always succeed.
fn try_reg_to_gpreg(reg: Self::Reg) -> Option<Self::GpReg>
fn try_reg_to_gpreg(reg: Self::Reg) -> Option<Self::GpReg>
Converts a generic register into a general-purpose register.
If the generic register is not a general-purpose register, None
is returned.
fn flagreg_to_flags(
reg: Self::Reg,
start_byte: usize,
end_byte: usize,
) -> &'static [Self::Flag]
fn flagreg_to_flags( reg: Self::Reg, start_byte: usize, end_byte: usize, ) -> &'static [Self::Flag]
Returns the flags associated with the byte range in the flags register. By convention, a flag register should contain one flag per byte.
fn iter_gpregs() -> impl Iterator<Item = Self::GpReg>
fn iter_gpregs() -> impl Iterator<Item = Self::GpReg>
Returns an iterator that iterates over all general-purpose registers. The zero register must not be included, as it is not a real register.