pub enum RegClass {
Int = 0,
Float = 1,
Vector = 2,
}
Expand description
Register classes.
Every value has a “register class”, which is like a type at the register-allocator level. Every register must belong to only one class; i.e., they are disjoint.
For tight bit-packing throughout our data structures, we support only three classes, “int”, “float” and “vector”. Usually two will be enough on modern machines, as they have one class of general-purpose integer registers of machine width (e.g. 64 bits), and another class of float/vector registers used both for FP and for vector operations. Additionally for machines with totally separate vector registers a third class is provided.
Variants§
Trait Implementations§
source§impl Ord for RegClass
impl Ord for RegClass
source§impl PartialOrd for RegClass
impl PartialOrd for RegClass
impl Copy for RegClass
impl Eq for RegClass
impl StructuralPartialEq for RegClass
Auto Trait Implementations§
impl Freeze for RegClass
impl RefUnwindSafe for RegClass
impl Send for RegClass
impl Sync for RegClass
impl Unpin for RegClass
impl UnwindSafe for RegClass
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
Mutably borrows from an owned value. Read more
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)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)