pub struct MachineEnv {
pub preferred_regs_by_class: [Vec<PReg>; 3],
pub non_preferred_regs_by_class: [Vec<PReg>; 3],
pub scratch_by_class: [Option<PReg>; 3],
pub fixed_stack_slots: Vec<PReg>,
}
Expand description
A machine environment tells the register allocator which registers are available to allocate and what register may be used as a scratch register for each class, and some other miscellaneous info as well.
Fields§
§preferred_regs_by_class: [Vec<PReg>; 3]
Preferred physical registers for each class. These are the registers that will be allocated first, if free.
If an explicit scratch register is provided in scratch_by_class
then
it must not appear in this list.
non_preferred_regs_by_class: [Vec<PReg>; 3]
Non-preferred physical registers for each class. These are the registers that will be allocated if a preferred register is not available; using one of these is considered suboptimal, but still better than spilling.
If an explicit scratch register is provided in scratch_by_class
then
it must not appear in this list.
scratch_by_class: [Option<PReg>; 3]
Optional dedicated scratch register per class. This is needed to perform moves between registers when cyclic move patterns occur. The register should not be placed in either the preferred or non-preferred list (i.e., it is not otherwise allocatable).
Note that the register allocator will freely use this register between instructions, but within the machine code generated by a single (regalloc-level) instruction, the client is free to use the scratch register. E.g., if one “instruction” causes the emission of two machine-code instructions, this lowering can use the scratch register between them.
If a scratch register is not provided then the register allocator will automatically allocate one as needed, spilling a value to the stack if necessary.
fixed_stack_slots: Vec<PReg>
Some PReg
s can be designated as locations on the stack rather than
actual registers. These can be used to tell the register allocator about
pre-defined stack slots used for function arguments and return values.
PReg
s in this list cannot be used as an allocatable or scratch
register.
Trait Implementations§
source§impl Clone for MachineEnv
impl Clone for MachineEnv
source§fn clone(&self) -> MachineEnv
fn clone(&self) -> MachineEnv
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for MachineEnv
impl Debug for MachineEnv
source§impl From<&MachineEnv> for PRegSet
impl From<&MachineEnv> for PRegSet
source§fn from(env: &MachineEnv) -> Self
fn from(env: &MachineEnv) -> Self
Auto Trait Implementations§
impl Freeze for MachineEnv
impl RefUnwindSafe for MachineEnv
impl Send for MachineEnv
impl Sync for MachineEnv
impl Unpin for MachineEnv
impl UnwindSafe for MachineEnv
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)