Struct x86_64::registers::rflags::RFlags[][src]

pub struct RFlags { /* fields omitted */ }
Expand description

The RFLAGS register.

Implementations

impl RFlags[src]

pub const ID: RFlags[src]

Processor feature identification flag.

If this flag is modifiable, the CPU supports CPUID.

pub const VIRTUAL_INTERRUPT_PENDING: RFlags[src]

Indicates that an external, maskable interrupt is pending.

Used when virtual-8086 mode extensions (CR4.VME) or protected-mode virtual interrupts (CR4.PVI) are activated.

pub const VIRTUAL_INTERRUPT: RFlags[src]

Virtual image of the INTERRUPT_FLAG bit.

Used when virtual-8086 mode extensions (CR4.VME) or protected-mode virtual interrupts (CR4.PVI) are activated.

pub const ALIGNMENT_CHECK: RFlags[src]

Enable automatic alignment checking if CR0.AM is set. Only works if CPL is 3.

pub const VIRTUAL_8086_MODE: RFlags[src]

Enable the virtual-8086 mode.

pub const RESUME_FLAG: RFlags[src]

Allows to restart an instruction following an instrucion breakpoint.

pub const NESTED_TASK: RFlags[src]

Used by iret in hardware task switch mode to determine if current task is nested.

pub const IOPL_HIGH: RFlags[src]

The high bit of the I/O Privilege Level field.

Specifies the privilege level required for executing I/O address-space instructions.

pub const IOPL_LOW: RFlags[src]

The low bit of the I/O Privilege Level field.

Specifies the privilege level required for executing I/O address-space instructions.

pub const OVERFLOW_FLAG: RFlags[src]

Set by hardware to indicate that the sign bit of the result of the last signed integer operation differs from the source operands.

pub const DIRECTION_FLAG: RFlags[src]

Determines the order in which strings are processed.

pub const INTERRUPT_FLAG: RFlags[src]

Enable interrupts.

pub const TRAP_FLAG: RFlags[src]

Enable single-step mode for debugging.

pub const SIGN_FLAG: RFlags[src]

Set by hardware if last arithmetic operation resulted in a negative value.

pub const ZERO_FLAG: RFlags[src]

Set by hardware if last arithmetic operation resulted in a zero value.

pub const AUXILIARY_CARRY_FLAG: RFlags[src]

Set by hardware if last arithmetic operation generated a carry ouf of bit 3 of the result.

pub const PARITY_FLAG: RFlags[src]

Set by hardware if last result has an even number of 1 bits (only for some operations).

pub const CARRY_FLAG: RFlags[src]

Set by hardware if last arithmetic operation generated a carry out of the most-significant bit of the result.

pub const fn empty() -> RFlags[src]

Returns an empty set of flags

pub const fn all() -> RFlags[src]

Returns the set containing all flags.

pub const fn bits(&self) -> u64[src]

Returns the raw value of the flags currently stored.

pub fn from_bits(bits: u64) -> Option<RFlags>[src]

Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.

pub const fn from_bits_truncate(bits: u64) -> RFlags[src]

Convert from underlying bit representation, dropping any bits that do not correspond to flags.

pub const unsafe fn from_bits_unchecked(bits: u64) -> RFlags[src]

Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).

pub const fn is_empty(&self) -> bool[src]

Returns true if no flags are currently stored.

pub const fn is_all(&self) -> bool[src]

Returns true if all flags are currently set.

pub const fn intersects(&self, other: RFlags) -> bool[src]

Returns true if there are flags common to both self and other.

pub const fn contains(&self, other: RFlags) -> bool[src]

Returns true all of the flags in other are contained within self.

pub fn insert(&mut self, other: RFlags)[src]

Inserts the specified flags in-place.

pub fn remove(&mut self, other: RFlags)[src]

Removes the specified flags in-place.

pub fn toggle(&mut self, other: RFlags)[src]

Toggles the specified flags in-place.

pub fn set(&mut self, other: RFlags, value: bool)[src]

Inserts or removes the specified flags depending on the passed value.

Trait Implementations

impl Binary for RFlags[src]

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

Formats the value using the given formatter.

impl BitAnd<RFlags> for RFlags[src]

fn bitand(self, other: RFlags) -> RFlags[src]

Returns the intersection between the two sets of flags.

type Output = RFlags

