summaryrefslogtreecommitdiffstats
path: root/third_party/rust/mach2/src/task.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /third_party/rust/mach2/src/task.rs
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'third_party/rust/mach2/src/task.rs')
-rw-r--r--third_party/rust/mach2/src/task.rs41
1 files changed, 41 insertions, 0 deletions
diff --git a/third_party/rust/mach2/src/task.rs b/third_party/rust/mach2/src/task.rs
new file mode 100644
index 0000000000..1ca2280eb1
--- /dev/null
+++ b/third_party/rust/mach2/src/task.rs
@@ -0,0 +1,41 @@
+//! This module corresponds to `mach/task.defs`.
+
+use kern_return::kern_return_t;
+use mach_types::{task_name_t, task_t, thread_act_array_t};
+use message::mach_msg_type_number_t;
+use port::mach_port_t;
+use task_info::{task_flavor_t, task_info_t};
+
+pub type task_special_port_t = ::libc::c_int;
+
+pub const TASK_KERNEL_PORT: task_special_port_t = 1;
+pub const TASK_HOST_PORT: task_special_port_t = 2;
+pub const TASK_NAME_PORT: task_special_port_t = 3;
+pub const TASK_BOOTSTRAP_PORT: task_special_port_t = 4;
+
+extern "C" {
+ pub fn task_resume(target_task: task_t) -> kern_return_t;
+ pub fn task_suspend(target_task: task_t) -> kern_return_t;
+ pub fn task_get_special_port(
+ task: task_t,
+ which_port: task_special_port_t,
+ special_port: *mut mach_port_t,
+ ) -> kern_return_t;
+ pub fn task_threads(
+ target_task: task_t,
+ act_list: *mut thread_act_array_t,
+ act_list_cnt: *mut mach_msg_type_number_t,
+ ) -> kern_return_t;
+ pub fn task_info(
+ target_task: task_name_t,
+ flavor: task_flavor_t,
+ task_info_out: task_info_t,
+ task_info_outCnt: *mut mach_msg_type_number_t,
+ ) -> kern_return_t;
+ pub fn task_set_info(
+ target_task: task_t,
+ flavor: task_flavor_t,
+ task_info_in: task_info_t,
+ task_info_inCnt: mach_msg_type_number_t,
+ ) -> kern_return_t;
+}