blob: 6d047ae402dfdf44837c02e63b525351fba39dbe [file] [log] [blame]
The Android Open Source Project1dc9e472009-03-03 19:28:35 -08001/* $OpenBSD: setjmp.h,v 1.5 2005/12/13 00:35:22 millert Exp $ */
2/* $NetBSD: setjmp.h,v 1.11 1994/12/20 10:35:44 cgd Exp $ */
3
4/*-
5 * Copyright (c) 1990, 1993
6 * The Regents of the University of California. All rights reserved.
7 * (c) UNIX System Laboratories, Inc.
8 * All or some portions of this file are derived from material licensed
9 * to the University of California by American Telephone and Telegraph
10 * Co. or Unix System Laboratories, Inc. and are reproduced herein with
11 * the permission of UNIX System Laboratories, Inc.
12 *
13 * Redistribution and use in source and binary forms, with or without
14 * modification, are permitted provided that the following conditions
15 * are met:
16 * 1. Redistributions of source code must retain the above copyright
17 * notice, this list of conditions and the following disclaimer.
18 * 2. Redistributions in binary form must reproduce the above copyright
19 * notice, this list of conditions and the following disclaimer in the
20 * documentation and/or other materials provided with the distribution.
21 * 3. Neither the name of the University nor the names of its contributors
22 * may be used to endorse or promote products derived from this software
23 * without specific prior written permission.
24 *
25 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
26 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
29 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
30 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
31 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
32 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
34 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 * SUCH DAMAGE.
36 *
37 * @(#)setjmp.h 8.2 (Berkeley) 1/21/94
38 */
39
Elliott Hughes963e24b2022-08-25 20:13:00 +000040#pragma once
41
42/**
43 * @file setjmp.h
44 * @brief Non-local jumps.
45 */
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080046
47#include <sys/cdefs.h>
Elliott Hughesd4ca2312017-10-11 22:27:45 -070048
49#if defined(__aarch64__)
Elliott Hughes634186b2023-04-12 12:43:10 -070050/**
51 * The size in words of an arm64 jmp_buf. Room for callee-saved registers,
52 * including floating point, stack pointer and program counter, various
53 * internal implementation details, and leaving some free space.
54 *
55 * Coincidentally matches OpenBSD, though they also save/restore the
56 * floating point status register too.
57 */
Elliott Hughesd4ca2312017-10-11 22:27:45 -070058#define _JBLEN 32
59#elif defined(__arm__)
Elliott Hughes634186b2023-04-12 12:43:10 -070060/** The size in words of an arm32 jmp_buf. Inherited from OpenBSD. */
Elliott Hughesd4ca2312017-10-11 22:27:45 -070061#define _JBLEN 64
62#elif defined(__i386__)
Elliott Hughes634186b2023-04-12 12:43:10 -070063/** The size in words of an x86 jmp_buf. Inherited from OpenBSD. */
Elliott Hughesd4ca2312017-10-11 22:27:45 -070064#define _JBLEN 10
Elliott Hughese1905ed2022-10-17 23:23:36 +000065#elif defined(__riscv)
Elliott Hughes634186b2023-04-12 12:43:10 -070066/**
67 * The size in words of a riscv64 jmp_buf. Room for callee-saved registers,
68 * including floating point, stack pointer and program counter, various
69 * internal implementation details, and leaving some free space.
70 *
71 * Coincidentally matches OpenBSD, though they also save/restore the
72 * floating point status register too.
73 */
Elliott Hughese7b3b8b2023-04-06 14:44:50 -070074#define _JBLEN 32
Elliott Hughesd4ca2312017-10-11 22:27:45 -070075#elif defined(__x86_64__)
Elliott Hughes634186b2023-04-12 12:43:10 -070076/** The size in words of an x86-64 jmp_buf. Inherited from OpenBSD. */
Elliott Hughesd4ca2312017-10-11 22:27:45 -070077#define _JBLEN 11
78#endif
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080079
Elliott Hughes963e24b2022-08-25 20:13:00 +000080/** The type of the buffer used by sigsetjmp()/siglongjmp(). */
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080081typedef long sigjmp_buf[_JBLEN + 1];
Elliott Hughes963e24b2022-08-25 20:13:00 +000082
83/** The type of the buffer used by setjmp()/longjmp(). */
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080084typedef long jmp_buf[_JBLEN];
85
Elliott Hughesd4ca2312017-10-11 22:27:45 -070086#undef _JBLEN
87
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080088__BEGIN_DECLS
89
Elliott Hughes963e24b2022-08-25 20:13:00 +000090/**
91 * Equivalent to sigsetjmp() with the second argument 0, so that the signal
92 * mask is not saved.
93 */
Josh Gao34033152019-05-13 13:15:50 -070094int _setjmp(jmp_buf __env) __returns_twice;
Elliott Hughes963e24b2022-08-25 20:13:00 +000095
96/** Equivalent to siglongjmp(). */
Josh Gao34033152019-05-13 13:15:50 -070097__noreturn void _longjmp(jmp_buf __env, int __value);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080098
Elliott Hughes963e24b2022-08-25 20:13:00 +000099/**
100 * Equivalent to sigsetjmp() with the second argument 1, so that the signal
101 * mask is saved.
102 */
Josh Gao34033152019-05-13 13:15:50 -0700103int setjmp(jmp_buf __env) __returns_twice;
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800104
Elliott Hughes963e24b2022-08-25 20:13:00 +0000105/** C11 says setjmp() must be a macro, but Android already had a function. */
Elliott Hughesbf748152018-07-17 13:55:36 -0700106#define setjmp(__env) setjmp(__env)
107
Elliott Hughes963e24b2022-08-25 20:13:00 +0000108/** Equivalent to siglongjmp(). */
109__noreturn void longjmp(jmp_buf __env, int __value);
110
111/**
112 * [sigsetjmp(3)](http://man7.org/linux/man-pages/man3/sigsetjmp.3.html)
113 * sets the target of a future siglongjmp() call, saving or not saving the
114 * current signal mask based on the second argument.
115 *
116 * Returns 0 when first called, and returns the value passed to siglongjmp()
117 * when returning here as a result of a siglongjmp() call.
118 */
119int sigsetjmp(sigjmp_buf __env, int __save_signal_mask) __returns_twice;
120
121/**
122 * [siglongjmp(3)](http://man7.org/linux/man-pages/man3/siglongjmp.3.html)
123 * transfers control back to the site of the sigsetjmp() call that initialized
124 * the given jump buffer, returning the given value.
125 *
126 * Does not return.
127 */
Elliott Hughesf106a392019-10-03 16:09:04 -0700128__noreturn void siglongjmp(sigjmp_buf __env, int __value);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800129
130__END_DECLS