]> git.saurik.com Git - apple/xnu.git/blame - osfmk/mach/mach_types.h
xnu-7195.50.7.100.1.tar.gz
[apple/xnu.git] / osfmk / mach / mach_types.h
CommitLineData
1c79356b 1/*
cb323159 2 * Copyright (c) 2000-2018 Apple Inc. All rights reserved.
1c79356b 3 *
2d21ac55 4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
0a7de745 5 *
2d21ac55
A
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. The rights granted to you under the License
10 * may not be used to create, or enable the creation or redistribution of,
11 * unlawful or unlicensed copies of an Apple operating system, or to
12 * circumvent, violate, or enable the circumvention or violation of, any
13 * terms of an Apple operating system software license agreement.
0a7de745 14 *
2d21ac55
A
15 * Please obtain a copy of the License at
16 * http://www.opensource.apple.com/apsl/ and read it before using this file.
0a7de745 17 *
2d21ac55
A
18 * The Original Code and all software distributed under the License are
19 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
8f6c56a5
A
20 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
2d21ac55
A
22 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23 * Please see the License for the specific language governing rights and
24 * limitations under the License.
0a7de745 25 *
2d21ac55 26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
1c79356b
A
27 */
28/*
29 * @OSF_COPYRIGHT@
30 */
0a7de745 31/*
1c79356b
A
32 * Mach Operating System
33 * Copyright (c) 1991,1990,1989,1988 Carnegie Mellon University
34 * All Rights Reserved.
0a7de745 35 *
1c79356b
A
36 * Permission to use, copy, modify and distribute this software and its
37 * documentation is hereby granted, provided that both the copyright
38 * notice and this permission notice appear in all copies of the
39 * software, derivative works or modified versions, and any portions
40 * thereof, and that both notices appear in supporting documentation.
0a7de745 41 *
1c79356b
A
42 * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
43 * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
44 * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
0a7de745 45 *
1c79356b 46 * Carnegie Mellon requests users of this software to return to
0a7de745 47 *
1c79356b
A
48 * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
49 * School of Computer Science
50 * Carnegie Mellon University
51 * Pittsburgh PA 15213-3890
0a7de745 52 *
1c79356b
A
53 * any improvements or extensions that they make and grant Carnegie Mellon
54 * the rights to redistribute these changes.
55 */
56/*
57 */
2d21ac55
A
58/*
59 * NOTICE: This file was modified by SPARTA, Inc. in 2005 to introduce
60 * support for mandatory and extensible security protections. This notice
61 * is included in support of clause 2.2 (b) of the Apple Public License,
62 * Version 2.0.
63 */
1c79356b
A
64/*
65 * File: mach/mach_types.h
66 * Author: Avadis Tevanian, Jr., Michael Wayne Young
67 * Date: 1986
68 *
69 * Mach external interface definitions.
70 *
71 */
72
0a7de745 73#ifndef _MACH_MACH_TYPES_H_
1c79356b
A
74#define _MACH_MACH_TYPES_H_
75
0b4e3aa0
A
76#include <stdint.h>
77
91447636
A
78#include <sys/cdefs.h>
79
1c79356b 80#include <mach/host_info.h>
55e303ae
A
81#include <mach/host_notify.h>
82#include <mach/host_special_ports.h>
1c79356b
A
83#include <mach/machine.h>
84#include <mach/machine/vm_types.h>
85#include <mach/memory_object_types.h>
91447636 86#include <mach/message.h>
1c79356b
A
87#include <mach/exception_types.h>
88#include <mach/port.h>
fe8ab488 89#include <mach/mach_voucher_types.h>
1c79356b
A
90#include <mach/processor_info.h>
91#include <mach/task_info.h>
5ba3f43e 92#include <mach/task_inspect.h>
1c79356b
A
93#include <mach/task_policy.h>
94#include <mach/task_special_ports.h>
95#include <mach/thread_info.h>
96#include <mach/thread_policy.h>
97#include <mach/thread_special_ports.h>
98#include <mach/thread_status.h>
99#include <mach/time_value.h>
100#include <mach/clock_types.h>
101#include <mach/vm_attributes.h>
102#include <mach/vm_inherit.h>
91447636 103#include <mach/vm_purgable.h>
1c79356b
A
104#include <mach/vm_behavior.h>
105#include <mach/vm_prot.h>
106#include <mach/vm_statistics.h>
107#include <mach/vm_sync.h>
108#include <mach/vm_types.h>
109#include <mach/vm_region.h>
110#include <mach/kmod.h>
39037602 111#include <mach/dyld_kernel.h>
1c79356b 112
0a7de745 113#ifdef KERNEL
1c79356b
A
114
115#include <mach/vm_param.h>
116
117/*
118 * If we are in the kernel, then pick up the kernel definitions for
119 * the basic mach types.
120 */
f427ee49
A
121typedef struct task *task_t, *task_name_t, *task_inspect_t, *task_read_t, *task_suspension_token_t, *task_policy_set_t, *task_policy_get_t;
122typedef struct thread *thread_t, *thread_act_t, *thread_inspect_t, *thread_read_t;
123typedef struct ipc_space *ipc_space_t, *ipc_space_read_t, *ipc_space_inspect_t;
0a7de745
A
124typedef struct coalition *coalition_t;
125typedef struct host *host_t;
126typedef struct host *host_priv_t;
127typedef struct host *host_security_t;
128typedef struct processor *processor_t;
129typedef struct processor_set *processor_set_t;
130typedef struct processor_set *processor_set_control_t;
131typedef struct semaphore *semaphore_t;
132typedef struct ledger *ledger_t;
133typedef struct alarm *alarm_t;
134typedef struct clock *clock_serv_t;
135typedef struct clock *clock_ctrl_t;
cb323159 136typedef struct arcade_register *arcade_register_t;
f427ee49
A
137typedef struct ipc_eventlink *ipc_eventlink_t;
138typedef struct ipc_port *eventlink_port_pair_t[2];
139typedef struct suid_cred *suid_cred_t;
fe8ab488 140
39236c6e
A
141/*
142 * OBSOLETE: lock_set interfaces are obsolete.
143 */
0a7de745
A
144typedef struct lock_set *lock_set_t;
145struct lock_set;
39236c6e 146
0a7de745 147#ifndef MACH_KERNEL_PRIVATE
91447636
A
148
149__BEGIN_DECLS
9bccf70c 150
0a7de745
A
151struct task;
152struct thread;
153struct host;
154struct processor;
155struct processor_set;
156struct semaphore;
157struct ledger;
158struct alarm;
159struct clock;
cb323159 160struct arcade_register;
f427ee49
A
161struct ipc_eventlink;
162struct ipc_port;
ea3f0419 163struct suid_cred;
cb323159 164
91447636 165__END_DECLS
1c79356b 166
0a7de745 167#endif /* MACH_KERNEL_PRIVATE */
91447636 168
0a7de745 169#else /* KERNEL */
1c79356b
A
170
171/*
172 * If we are not in the kernel, then these will all be represented by
173 * ports at user-space.
174 */
0a7de745
A
175typedef mach_port_t task_t;
176typedef mach_port_t task_name_t;
f427ee49
A
177typedef mach_port_t task_policy_set_t;
178typedef mach_port_t task_policy_get_t;
0a7de745 179typedef mach_port_t task_inspect_t;
f427ee49 180typedef mach_port_t task_read_t;
0a7de745
A
181typedef mach_port_t task_suspension_token_t;
182typedef mach_port_t thread_t;
183typedef mach_port_t thread_act_t;
184typedef mach_port_t thread_inspect_t;
f427ee49 185typedef mach_port_t thread_read_t;
0a7de745 186typedef mach_port_t ipc_space_t;
f427ee49 187typedef mach_port_t ipc_space_read_t;
0a7de745
A
188typedef mach_port_t ipc_space_inspect_t;
189typedef mach_port_t coalition_t;
190typedef mach_port_t host_t;
191typedef mach_port_t host_priv_t;
192typedef mach_port_t host_security_t;
193typedef mach_port_t processor_t;
194typedef mach_port_t processor_set_t;
195typedef mach_port_t processor_set_control_t;
196typedef mach_port_t semaphore_t;
197typedef mach_port_t lock_set_t;
198typedef mach_port_t ledger_t;
199typedef mach_port_t alarm_t;
200typedef mach_port_t clock_serv_t;
201typedef mach_port_t clock_ctrl_t;
cb323159 202typedef mach_port_t arcade_register_t;
f427ee49
A
203typedef mach_port_t ipc_eventlink_t;
204typedef mach_port_t eventlink_port_pair_t[2];
ea3f0419
A
205typedef mach_port_t suid_cred_t;
206
0a7de745 207#endif /* KERNEL */
1c79356b 208
9bccf70c
A
209/*
210 * These aren't really unique types. They are just called
211 * out as unique types at one point in history. So we list
212 * them here for compatibility.
213 */
0a7de745 214typedef processor_set_t processor_set_name_t;
1c79356b
A
215
216/*
91447636 217 * These types are just hard-coded as ports
1c79356b 218 */
0a7de745
A
219typedef mach_port_t clock_reply_t;
220typedef mach_port_t bootstrap_t;
221typedef mach_port_t mem_entry_name_port_t;
222typedef mach_port_t exception_handler_t;
223typedef exception_handler_t *exception_handler_array_t;
224typedef mach_port_t vm_task_entry_t;
225typedef mach_port_t io_master_t;
226typedef mach_port_t UNDServerRef;
f427ee49 227typedef mach_port_t mach_eventlink_t;
1c79356b
A
228
229/*
91447636 230 * Mig doesn't translate the components of an array.
1c79356b
A
231 * For example, Mig won't use the thread_t translations
232 * to translate a thread_array_t argument. So, these definitions
233 * are not completely accurate at the moment for other kernel
91447636 234 * components.
1c79356b 235 */
0a7de745
A
236typedef task_t *task_array_t;
237typedef thread_t *thread_array_t;
238typedef processor_set_t *processor_set_array_t;
239typedef processor_set_t *processor_set_name_array_t;
240typedef processor_t *processor_array_t;
241typedef thread_act_t *thread_act_array_t;
242typedef ledger_t *ledger_array_t;
1c79356b
A
243
244/*
245 * However the real mach_types got declared, we also have to declare
246 * types with "port" in the name for compatability with the way OSF
247 * had declared the user interfaces at one point. Someday these should
248 * go away.
249 */
0a7de745
A
250typedef task_t task_port_t;
251typedef task_array_t task_port_array_t;
252typedef thread_t thread_port_t;
253typedef thread_array_t thread_port_array_t;
254typedef ipc_space_t ipc_space_port_t;
255typedef host_t host_name_t;
256typedef host_t host_name_port_t;
257typedef processor_set_t processor_set_port_t;
258typedef processor_set_t processor_set_name_port_t;
259typedef processor_set_array_t processor_set_name_port_array_t;
260typedef processor_set_t processor_set_control_port_t;
261typedef processor_t processor_port_t;
262typedef processor_array_t processor_port_array_t;
263typedef thread_act_t thread_act_port_t;
264typedef thread_act_array_t thread_act_port_array_t;
265typedef semaphore_t semaphore_port_t;
266typedef lock_set_t lock_set_port_t;
267typedef ledger_t ledger_port_t;
268typedef ledger_array_t ledger_port_array_t;
269typedef alarm_t alarm_port_t;
270typedef clock_serv_t clock_serv_port_t;
271typedef clock_ctrl_t clock_ctrl_port_t;
272typedef exception_handler_t exception_port_t;
1c79356b 273typedef exception_handler_array_t exception_port_arrary_t;
cb323159
A
274typedef char vfs_path_t[4096];
275typedef char nspace_path_t[1024]; /* 1024 == PATH_MAX */
ea3f0419
A
276typedef char suid_cred_path_t[1024];
277typedef uint32_t suid_cred_uid_t;
1c79356b 278
cb323159
A
279#ifdef KERNEL
280#define TASK_NULL ((task_t) NULL)
281#define TASK_NAME_NULL ((task_name_t) NULL)
f427ee49
A
282#define TASK_INSPECT_NULL ((task_inspect_t) NULL)
283#define TASK_READ_NULL ((task_read_t) NULL)
cb323159
A
284#define THREAD_NULL ((thread_t) NULL)
285#define THREAD_INSPECT_NULL ((thread_inspect_t)NULL)
f427ee49 286#define THREAD_READ_NULL ((thread_read_t)NULL)
cb323159
A
287#define TID_NULL ((uint64_t) NULL)
288#define THR_ACT_NULL ((thread_act_t) NULL)
289#define IPC_SPACE_NULL ((ipc_space_t) NULL)
f427ee49 290#define IPC_SPACE_READ_NULL ((ipc_space_read_t) NULL)
cb323159
A
291#define IPC_SPACE_INSPECT_NULL ((ipc_space_inspect_t) NULL)
292#define COALITION_NULL ((coalition_t) NULL)
293#define HOST_NULL ((host_t) NULL)
294#define HOST_PRIV_NULL ((host_priv_t)NULL)
295#define HOST_SECURITY_NULL ((host_security_t)NULL)
296#define PROCESSOR_SET_NULL ((processor_set_t) NULL)
297#define PROCESSOR_NULL ((processor_t) NULL)
298#define SEMAPHORE_NULL ((semaphore_t) NULL)
299#define LOCK_SET_NULL ((lock_set_t) NULL)
300#define LEDGER_NULL ((ledger_t) NULL)
301#define ALARM_NULL ((alarm_t) NULL)
302#define CLOCK_NULL ((clock_t) NULL)
303#define UND_SERVER_NULL ((UNDServerRef) NULL)
304#define ARCADE_REG_NULL ((arcade_register_t) NULL)
f427ee49
A
305#define MACH_EVENTLINK_NULL ((mach_eventlink_t) 0)
306#define IPC_EVENTLINK_NULL ((ipc_eventlink_t) NULL)
307#define SUID_CRED_NULL ((suid_cred_t) NULL)
cb323159 308#else
0a7de745
A
309#define TASK_NULL ((task_t) 0)
310#define TASK_NAME_NULL ((task_name_t) 0)
f427ee49
A
311#define TASK_INSPECT_NULL ((task_inspect_t) 0)
312#define TASK_READ_NULL ((task_read_t) 0)
0a7de745 313#define THREAD_NULL ((thread_t) 0)
cb323159 314#define THREAD_INSPECT_NULL ((thread_inspect_t) 0)
f427ee49 315#define THREAD_READ_NULL ((thread_read_t) 0)
0a7de745
A
316#define TID_NULL ((uint64_t) 0)
317#define THR_ACT_NULL ((thread_act_t) 0)
318#define IPC_SPACE_NULL ((ipc_space_t) 0)
f427ee49 319#define IPC_SPACE_READ_NULL ((ipc_space_read_t) 0)
0a7de745
A
320#define IPC_SPACE_INSPECT_NULL ((ipc_space_inspect_t) 0)
321#define COALITION_NULL ((coalition_t) 0)
322#define HOST_NULL ((host_t) 0)
cb323159
A
323#define HOST_PRIV_NULL ((host_priv_t) 0)
324#define HOST_SECURITY_NULL ((host_security_t) 0)
0a7de745
A
325#define PROCESSOR_SET_NULL ((processor_set_t) 0)
326#define PROCESSOR_NULL ((processor_t) 0)
327#define SEMAPHORE_NULL ((semaphore_t) 0)
328#define LOCK_SET_NULL ((lock_set_t) 0)
329#define LEDGER_NULL ((ledger_t) 0)
330#define ALARM_NULL ((alarm_t) 0)
331#define CLOCK_NULL ((clock_t) 0)
332#define UND_SERVER_NULL ((UNDServerRef) 0)
cb323159 333#define ARCADE_REG_NULL ((arcade_register_t) 0)
f427ee49
A
334#define MACH_EVENTLINK_NULL ((mach_eventlink_t) 0)
335#define IPC_EVENTLINK_NULL ((ipc_eventlink_t) 0)
336#define SUID_CRED_NULL ((suid_cred_t) 0)
cb323159 337#endif
1c79356b 338
f427ee49
A
339/* capability strictly _DECREASING_.
340 * not ordered the other way around because we want TASK_FLAVOR_CONTROL
341 * to be closest to the itk_lock. see task.h.
342 */
343typedef unsigned int mach_task_flavor_t;
344#define TASK_FLAVOR_CONTROL 0 /* a task_t */
345#define TASK_FLAVOR_READ 1 /* a task_read_t */
346#define TASK_FLAVOR_INSPECT 2 /* a task_inspect_t */
347#define TASK_FLAVOR_NAME 3 /* a task_name_t */
348
349/* capability strictly _DECREASING_ */
350typedef unsigned int mach_thread_flavor_t;
351#define THREAD_FLAVOR_CONTROL 0 /* a thread_t */
352#define THREAD_FLAVOR_READ 1 /* a thread_read_t */
353#define THREAD_FLAVOR_INSPECT 2 /* a thread_inspect_t */
354
316670eb 355/* DEPRECATED */
0a7de745
A
356typedef natural_t ledger_item_t;
357#define LEDGER_ITEM_INFINITY ((ledger_item_t) (~0))
316670eb 358
0a7de745 359typedef int64_t ledger_amount_t;
39236c6e 360#define LEDGER_LIMIT_INFINITY ((ledger_amount_t)((1ULL << 63) - 1))
91447636 361
0a7de745
A
362typedef mach_vm_offset_t *emulation_vector_t;
363typedef char *user_subsystem_t;
1c79356b 364
0a7de745 365typedef char *labelstr_t;
1c79356b
A
366/*
367 * Backwards compatibility, for those programs written
368 * before mach/{std,mach}_types.{defs,h} were set up.
369 */
370#include <mach/std_types.h>
371
0a7de745 372#endif /* _MACH_MACH_TYPES_H_ */