TaskMutableState

Struct TaskMutableState 

Source
pub struct TaskMutableState {
    pub clear_child_tid: UserRef<tid_t>,
    pub scheduler_state: SchedulerState,
    pub uts_ns: UtsNamespaceHandle,
    pub oom_score_adj: i32,
    pub seccomp_filters: SeccompFilterContainer,
    pub robust_list_head: RobustListHeadPtr,
    pub timerslack_ns: u64,
    pub default_timerslack_ns: u64,
    pub ptrace: Option<Box<PtraceState>>,
    pub captured_thread_state: Option<Box<CapturedThreadState>>,
    /* private fields */
}

Fields§

§clear_child_tid: UserRef<tid_t>§scheduler_state: SchedulerState

Desired scheduler state for the task.

§uts_ns: UtsNamespaceHandle

The UTS namespace assigned to this thread.

This field is kept in the mutable state because the UTS namespace of a thread can be forked using clone() or unshare() syscalls.

We use UtsNamespaceHandle because the UTS properties can be modified by any other thread that shares this namespace.

§oom_score_adj: i32

Userspace hint about how to adjust the OOM score for this process.

§seccomp_filters: SeccompFilterContainer

List of currently installed seccomp_filters

§robust_list_head: RobustListHeadPtr

A pointer to the head of the robust futex list of this thread in userspace. See get_robust_list(2)

§timerslack_ns: u64

The timer slack used to group timer expirations for the calling thread.

Timers may expire up to timerslack_ns late, but never early.

If this value is 0, the task’s default timerslack is used.

§default_timerslack_ns: u64

The default value for timerslack_ns. This value cannot change during the lifetime of a task.

This value is set to the timerslack_ns of the creating thread, and thus is not constant across tasks.

§ptrace: Option<Box<PtraceState>>

Information that a tracer needs to communicate with this process, if it is being traced.

§captured_thread_state: Option<Box<CapturedThreadState>>

Information that a tracer needs to inspect this process.

Implementations§

Source§

impl TaskMutableState

Source

pub fn no_new_privs(&self) -> bool

Source

pub fn enable_no_new_privs(&mut self)

Sets the value of no_new_privs to true. It is an error to set it to anything else.

Source

pub fn get_timerslack<T: Timeline>(&self) -> Duration<T>

Source

pub fn set_timerslack_ns(&mut self, ns: u64)

Sets the current timerslack of the task to ns.

If ns is zero, the current timerslack gets reset to the task’s default timerslack.

Source

pub fn is_ptraced(&self) -> bool

Source

pub fn is_ptrace_listening(&self) -> bool

Source

pub fn ptrace_on_signal_consume(&mut self) -> bool

Source

pub fn notify_ptracers(&mut self)

Source

pub fn wait_on_ptracer(&self, waiter: &Waiter)

Source

pub fn notify_ptracees(&mut self)

Source

pub fn take_captured_state(&mut self) -> Option<Box<CapturedThreadState>>

Source

pub fn copy_state_from(&mut self, current_task: &CurrentTask)

Source

pub fn signal_mask(&self) -> SigSet

Returns the task’s currently active signal mask.

Source

pub fn is_signal_masked(&self, signal: Signal) -> bool

Returns true if signal is currently blocked by this task’s signal mask.

Source

pub fn is_signal_masked_by_saved_mask(&self, signal: Signal) -> bool

Returns true if signal is blocked by the saved signal mask.

Note that the current signal mask may still not be blocking the signal.

Source

pub fn enqueue_kernel_signal(&mut self, signal: KernelSignal)

Enqueues an internal signal at the back of the task’s kernel signal queue.

Source

pub fn enqueue_signal(&mut self, signal: SignalInfo)

Enqueues a signal at the back of the task’s signal queue.

Source

pub fn enqueue_signal_front(&mut self, signal: SignalInfo)

Enqueues the signal, allowing the signal to skip straight to the front of the task’s queue.

enqueue_signal is the more common API to use.

Note that this will not guarantee that the signal is dequeued before any process-directed signals.

Source

pub fn set_signal_mask(&mut self, mask: SigSet)

Sets the current signal mask of the task.

Source

pub fn set_temporary_signal_mask(&mut self, mask: SigSet)

Sets a temporary signal mask for the task.

This mask should be removed by a matching call to restore_signal_mask.

Source

pub fn restore_signal_mask(&mut self)

Removes the currently active, temporary, signal mask and restores the previously active signal mask.

Source

pub fn is_blocked(&self) -> bool

Returns true if the task’s current RunState is blocked.

Source

pub fn set_run_state(&mut self, run_state: RunState)

Sets the task’s RunState to run_state.

Source

pub fn run_state(&self) -> RunState

Source

pub fn on_signal_stack(&self, stack_pointer_register: u64) -> bool

Source

pub fn set_sigaltstack(&mut self, stack: Option<sigaltstack>)

Source

pub fn sigaltstack(&self) -> Option<sigaltstack>

Source

pub fn wait_on_signal(&mut self, waiter: &Waiter)

Source

pub fn signals_mut(&mut self) -> &mut SignalState

Source

pub fn wait_on_signal_fd_events( &self, waiter: &Waiter, mask: SigSet, handler: EventHandler, ) -> WaitCanceler

Source

pub fn notify_signal_waiters(&self, signal: &Signal)

Source

pub fn thaw(&mut self)

Thaw the task if has been frozen

Source

pub fn is_frozen(&self) -> bool

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> AsAny for T
where T: Any,

Source§

fn as_any(&self) -> &(dyn Any + 'static)

Source§

fn type_name(&self) -> &'static str

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, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

Source§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
Source§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

Source§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> InstanceFromServiceTransport<T> for T

§

fn from_service_transport(handle: T) -> T

Converts the given service transport handle of type T to [Self]
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> Into32<U> for T
where U: MultiArchFrom<T>,

Source§

fn into_32(self) -> U

Source§

impl<T, U> Into64<U> for T
where U: MultiArchFrom<T>,

Source§

fn into_64(self) -> U

Source§

impl<T> IntoAny for T
where T: 'static + Send + Sync,

Source§

fn into_any(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Cast the given object into a dyn std::any::Any.
Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

impl<T, U> IntoExt<U> for T
where U: FromExt<T>,

§

fn into_ext(self) -> U

Performs the conversion.
Source§

impl<T, U> IntoFidl<U> for T
where U: FromFidl<T>,

Source§

fn into_fidl(self) -> U

Source§

impl<T, U> MultiArchFrom<T> for U
where U: From<T>,

Source§

fn from_64(value: T) -> U

Source§

fn from_32(value: T) -> U

§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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.
§

impl<T, U> TryIntoExt<U> for T
where U: TryFromExt<T>,

§

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

§

fn try_into_ext(self) -> Result<U, <T as TryIntoExt<U>>::Error>

Tries to perform the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<St> WithTag for St

§

fn tagged<T>(self, tag: T) -> Tagged<T, St>

Produce a new stream from this one which yields item tupled with a constant tag
Source§

impl<B, A> LockBefore<B> for A
where B: LockAfter<A>,

Source§

impl<B, A> LockEqualOrBefore<B> for A
where A: LockBefore<B>,

§

impl<E> RunsTransport<Mpsc> for E

§

impl<E> RunsTransport<Mpsc> for E
where E: RunsTransport<Mpsc>,