2 * Copyright (c) 2005 Apple Computer, Inc. All rights reserved.
4 * @APPLE_APACHE_LICENSE_HEADER_START@
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
18 * @APPLE_APACHE_LICENSE_HEADER_END@
20 #ifndef __LAUNCHD_RUNTIME_H__
21 #define __LAUNCHD_RUNTIME_H__
23 #include <mach/mach.h>
24 #include <sys/types.h>
25 #include <bsm/libbsm.h>
29 #include "launchd_runtime_kill.h"
41 * Use launchd_assumes() when we can recover, even if it means we leak or limp along.
43 * Use launchd_assert() for core initialization routines.
45 #define launchd_assumes(e) \
46 (__builtin_expect(!(e), 0) ? _log_launchd_bug(__rcs_file_version__, __FILE__, __LINE__, #e), false : true)
48 #define launchd_blame(e, b) \
49 (__builtin_expect(!(e), 0) ? syslog(LOG_DEBUG, "Encountered bug: %d", b), false : true)
51 #define launchd_assert(e) if (__builtin_constant_p(e)) { char __compile_time_assert__[e ? 1 : -1] __attribute__((unused)); } else if (!launchd_assumes(e)) { abort(); }
53 #define likely(x) __builtin_expect((bool)(x), true)
54 #define unlikely(x) __builtin_expect((bool)(x), false)
56 void _log_launchd_bug(const char *rcs_rev
, const char *path
, unsigned int line
, const char *test
);
58 typedef void (*kq_callback
)(void *, struct kevent
*);
59 typedef boolean_t (*mig_callback
)(mach_msg_header_t
*, mach_msg_header_t
*);
60 typedef void (*timeout_callback
)(void);
62 mach_port_t
runtime_get_kernel_port(void);
64 void runtime_add_ref(void);
65 void runtime_del_ref(void);
67 void launchd_runtime_init(void);
68 void launchd_runtime_init2(void);
69 void launchd_runtime(void) __attribute__((noreturn
));
71 int runtime_close(int fd
);
72 int runtime_fsync(int fd
);
74 #define RUNTIME_ADVISABLE_IDLE_TIMEOUT 30
76 void runtime_set_timeout(timeout_callback to_cb
, unsigned int sec
);
77 kern_return_t
runtime_add_mport(mach_port_t name
, mig_callback demux
, mach_msg_size_t msg_size
);
78 kern_return_t
runtime_remove_mport(mach_port_t name
);
79 bool runtime_get_caller_creds(struct ldcred
*ldc
);
81 const char *signal_to_C_name(unsigned int sig
);
82 const char *reboot_flags_to_C_names(unsigned int flags
);
83 const char *proc_flags_to_C_names(unsigned int flags
);
86 int kevent_bulk_mod(struct kevent
*kev
, size_t kev_cnt
);
87 int kevent_mod(uintptr_t ident
, short filter
, u_short flags
, u_int fflags
, intptr_t data
, void *udata
);
89 pid_t
runtime_fork(mach_port_t bsport
);
91 kern_return_t
runtime_log_forward(uid_t forward_uid
, gid_t forward_gid
, vm_offset_t inval
, mach_msg_type_number_t invalCnt
);
92 kern_return_t
runtime_log_drain(mach_port_t srp
, vm_offset_t
*outval
, mach_msg_type_number_t
*outvalCnt
);
94 #define LOG_APPLEONLY 0x4141504c /* AAPL in hex */
96 struct runtime_syslog_attr
{
97 const char *from_name
;
98 const char *about_name
;
99 const char *session_name
;
106 int runtime_setlogmask(int maskpri
);
107 void runtime_closelog(void);
108 void runtime_syslog(int pri
, const char *message
, ...) __attribute__((format(printf
, 2, 3)));
109 void runtime_vsyslog(struct runtime_syslog_attr
*attr
, const char *message
, va_list args
) __attribute__((format(printf
, 2, 0)));
112 kern_return_t
launchd_set_bport(mach_port_t name
);
113 kern_return_t
launchd_get_bport(mach_port_t
*name
);
114 kern_return_t
launchd_mport_notify_req(mach_port_t name
, mach_msg_id_t which
);
115 kern_return_t
launchd_mport_notify_cancel(mach_port_t name
, mach_msg_id_t which
);
116 kern_return_t
launchd_mport_create_recv(mach_port_t
*name
);
117 kern_return_t
launchd_mport_deallocate(mach_port_t name
);
118 kern_return_t
launchd_mport_make_send(mach_port_t name
);
119 kern_return_t
launchd_mport_close_recv(mach_port_t name
);