Skip to main content

UserContext

Struct UserContext 

Source
pub struct UserContext {
    pub fs_base: u64,
    pub gs_base: u64,
    /* private fields */
}
Available on crate feature uspace only.
Expand description

Context to enter user space.

Fields§

§fs_base: u64

FS Segment Base

§gs_base: u64

GS Segment Base

Implementations§

Source§

impl UserContext

Source

pub fn new(entry: usize, ustack_top: VirtAddr, arg0: usize) -> Self

Creates a new context with the given entry point, user stack pointer, and the argument.

Source

pub const fn tls(&self) -> usize

Gets the TLS area.

Source

pub const fn set_tls(&mut self, tls_area: usize)

Sets the TLS area.

Source

pub fn run(&mut self) -> ReturnReason

Enters user space.

It restores the user registers and jumps to the user entry point (saved in rip).

This function returns when an exception or syscall occurs.

Methods from Deref<Target = TrapFrame>§

Source

pub fn arg0(&self) -> usize

Gets the 0th syscall argument.

Source

pub fn set_arg0(&mut self, rdi: usize)

Sets the 0th syscall argument.

Source

pub fn arg1(&self) -> usize

Gets the 1st syscall argument.

Source

pub fn set_arg1(&mut self, rsi: usize)

Sets the 1st syscall argument.

Source

pub fn arg2(&self) -> usize

Gets the 2nd syscall argument.

Source

pub fn set_arg2(&mut self, rdx: usize)

Sets the 2nd syscall argument.

Source

pub fn arg3(&self) -> usize

Gets the 3rd syscall argument.

Source

pub fn set_arg3(&mut self, r10: usize)

Sets the 3rd syscall argument.

Source

pub fn arg4(&self) -> usize

Gets the 4th syscall argument.

Source

pub fn set_arg4(&mut self, r8: usize)

Sets the 4th syscall argument.

Source

pub fn arg5(&self) -> usize

Gets the 5th syscall argument.

Source

pub fn set_arg5(&mut self, r9: usize)

Sets the 5th syscall argument.

Source

pub fn ip(&self) -> usize

Gets the instruction pointer.

Source

pub fn set_ip(&mut self, rip: usize)

Sets the instruction pointer.

Source

pub fn sp(&self) -> usize

Gets the stack pointer.

Source

pub fn set_sp(&mut self, rsp: usize)

Sets the stack pointer.

Source

pub fn sysno(&self) -> usize

Gets the syscall number.

Source

pub fn set_sysno(&mut self, rax: usize)

Sets the syscall number.

Source

pub fn retval(&self) -> usize

Gets the return value register.

Source

pub fn set_retval(&mut self, rax: usize)

Sets the return value register.

Source

pub fn backtrace(&self) -> Backtrace

Unwind the stack and get the backtrace.

Trait Implementations§

Source§

impl Clone for UserContext

Source§

fn clone(&self) -> UserContext

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for UserContext

Source§

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

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

impl Deref for UserContext

Source§

type Target = TrapFrame

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl DerefMut for UserContext

Source§

fn deref_mut(&mut self) -> &mut Self::Target

Mutably dereferences the value.
Source§

impl Copy for UserContext

Auto Trait Implementations§

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
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.