x86_64::registers::segmentation

Struct CS

Source
pub struct CS;
Expand description

Code Segment

While most fields in the Code-Segment Descriptor are unused in 64-bit long mode, some of them must be set to a specific value. The EXECUTABLE, USER_SEGMENT, and LONG_MODE bits must be set, while the DEFAULT_SIZE bit must be unset.

The DPL_RING_3 field can be used to change privilege level. The PRESENT bit can be used to make a segment present or not present.

All other fields (like the segment base and limit) are ignored by the processor and setting them has no effect.

Trait Implementations§

Source§

impl Debug for CS

Source§

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

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

impl Segment for CS

Source§

unsafe fn set_reg(sel: SegmentSelector)

Note this is special since we cannot directly move to CS; x86 requires the instruction pointer and CS to be set at the same time. To do this, we push the new segment selector and return value onto the stack and use a “far return” (retfq) to reload CS and continue at the end of our function.

Note we cannot use a “far call” (lcall) or “far jmp” (ljmp) to do this because then we would only be able to jump to 32-bit instruction pointers. Only Intel implements support for 64-bit far calls/jumps in long-mode, AMD does not.

Source§

fn get_reg() -> SegmentSelector

Returns the current value of the segment register.

Auto Trait Implementations§

§

impl Freeze for CS

§

impl RefUnwindSafe for CS

§

impl Send for CS

§

impl Sync for CS

§

impl Unpin for CS

§

impl UnwindSafe for CS

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> 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, 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.