2 * Copyright (c) 2007, 2008, 2011-2013 Apple Inc. All rights reserved.
4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
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.
15 * Please obtain a copy of the License at
16 * http://www.opensource.apple.com/apsl/ and read it before using this file.
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
20 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
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.
26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
29 #include <TargetConditionals.h> // for TARGET_OS_*
33 #include <libc_private.h>
35 #include <pthread/private.h>
39 #include <_libkernel_init.h> // Must be after voucher_private.h
41 #include <mach-o/dyld_priv.h>
43 // system library initialisers
44 extern void mach_init(void); // from libsystem_kernel.dylib
45 extern void __libplatform_init(void *future_use
, const char *envp
[], const char *apple
[], const struct ProgramVars
*vars
);
46 extern void __pthread_init(const struct _libpthread_functions
*libpthread_funcs
, const char *envp
[], const char *apple
[], const struct ProgramVars
*vars
); // from libsystem_pthread.dylib
47 extern void __malloc_init(const char *apple
[]); // from libsystem_malloc.dylib
48 extern void __keymgr_initializer(void); // from libkeymgr.dylib
49 extern void _dyld_initializer(void); // from libdyld.dylib
50 extern void libdispatch_init(void); // from libdispatch.dylib
51 extern void _libxpc_initializer(void); // from libxpc.dylib
52 extern void _libsecinit_initializer(void); // from libsecinit.dylib
53 extern void _libtrace_init(void); // from libsystem_trace.dylib
54 extern void _container_init(const char *apple
[]); // from libsystem_containermanager.dylib
55 extern void __libdarwin_init(void); // from libsystem_darwin.dylib
58 // signal malloc stack logging that initialisation has finished
59 extern void __stack_logging_early_finished(void); // form libsystem_c.dylib
61 // clear qos tsd (from pthread)
62 extern void _pthread_clear_qos_tsd(mach_port_t
) __attribute__((weak_import
));
64 // system library atfork handlers
65 extern void _pthread_atfork_prepare(void);
66 extern void _pthread_atfork_parent(void);
67 extern void _pthread_atfork_child(void);
68 extern void _pthread_atfork_prepare_handlers();
69 extern void _pthread_atfork_parent_handlers(void);
70 extern void _pthread_atfork_child_handlers(void);
71 extern void _pthread_exit_if_canceled(int);
73 extern void dispatch_atfork_prepare(void);
74 extern void dispatch_atfork_parent(void);
75 extern void dispatch_atfork_child(void);
77 extern void _libtrace_fork_child(void);
79 extern void _malloc_fork_prepare(void);
80 extern void _malloc_fork_parent(void);
81 extern void _malloc_fork_child(void);
83 extern void _mach_fork_child(void);
84 extern void _notify_fork_child(void);
85 extern void _dyld_fork_child(void);
86 extern void xpc_atfork_prepare(void);
87 extern void xpc_atfork_parent(void);
88 extern void xpc_atfork_child(void);
89 extern void _libSC_info_fork_prepare(void);
90 extern void _libSC_info_fork_parent(void);
91 extern void _libSC_info_fork_child(void);
92 extern void _asl_fork_child(void);
94 #if defined(HAVE_SYSTEM_CORESERVICES)
95 // libsystem_coreservices.dylib
96 extern void _libcoreservices_fork_child(void);
97 extern char *_dirhelper(int, char *, size_t);
100 // advance decls for below;
101 void libSystem_atfork_prepare(void);
102 void libSystem_atfork_parent(void);
103 void libSystem_atfork_child(void);
105 #if CURRENT_VARIANT_asan
106 const char *__asan_default_options(void);
109 // libsyscall_initializer() initializes all of libSystem.dylib
110 // <rdar://problem/4892197>
111 __attribute__((constructor
))
113 libSystem_initializer(int argc
,
117 const struct ProgramVars
* vars
)
119 static const struct _libkernel_functions libkernel_funcs
= {
126 ._pthread_exit_if_canceled
= _pthread_exit_if_canceled
,
127 // V2 functions (removed)
129 .pthread_clear_qos_tsd
= _pthread_clear_qos_tsd
,
132 static const struct _libpthread_functions libpthread_funcs
= {
139 static const struct _libc_functions libc_funcs
= {
141 .atfork_prepare
= libSystem_atfork_prepare
,
142 .atfork_parent
= libSystem_atfork_parent
,
143 .atfork_child
= libSystem_atfork_child
,
144 #if defined(HAVE_SYSTEM_CORESERVICES)
145 .dirhelper
= _dirhelper
,
149 __libkernel_init(&libkernel_funcs
, envp
, apple
, vars
);
151 __libplatform_init(NULL
, envp
, apple
, vars
);
153 __pthread_init(&libpthread_funcs
, envp
, apple
, vars
);
155 _libc_initializer(&libc_funcs
, envp
, apple
, vars
);
157 // TODO: Move __malloc_init before __libc_init after breaking malloc's upward link to Libc
158 __malloc_init(apple
);
161 /* <rdar://problem/9664631> */
162 __keymgr_initializer();
165 // No ASan interceptors are invoked before this point. ASan is normally initialized via the malloc interceptor:
166 // _dyld_initializer() -> tlv_load_notification -> wrap_malloc -> ASanInitInternal
171 _libxpc_initializer();
173 #if CURRENT_VARIANT_asan
174 setenv("DT_BYPASS_LEAKS_CHECK", "1", 1);
177 // must be initialized after dispatch
180 #if !(TARGET_OS_EMBEDDED || TARGET_OS_SIMULATOR)
181 _libsecinit_initializer();
184 #if defined(HAVE_SYSTEM_CONTAINERMANAGER)
185 _container_init(apple
);
190 __stack_logging_early_finished();
192 #if !TARGET_OS_IPHONE
193 /* <rdar://problem/22139800> - Preserve the old behavior of apple[] for
194 * programs that haven't linked against newer SDK.
196 #define APPLE0_PREFIX "executable_path="
197 if (dyld_get_program_sdk_version() < DYLD_MACOSX_VERSION_10_11
){
198 if (strncmp(apple
[0], APPLE0_PREFIX
, strlen(APPLE0_PREFIX
)) == 0){
199 apple
[0] = apple
[0] + strlen(APPLE0_PREFIX
);
204 /* <rdar://problem/11588042>
205 * C99 standard has the following in section 7.5(3):
206 * "The value of errno is zero at program startup, but is never set
207 * to zero by any library function."
213 * libSystem_atfork_{prepare,parent,child}() are called by libc during fork(2).
216 libSystem_atfork_prepare(void)
218 // first call client prepare handlers registered with pthread_atfork()
219 _pthread_atfork_prepare_handlers();
221 // second call hardwired fork prepare handlers for Libsystem components
222 // in the _reverse_ order of library initalization above
223 _libSC_info_fork_prepare();
224 xpc_atfork_prepare();
225 dispatch_atfork_prepare();
226 _malloc_fork_prepare();
227 _pthread_atfork_prepare();
231 libSystem_atfork_parent(void)
233 // first call hardwired fork parent handlers for Libsystem components
234 // in the order of library initalization above
235 _pthread_atfork_parent();
236 _malloc_fork_parent();
237 dispatch_atfork_parent();
239 _libSC_info_fork_parent();
241 // second call client parent handlers registered with pthread_atfork()
242 _pthread_atfork_parent_handlers();
246 libSystem_atfork_child(void)
248 // first call hardwired fork child handlers for Libsystem components
249 // in the order of library initalization above
251 _pthread_atfork_child();
253 _malloc_fork_child();
254 _libc_fork_child(); // _arc4_fork_child calls malloc
255 dispatch_atfork_child();
256 #if defined(HAVE_SYSTEM_CORESERVICES)
257 _libcoreservices_fork_child();
260 _notify_fork_child();
262 _libtrace_fork_child();
263 _libSC_info_fork_child();
265 // second call client parent handlers registered with pthread_atfork()
266 _pthread_atfork_child_handlers();
269 #if CURRENT_VARIANT_asan
270 char dynamic_asan_opts
[1024] = {0};
271 const char *__asan_default_options(void) {
272 int fd
= open("/System/Library/Preferences/com.apple.asan.options", O_RDONLY
);
274 ssize_t remaining_size
= sizeof(dynamic_asan_opts
) - 1;
275 char *p
= dynamic_asan_opts
;
276 ssize_t read_bytes
= 0;
278 read_bytes
= read(fd
, p
, remaining_size
);
279 remaining_size
-= read_bytes
;
280 } while (read_bytes
> 0);
283 if (dynamic_asan_opts
[0]) {
284 return dynamic_asan_opts
;
288 return "color=never:handle_segv=0:handle_sigbus=0:handle_sigill=0:handle_sigfpe=0";
293 * Old crt1.o glue used to call through mach_init_routine which was used to initialize libSystem.
294 * LibSystem now auto-initializes but mach_init_routine is left for binary compatibility.
296 static void mach_init_old(void) {}
297 void (*mach_init_routine
)(void) = &mach_init_old
;
300 * This __crashreporter_info__ symbol is for all non-dylib parts of libSystem.
302 const char *__crashreporter_info__
;
303 asm (".desc __crashreporter_info__, 0x10");