zx

Struct Process

Source
pub struct Process(/* private fields */);
Expand description

An object representing a Zircon process.

As essentially a subtype of Handle, it can be freely interconverted.

Implementations§

Source§

impl Process

Source§

impl Process

Source

pub fn set_debug_addr(&self, val: &u64) -> Result<(), Status>

Source§

impl Process

Source§

impl Process

Source

pub fn set_break_on_load(&self, val: &u64) -> Result<(), Status>

Source§

impl Process

Source

pub fn start( &self, thread: &Thread, entry: usize, stack: usize, arg1: Handle, arg2: usize, ) -> Result<(), Status>

Similar to Thread::start, but is used to start the first thread in a process.

Wraps the zx_process_start syscall.

Source

pub fn create_thread(&self, name: &[u8]) -> Result<Thread, Status>

Create a thread inside a process.

Wraps the zx_thread_create syscall.

Source

pub fn write_memory( &self, vaddr: zx_vaddr_t, bytes: &[u8], ) -> Result<usize, Status>

Write memory inside a process.

Wraps the zx_process_write_memory syscall.

Source

pub fn read_memory( &self, vaddr: zx_vaddr_t, bytes: &mut [u8], ) -> Result<usize, Status>

Read memory from inside a process.

Wraps the zx_process_read_memory syscall.

Source

pub fn read_memory_uninit<'a>( &self, vaddr: zx_vaddr_t, buffer: &'a mut [MaybeUninit<u8>], ) -> Result<(&'a mut [u8], &'a mut [MaybeUninit<u8>]), Status>

Read memory from inside a process without requiring the output buffer to be initialized.

Wraps the zx_process_read_memory syscall.

Source

pub fn info(&self) -> Result<ProcessInfo, Status>

Wraps the zx_object_get_info syscall for the ZX_INFO_PROCESS topic.

Source

pub fn threads(&self) -> Result<Vec<Koid>, Status>

Wraps the zx_object_get_info syscall for the ZX_INFO_PROCESS_THREADS topic.

Source

pub fn task_stats(&self) -> Result<TaskStatsInfo, Status>

Wraps the zx_object_get_info syscall for the ZX_INFO_TASK_STATS topic.

Source

pub fn info_maps_vec(&self) -> Result<Vec<MapInfo>, Status>

Wraps the zx_object_get_info syscall for the ZX_INFO_PROCESS_MAPS topic.

Source

pub fn exit(retcode: i64) -> !

Exit the current process with the given return code.

Wraps the zx_process_exit syscall.

Source

pub fn handle_stats(&self) -> Result<ProcessHandleStats, Status>

Wraps the zx_object_get_info syscall for the ZX_INFO_PROCESS_HANDLE_STATS topic.

Source

pub fn get_child(&self, koid: &Koid, rights: Rights) -> Result<Thread, Status>

Wraps the zx_object_get_child syscall.

Source

pub fn info_vmos_vec(&self) -> Result<Vec<VmoInfo>, Status>

Wraps the zx_object_get_info syscall for the ZX_INFO_PROCESS_VMO topic.

Source

pub fn info_maps<'a>( &self, info_out: &'a mut [MaybeUninit<MapInfo>], ) -> Result<(&'a mut [MapInfo], &'a mut [MaybeUninit<MapInfo>], usize), Status>

Wraps the zx_object_get_info syscall for the ZX_INFO_PROCESS_MAPS topic. Contrarily to Process::info_vmos_vec, this method ensures that no intermediate copy of the data is made, at the price of a less convenient interface.

Source

pub fn info_vmos<'a>( &self, info_out: &'a mut [MaybeUninit<VmoInfo>], ) -> Result<(&'a mut [VmoInfo], &'a mut [MaybeUninit<VmoInfo>], usize), Status>

Wraps the zx_object_get_info syscall for the ZX_INFO_PROCESS_VMO topic. Contrarily to Process::info_vmos_vec, this method ensures that no intermediate copy of the data is made, at the price of a less convenient interface.

Trait Implementations§

Source§

