Thread

Struct Thread 

Source
pub struct Thread { /* private fields */ }
Expand description

Handle to an OS thread.

For the common case of current-thread operations (sleep_ms, yield_now), use the associated functions directly — no handle needed.

Implementations§

Source§

impl Thread

Source

pub fn sleep_ms(ms: u32)

Sleep the current thread for ms milliseconds.

Source

pub fn yield_now()

Yield the current thread’s time slice.

Source

pub fn current() -> Self

Get a non-owning handle to the currently running thread.

The returned handle will not destroy the thread on drop, since the caller does not own it.

Source

pub fn create( name: &[u8], entry: unsafe extern "C" fn(*mut c_void), priority: Priority, stack_size: usize, ) -> Result<Self>

Create a new thread via heap allocation (only in heap mode).

This is the low-level API that takes an unsafe extern "C" entry. Prefer Thread::spawn() for safe Rust entry functions.

§Errors

Returns Error::NoMemory if heap allocation fails, or another error if the RTOS rejects the thread descriptor.

Source

pub fn spawn( name: &[u8], entry: fn(), priority: Priority, stack_size: usize, ) -> Result<Self>

Spawn a thread with a safe Rust entry function.

Uses a trampoline to convert fn() into the unsafe extern "C" entry expected by the C API. No raw pointers or unsafe needed in user code.

§Errors

Returns Error::NoMemory if heap allocation fails, or another error if the RTOS rejects the thread descriptor.

Source

pub fn suspend(&self)

Suspend this thread.

Source

pub fn resume(&self)

Resume this thread.

Source

pub fn set_priority(&self, prio: Priority)

Set this thread’s priority.

Source

pub fn get_stack_usage(&self) -> usize

Get current stack usage in bytes.

Source

pub fn get_state(&self) -> ThreadState

Get the thread’s current state.

Source

pub fn get_runtime_stats(&self) -> Result<ThreadStats>

Get runtime statistics (CPU time and utilization) for this thread.

§Errors

Returns an error if the RTOS does not support runtime statistics or the thread handle is invalid.

Trait Implementations§

Source§

impl Debug for Thread

Source§

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

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

impl Drop for Thread

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl Freeze for Thread

§

impl RefUnwindSafe for Thread

§

impl !Send for Thread

§

impl !Sync for Thread

§

impl Unpin for Thread

§

impl UnwindSafe for Thread

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.