blob: a3de9c785fc5d14b8fdb546fd595783b6420932c [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__)
50#define _JBLEN 32
51#elif defined(__arm__)
52#define _JBLEN 64
53#elif defined(__i386__)
54#define _JBLEN 10
Elliott Hughese1905ed2022-10-17 23:23:36 +000055#elif defined(__riscv)
56#define _JBLEN 29
Elliott Hughesd4ca2312017-10-11 22:27:45 -070057#elif defined(__x86_64__)
58#define _JBLEN 11
59#endif
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080060
Elliott Hughes963e24b2022-08-25 20:13:00 +000061/** The type of the buffer used by sigsetjmp()/siglongjmp(). */
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080062typedef long sigjmp_buf[_JBLEN + 1];
Elliott Hughes963e24b2022-08-25 20:13:00 +000063
64/** The type of the buffer used by setjmp()/longjmp(). */
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080065typedef long jmp_buf[_JBLEN];
66
Elliott Hughesd4ca2312017-10-11 22:27:45 -070067#undef _JBLEN
68
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080069__BEGIN_DECLS
70
Elliott Hughes963e24b2022-08-25 20:13:00 +000071/**
72 * Equivalent to sigsetjmp() with the second argument 0, so that the signal
73 * mask is not saved.
74 */
Josh Gao34033152019-05-13 13:15:50 -070075int _setjmp(jmp_buf __env) __returns_twice;
Elliott Hughes963e24b2022-08-25 20:13:00 +000076
77/** Equivalent to siglongjmp(). */
Josh Gao34033152019-05-13 13:15:50 -070078__noreturn void _longjmp(jmp_buf __env, int __value);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080079
Elliott Hughes963e24b2022-08-25 20:13:00 +000080/**
81 * Equivalent to sigsetjmp() with the second argument 1, so that the signal
82 * mask is saved.
83 */
Josh Gao34033152019-05-13 13:15:50 -070084int setjmp(jmp_buf __env) __returns_twice;
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080085
Elliott Hughes963e24b2022-08-25 20:13:00 +000086/** C11 says setjmp() must be a macro, but Android already had a function. */
Elliott Hughesbf748152018-07-17 13:55:36 -070087#define setjmp(__env) setjmp(__env)
88
Elliott Hughes963e24b2022-08-25 20:13:00 +000089/** Equivalent to siglongjmp(). */
90__noreturn void longjmp(jmp_buf __env, int __value);
91
92/**
93 * [sigsetjmp(3)](http://man7.org/linux/man-pages/man3/sigsetjmp.3.html)
94 * sets the target of a future siglongjmp() call, saving or not saving the
95 * current signal mask based on the second argument.
96 *
97 * Returns 0 when first called, and returns the value passed to siglongjmp()
98 * when returning here as a result of a siglongjmp() call.
99 */
100int sigsetjmp(sigjmp_buf __env, int __save_signal_mask) __returns_twice;
101
102/**
103 * [siglongjmp(3)](http://man7.org/linux/man-pages/man3/siglongjmp.3.html)
104 * transfers control back to the site of the sigsetjmp() call that initialized
105 * the given jump buffer, returning the given value.
106 *
107 * Does not return.
108 */
Elliott Hughesf106a392019-10-03 16:09:04 -0700109__noreturn void siglongjmp(sigjmp_buf __env, int __value);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800110
111__END_DECLS