/*
- * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2007 Apple Inc. All rights reserved.
*
- * @APPLE_LICENSE_HEADER_START@
- *
- * Copyright (c) 1999-2003 Apple Computer, Inc. All Rights Reserved.
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
*
* This file contains Original Code and/or Modifications of Original Code
* as defined in and that are subject to the Apple Public Source License
* Version 2.0 (the 'License'). You may not use this file except in
- * compliance with the License. Please obtain a copy of the License at
- * http://www.opensource.apple.com/apsl/ and read it before using this
- * file.
+ * compliance with the License. The rights granted to you under the License
+ * may not be used to create, or enable the creation or redistribution of,
+ * unlawful or unlicensed copies of an Apple operating system, or to
+ * circumvent, violate, or enable the circumvention or violation of, any
+ * terms of an Apple operating system software license agreement.
+ *
+ * Please obtain a copy of the License at
+ * http://www.opensource.apple.com/apsl/ and read it before using this file.
*
* The Original Code and all software distributed under the License are
* distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
* Please see the License for the specific language governing rights and
* limitations under the License.
*
- * @APPLE_LICENSE_HEADER_END@
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
*/
/*
* @OSF_FREE_COPYRIGHT@
subsystem
#if KERNEL_SERVER
KernelServer
-#endif KERNEL_SERVER
+#endif /* KERNEL_SERVER */
thread_act 3600;
#include <mach/std_types.defs>
#include <mach/mach_types.defs>
+#if !KERNEL && !LIBSYSCALL_INTERFACE
+#define PREFIX(NAME) _kernelrpc_ ## NAME
+#else
+#define PREFIX(NAME) NAME
+#endif
+
/*
* Destroy the target thread.
*
* may be stale. [Flavor THREAD_STATE_FLAVOR_LIST provides a
* list of valid flavors for the target thread.]
*/
-routine act_get_state(
+routine
+#ifdef KERNEL_SERVER
+act_get_state_to_user(
+#else
+act_get_state(
+#endif
target_act : thread_act_t;
flavor : int;
out old_state : thread_state_t, CountInOut);
* If the thread is currently executing, the state change
* may be ill-defined.
*/
-routine act_set_state(
+routine
+#ifdef KERNEL_SERVER
+act_set_state_from_user(
+#else
+act_set_state(
+#endif
target_act : thread_act_t;
flavor : int;
new_state : thread_state_t);
* may be stale. [Flavor THREAD_STATE_FLAVOR_LIST provides a
* list of valid flavors for the target thr_act.]
*/
-routine thread_get_state(
+routine
+#ifdef KERNEL_SERVER
+thread_get_state_to_user(
+#else
+thread_get_state(
+#endif
target_act : thread_act_t;
flavor : thread_state_flavor_t;
out old_state : thread_state_t, CountInOut);
* If the thread is currently executing, the state change
* may be ill-defined.
*/
-routine thread_set_state(
+routine
+#ifdef KERNEL_SERVER
+thread_set_state_from_user(
+#else
+thread_set_state(
+#endif
target_act : thread_act_t;
flavor : thread_state_flavor_t;
new_state : thread_state_t);
target_act : thread_act_t);
-routine thread_depress_abort(
+routine
+#ifdef KERNEL_SERVER
+thread_depress_abort_from_user(
+#else
+thread_depress_abort(
+#endif
thread : thread_act_t);
* Returns information about the target thread.
*/
routine thread_info(
- target_act : thread_act_t;
+ target_act : thread_inspect_t;
flavor : thread_flavor_t;
out thread_info_out : thread_info_t, CountInOut);
* Lookup some of the old exception handlers for a thread
*/
routine thread_get_exception_ports(
- thread : thread_act_t;
+ thread : thread_inspect_t;
exception_mask : exception_mask_t;
out masks : exception_mask_array_t;
out old_handlers : exception_handler_array_t, SameCount;
/*
* OBSOLETE interface.
*/
-routine thread_policy(
+routine PREFIX(thread_policy)(
thr_act : thread_act_t;
policy : policy_t;
base : policy_base_t;
* (Approved Mac OS X microkernel interface)
*/
-routine thread_policy_set(
+routine PREFIX(thread_policy_set)(
thread : thread_act_t;
flavor : thread_policy_flavor_t;
policy_info : thread_policy_t);
routine thread_policy_get(
- thread : thread_act_t;
+ thread : thread_inspect_t;
flavor : thread_policy_flavor_t;
out policy_info : thread_policy_t, CountInOut;
inout get_default : boolean_t);
/*
- * Thread profiling
- * This call is only valid for MACH_PROF compiled kernels.
- * Otherwise, KERN_FAILURE is returned.
+ * Removed from the kernel.
*/
+#if KERNEL_SERVER
+skip;
+#else
routine thread_sample(
thread : thread_act_t;
reply : mach_port_make_send_t);
+#endif
/*
- * JMM - Keep etap and processor_set related things at the end
- * because they are likely to be removed.
- */
-/*
- * Sets the ETAP trace status of the target thread.
+ * ETAP has been removed from the kernel.
*/
+#if KERNEL_SERVER
+skip;
+#else
routine etap_trace_thread(
target_act : thread_act_t;
trace_status : boolean_t);
+#endif
/*
* Assign thread to processor set.
thread : thread_act_t;
out assigned_set : processor_set_name_t);
-
/*
* OBSOLETE interface.
*/
-routine thread_set_policy(
- thr_act : thread_act_t;
- pset : processor_set_t;
- policy : policy_t;
- base : policy_base_t;
- limit : policy_limit_t);
+routine PREFIX(thread_set_policy)(
+ thr_act : thread_act_t;
+ pset : processor_set_t;
+ policy : policy_t;
+ base : policy_base_t;
+ limit : policy_limit_t);
+
+routine thread_get_mach_voucher(
+ thr_act : thread_act_t;
+ which : mach_voucher_selector_t;
+ out voucher : ipc_voucher_t);
+
+routine thread_set_mach_voucher(
+ thr_act : thread_act_t;
+ voucher : ipc_voucher_t);
+
+routine thread_swap_mach_voucher(
+ thr_act : thread_act_t;
+ new_voucher : ipc_voucher_t;
+ inout old_voucher : ipc_voucher_t);
+
+/* vim: set ft=c : */