impl AsHandleRef for Process

Source§

fn as_handle_ref(&self) -> HandleRef<'_>

Get a reference to the handle. One important use of such a reference is for object_wait_many.
Source§

fn raw_handle(&self) -> zx_handle_t

Interpret the reference as a raw handle (an integer type). Two distinct handles will have different raw values (so it can perhaps be used as a key in a data structure).
Source§

fn signal_handle( &self, clear_mask: Signals, set_mask: Signals, ) -> Result<(), Status>

Set and clear userspace-accessible signal bits on an object. Wraps the zx_object_signal syscall.
Source§

fn wait_handle( &self, signals: Signals, deadline: MonotonicInstant, ) -> Result<Signals, Status>

Waits on a handle. Wraps the zx_object_wait_one syscall.
Source§

fn wait_async_handle( &self, port: &Port, key: u64, signals: Signals, options: WaitAsyncOpts, ) -> Result<(), Status>

Causes packet delivery on the given port when the object changes state and matches signals. zx_object_wait_async syscall.
Source§

fn get_name(&self) -> Result<Name, Status>

Get the Property::NAME property for this object. Read more
Source§

fn set_name(&self, name: &Name) -> Result<(), Status>

Set the Property::NAME property for this object. Read more
Source§

fn basic_info(&self) -> Result<HandleBasicInfo, Status>

Wraps the zx_object_get_info syscall for the ZX_INFO_HANDLE_BASIC topic.
Source§

fn count_info(&self) -> Result<HandleCountInfo, Status>

Wraps the zx_object_get_info syscall for the ZX_INFO_HANDLE_COUNT topic.
Source§

fn get_koid(&self) -> Result<Koid, Status>

Returns the koid (kernel object ID) for this handle.
Source§

impl Debug for Process

Source§

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

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

impl From<Handle> for Process

Source§

fn from(handle: Handle) -> Self

Converts to this type from the input type.
Source§

impl From<Process> for Handle

Source§

fn from(x: Process) -> Handle

Converts to this type from the input type.
Source§

impl HandleBased for Process

Source§

fn duplicate_handle(&self, rights: Rights) -> Result<Self, Status>

Duplicate a handle, possibly reducing the rights available. Wraps the zx_handle_duplicate syscall.
Source§

fn replace_handle(self, rights: Rights) -> Result<Self, Status>

Create a replacement for a handle, possibly reducing the rights available. This invalidates the original handle. Wraps the zx_handle_replace syscall.
Source§

fn into_handle(self) -> Handle

Converts the value into its inner handle. Read more
Source§

fn into_raw(self) -> zx_handle_t

Converts the handle into it’s raw representation. Read more
Source§

fn from_handle(handle: Handle) -> Self

Creates an instance of this type from a handle. Read more
Source§

fn into_handle_based<H: HandleBased>(self) -> H

Creates an instance of another handle-based type from this value’s inner handle.
Source§

fn from_handle_based<H: HandleBased>(h: H) -> Self

Creates an instance of this type from the inner handle of another handle-based type.
Source§

fn is_invalid_handle(&self) -> bool

Source§

impl Hash for Process

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Ord for Process

Source§

fn cmp(&self, other: &Process) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq for Process

Source§

fn eq(&self, other: &Process) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for Process

Source§

fn partial_cmp(&self, other: &Process) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl Task for Process

Source§

fn kill(&self) -> Result<(), Status>

Kill the given task (job, process, or thread). Read more
Source§

fn suspend(&self) -> Result<Handle, Status>

Suspend the given task Read more
Source§

fn create_exception_channel_with_opts( &self, opts: ExceptionChannelOptions, ) -> Result<Channel, Status>

Create an exception channel (with options) for the task. Read more
Source§

fn create_exception_channel(&self) -> Result<Channel, Status>

Create an exception channel for the task. Read more
Source§

fn get_runtime_info(&self) -> Result<TaskRuntimeInfo, Status>

Returns the runtime information for the task. Read more
Source§

impl Eq for Process

Source§

impl StructuralPartialEq for Process

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.