The resulting type after applying the & operator.

impl BitAndAssign<RFlags> for RFlags[src]

fn bitand_assign(&mut self, other: RFlags)[src]

Disables all flags disabled in the set.

impl BitOr<RFlags> for RFlags[src]

fn bitor(self, other: RFlags) -> RFlags[src]

Returns the union of the two sets of flags.

type Output = RFlags

The resulting type after applying the | operator.

impl BitOrAssign<RFlags> for RFlags[src]

fn bitor_assign(&mut self, other: RFlags)[src]

Adds the set of flags.

impl BitXor<RFlags> for RFlags[src]

fn bitxor(self, other: RFlags) -> RFlags[src]

Returns the left flags, but with all the right flags toggled.

type Output = RFlags

The resulting type after applying the ^ operator.

impl BitXorAssign<RFlags> for RFlags[src]

fn bitxor_assign(&mut self, other: RFlags)[src]

Toggles the set of flags.

impl Clone for RFlags[src]

fn clone(&self) -> RFlags[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl Debug for RFlags[src]

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

Formats the value using the given formatter. Read more

impl Extend<RFlags> for RFlags[src]

fn extend<T: IntoIterator<Item = RFlags>>(&mut self, iterator: T)[src]

Extends a collection with the contents of an iterator. Read more

fn extend_one(&mut self, item: A)[src]

🔬 This is a nightly-only experimental API. (extend_one)

Extends a collection with exactly one element.

fn extend_reserve(&mut self, additional: usize)[src]

🔬 This is a nightly-only experimental API. (extend_one)

Reserves capacity in a collection for the given number of additional elements. Read more

impl FromIterator<RFlags> for RFlags[src]

fn from_iter<T: IntoIterator<Item = RFlags>>(iterator: T) -> RFlags[src]

Creates a value from an iterator. Read more

impl Hash for RFlags[src]

fn hash<__H: Hasher>(&self, state: &mut __H)[src]

Feeds this value into the given Hasher. Read more

fn hash_slice<H>(data: &[Self], state: &mut H) where
    H: Hasher
1.3.0[src]

Feeds a slice of this type into the given Hasher. Read more

impl LowerHex for RFlags[src]

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

Formats the value using the given formatter.

impl Not for RFlags[src]

fn not(self) -> RFlags[src]

Returns the complement of this set of flags.

type Output = RFlags

The resulting type after applying the ! operator.

impl Octal for RFlags[src]

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

Formats the value using the given formatter.

impl Ord for RFlags[src]

fn cmp(&self, other: &RFlags) -> Ordering[src]

This method returns an Ordering between self and other. Read more

#[must_use]
fn max(self, other: Self) -> Self
1.21.0[src]

Compares and returns the maximum of two values. Read more

#[must_use]
fn min(self, other: Self) -> Self
1.21.0[src]

Compares and returns the minimum of two values. Read more

#[must_use]
fn clamp(self, min: Self, max: Self) -> Self
1.50.0[src]

Restrict a value to a certain interval. Read more

impl PartialEq<RFlags> for RFlags[src]

fn eq(&self, other: &RFlags) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, other: &RFlags) -> bool[src]

This method tests for !=.

impl PartialOrd<RFlags> for RFlags[src]

fn partial_cmp(&self, other: &RFlags) -> Option<Ordering>[src]

This method returns an ordering between self and other values if one exists. Read more

#[must_use]
fn lt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than (for self and other) and is used by the < operator. Read more

#[must_use]
fn le(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

#[must_use]
fn gt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than (for self and other) and is used by the > operator. Read more

#[must_use]
fn ge(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl Sub<RFlags> for RFlags[src]

fn sub(self, other: RFlags) -> RFlags[src]

Returns the set difference of the two sets of flags.

type Output = RFlags

The resulting type after applying the - operator.

impl SubAssign<RFlags> for RFlags[src]

fn sub_assign(&mut self, other: RFlags)[src]

Disables all flags enabled in the set.

impl UpperHex for RFlags[src]

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

Formats the value using the given formatter.

impl Copy for RFlags[src]

impl Eq for RFlags[src]

impl StructuralEq for RFlags[src]

impl StructuralPartialEq for RFlags[src]

Auto Trait Implementations

impl Send for RFlags

impl Sync for RFlags

impl Unpin for RFlags

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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

Performs the conversion.