blob: c2a9544ca142a1df3beb406c1eab03260d093806 [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 Hughesd4ca2312017-10-11 22:27:45 -070055#elif defined(__x86_64__)
56#define _JBLEN 11
57#endif
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080058
Elliott Hughes963e24b2022-08-25 20:13:00 +000059/** The type of the buffer used by sigsetjmp()/siglongjmp(). */
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080060typedef long sigjmp_buf[_JBLEN + 1];
Elliott Hughes963e24b2022-08-25 20:13:00 +000061
62/** The type of the buffer used by setjmp()/longjmp(). */
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080063typedef long jmp_buf[_JBLEN];
64
Elliott Hughesd4ca2312017-10-11 22:27:45 -070065#undef _JBLEN
66
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080067__BEGIN_DECLS
68
Elliott Hughes963e24b2022-08-25 20:13:00 +000069/**
70 * Equivalent to sigsetjmp() with the second argument 0, so that the signal
71 * mask is not saved.
72 */
Josh Gao34033152019-05-13 13:15:50 -070073int _setjmp(jmp_buf __env) __returns_twice;
Elliott Hughes963e24b2022-08-25 20:13:00 +000074
75/** Equivalent to siglongjmp(). */
Josh Gao34033152019-05-13 13:15:50 -070076__noreturn void _longjmp(jmp_buf __env, int __value);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080077
Elliott Hughes963e24b2022-08-25 20:13:00 +000078/**
79 * Equivalent to sigsetjmp() with the second argument 1, so that the signal
80 * mask is saved.
81 */
Josh Gao34033152019-05-13 13:15:50 -070082int setjmp(jmp_buf __env) __returns_twice;
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080083
Elliott Hughes963e24b2022-08-25 20:13:00 +000084/** C11 says setjmp() must be a macro, but Android already had a function. */
Elliott Hughesbf748152018-07-17 13:55:36 -070085#define setjmp(__env) setjmp(__env)
86
Elliott Hughes963e24b2022-08-25 20:13:00 +000087/** Equivalent to siglongjmp(). */
88__noreturn void longjmp(jmp_buf __env, int __value);
89
90/**
91 * [sigsetjmp(3)](http://man7.org/linux/man-pages/man3/sigsetjmp.3.html)
92 * sets the target of a future siglongjmp() call, saving or not saving the
93 * current signal mask based on the second argument.
94 *
95 * Returns 0 when first called, and returns the value passed to siglongjmp()
96 * when returning here as a result of a siglongjmp() call.
97 */
98int sigsetjmp(sigjmp_buf __env, int __save_signal_mask) __returns_twice;
99
100/**
101 * [siglongjmp(3)](http://man7.org/linux/man-pages/man3/siglongjmp.3.html)
102 * transfers control back to the site of the sigsetjmp() call that initialized
103 * the given jump buffer, returning the given value.
104 *
105 * Does not return.
106 */
Elliott Hughesf106a392019-10-03 16:09:04 -0700107__noreturn void siglongjmp(sigjmp_buf __env, int __value);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800108
109__END_DECLS