master
1/*
2 * Copyright (c) 2007 Apple Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
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. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
11 * file.
12 *
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 */
23#ifndef _EXECINFO_H_
24#define _EXECINFO_H_ 1
25
26#include <sys/cdefs.h>
27#include <_bounds.h>
28#include <Availability.h>
29#include <os/base.h>
30#include <os/availability.h>
31#include <stddef.h>
32#include <stdint.h>
33#include <uuid/uuid.h>
34
35_LIBC_SINGLE_BY_DEFAULT()
36
37__BEGIN_DECLS
38
39int backtrace(void **_LIBC_COUNT(__size), int __size) __OSX_AVAILABLE_STARTING(__MAC_10_5, __IPHONE_2_0);
40
41API_AVAILABLE(macosx(10.14), ios(12.0), tvos(12.0), watchos(5.0))
42OS_EXPORT
43int backtrace_from_fp(void *startfp, void **_LIBC_COUNT(size) array, int size);
44
45char *_LIBC_CSTR *_LIBC_COUNT_OR_NULL(__size) backtrace_symbols(void* const* _LIBC_COUNT(__size), int __size) __OSX_AVAILABLE_STARTING(__MAC_10_5, __IPHONE_2_0);
46void backtrace_symbols_fd(void* const* _LIBC_COUNT(__size),int __size,int) __OSX_AVAILABLE_STARTING(__MAC_10_5, __IPHONE_2_0);
47
48struct image_offset {
49 /*
50 * The UUID of the image.
51 */
52 uuid_t uuid;
53
54 /*
55 * The offset is relative to the __TEXT section of the image.
56 */
57 uint32_t offset;
58};
59
60API_AVAILABLE(macosx(10.14), ios(12.0), tvos(12.0), watchos(5.0))
61OS_EXPORT
62void backtrace_image_offsets(void* const* _LIBC_COUNT(size) array,
63 struct image_offset *image_offsets, int size);
64
65/*!
66 * @function backtrace_async
67 * Extracts the function return addresses of the current call stack. While
68 * backtrace() will only follow the OS call stack, backtrace_async() will
69 * prefer the unwind the Swift concurrency continuation stack if invoked
70 * from within an async context. In a non-async context this function is
71 * strictly equivalent to backtrace().
72 *
73 * @param array
74 * The array of pointers to fill with the return addresses.
75 *
76 * @param length
77 * The maximum number of pointers to write.
78 *
79 * @param task_id
80 * Can be NULL. If non-NULL, the uint32_t pointed to by `task_id` is set to
81 * a non-zero value that for the current process uniquely identifies the async
82 * task currently running. If called from a non-async context, the value is
83 * set to 0 and `array` contains the same values backtrace() would return.
84 *
85 * Note that the continuation addresses provided by backtrace_async()
86 * have an offset of 1 added to them. Most symbolication engines will
87 * substract 1 from the call stack return addresses in order to symbolicate
88 * the call site rather than the return location. With a Swift async
89 * continuation, substracting 1 from its address would result in an address
90 * in a different function. This offset allows the returned addresses to be
91 * handled correctly by most existing symbolication engines.
92 *
93 * @result
94 * The number of pointers actually written.
95 */
96API_AVAILABLE(macosx(12.0), ios(15.0), tvos(15.0), watchos(8.0))
97size_t backtrace_async(void** _LIBC_COUNT(length) array, size_t length, uint32_t *task_id);
98
99__END_DECLS
100
101#endif /* !_EXECINFO_H_ */