Skip to main content

TaskContext

Struct TaskContext 

Source
#[repr(C)]
pub struct TaskContext { pub ra: usize, pub sp: usize, pub s: [usize; 10], pub tp: usize, pub pgdl: usize, pub fpu: FpuState, }
Expand description

Saved hardware states of a task.

The context usually includes:

  • Callee-saved registers
  • Stack pointer register
  • Thread pointer register (for thread-local storage, currently unsupported)
  • FP/SIMD registers

On context switch, current task saves its context from CPU to memory, and the next task restores its context from memory to CPU.

Fields§

§ra: usize

Return Address

§sp: usize

Stack Pointer

§s: [usize; 10]

loongArch need to save 10 static registers from $r22 to $r31

§tp: usize

Thread Pointer

§pgdl: usize
Available on crate feature uspace only.

user page table root

§fpu: FpuState
Available on crate feature fp-simd only.

Floating Point Unit states

Implementations§

Source§

impl TaskContext

Source

pub fn new() -> Self

Creates a new default context for a new task.

Source

pub fn init(&mut self, entry: usize, kstack_top: VirtAddr, tls_area: VirtAddr)

Initializes the context for a new task, with the given entry point and kernel stack.

Source

pub fn set_page_table_root(&mut self, pgdl: PhysAddr)

Available on crate feature uspace only.

Changes the page table root in this context.

The hardware register for user page table root (pgdl for loongarch64) will be updated to the next task’s after Self::switch_to.

Source

pub fn switch_to(&mut self, next_ctx: &Self)

Switches to another task.

It first saves the current task’s context from CPU to this place, and then restores the next task’s context from next_ctx to CPU.

Trait Implementations§

Source§

impl Debug for TaskContext

Source§

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

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

impl Default for TaskContext

Source§

fn default() -> TaskContext

Returns the “default value” for a type. Read more

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