fdwalk should return 0 on an empty directory
[kopensolaris-gnu/glibc.git] / mach / mach / mach_traps.h
1 /* Copyright (C) 1994,96,97,2002 Free Software Foundation, Inc.
2    This file is part of the GNU C Library.
3
4    The GNU C Library is free software; you can redistribute it and/or
5    modify it under the terms of the GNU Lesser General Public
6    License as published by the Free Software Foundation; either
7    version 2.1 of the License, or (at your option) any later version.
8
9    The GNU C Library is distributed in the hope that it will be useful,
10    but WITHOUT ANY WARRANTY; without even the implied warranty of
11    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12    Lesser General Public License for more details.
13
14    You should have received a copy of the GNU Lesser General Public
15    License along with the GNU C Library; if not, write to the Free
16    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
17    02111-1307 USA.  */
18
19 /* Declare the few Mach system calls (except mach_msg, in <mach/message.h>).
20    This does not include the kernel RPC shortcut calls (in <mach-shortcuts.h>).
21
22    This file omits the MACH_IPC_COMPAT functions.  */
23
24 #ifndef _MACH_MACH_TRAPS_H
25
26 #define _MACH_MACH_TRAPS_H_     1
27
28 #include <mach/port.h>
29 #include <mach/message.h>       /* mach_msg_timeout_t */
30 #include <mach/kern_return.h>
31
32 /* Create and return a new receive right.  */
33 extern mach_port_t mach_reply_port (void);
34 extern mach_port_t __mach_reply_port (void);
35
36 /* Return the thread control port for the calling thread.  */
37 extern mach_port_t mach_thread_self (void);
38 extern mach_port_t __mach_thread_self (void);
39
40 /* Return the task control port for the calling task.
41    The parens are needed to protect against the macro in <mach_init.h>.  */
42 extern mach_port_t (mach_task_self) (void);
43 extern mach_port_t (__mach_task_self) (void);
44
45 /* Return the host information port for the host of the calling task.  */
46 extern mach_port_t mach_host_self (void);
47 extern mach_port_t __mach_host_self (void);
48
49 /* Attempt to context switch the current thread off the processor.  Returns
50    true if there are other threads that can be run and false if not.  */
51 extern boolean_t swtch (void);
52 extern boolean_t __swtch (void);
53
54 /* Attempt to context switch the current thread off the processor.  Lower
55    the thread's priority as much as possible.  The thread's priority will
56    be restored when it runs again.  PRIORITY is currently unused.  Return
57    true if there are other threads that can be run and false if not.  */
58 extern boolean_t swtch_pri (int priority);
59 extern boolean_t __swtch_pri (int priority);
60
61 /* Attempt to context switch the current thread of the processor.  Try
62    to run NEW_THREAD next, ignoring normal scheduling policies.  The
63    OPTION value comes from <mach/thread_switch.h>.  If OPTION is
64    SWITCH_OPTION_WAIT, then block the current thread for TIME
65    milliseconds.  If OPTION is SWITCH_OPTION_DEPRESS, then block for
66    TIME milliseconds and depress the thread's priority as done by
67    swtch_pri.  If OPTION is SWITCH_OPTION_NONE, ignore TIME.  */
68 kern_return_t thread_switch (mach_port_t new_thread,
69                              int option, mach_msg_timeout_t option_time);
70 kern_return_t __thread_switch (mach_port_t new_thread,
71                              int option, mach_msg_timeout_t option_time);
72
73 /* Block the current thread until the kernel (or device) event
74    identified by EVENT occurs.  */
75 kern_return_t evc_wait (unsigned int event);
76 kern_return_t __evc_wait (unsigned int event);
77
78
79 #endif  /* mach/mach_traps.h */