signal.h revision 1.20
1/* $NetBSD: signal.h,v 1.20 2003/09/11 19:16:05 christos Exp $ */ 2 3/* 4 * Copyright (c) 1982, 1986, 1989, 1991 Regents of the University of California. 5 * All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * 2. Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in the 14 * documentation and/or other materials provided with the distribution. 15 * 3. Neither the name of the University nor the names of its contributors 16 * may be used to endorse or promote products derived from this software 17 * without specific prior written permission. 18 * 19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29 * SUCH DAMAGE. 30 * 31 * @(#)signal.h 7.16 (Berkeley) 3/17/91 32 */ 33 34#ifndef _I386_SIGNAL_H_ 35#define _I386_SIGNAL_H_ 36 37#include <sys/featuretest.h> 38 39typedef int sig_atomic_t; 40 41#define __HAVE_SIGINFO 42 43#if defined(_NETBSD_SOURCE) 44/* 45 * Get the "code" values 46 */ 47#include <machine/trap.h> 48 49/* 50 * Information pushed on stack when a signal is delivered. 51 * This is used by the kernel to restore state following 52 * execution of the signal handler. It is also made available 53 * to the handler to allow it to restore state properly if 54 * a non-standard exit is performed. 55 */ 56#if defined(__LIBC12_SOURCE__) || defined(_KERNEL) 57struct sigcontext13 { 58 int sc_gs; 59 int sc_fs; 60 int sc_es; 61 int sc_ds; 62 int sc_edi; 63 int sc_esi; 64 int sc_ebp; 65 int sc_ebx; 66 int sc_edx; 67 int sc_ecx; 68 int sc_eax; 69 /* XXX */ 70 int sc_eip; 71 int sc_cs; 72 int sc_eflags; 73 int sc_esp; 74 int sc_ss; 75 76 int sc_onstack; /* sigstack state to restore */ 77 int sc_mask; /* signal mask to restore (old style) */ 78 79 int sc_trapno; /* XXX should be above */ 80 int sc_err; 81}; 82#endif 83 84#if defined(COMPAT_16) || defined(_KERNEL) 85/* 86 * We limit this to kernel use only, so that legacy code will break. 87 */ 88struct sigcontext { 89 int sc_gs; 90 int sc_fs; 91 int sc_es; 92 int sc_ds; 93 int sc_edi; 94 int sc_esi; 95 int sc_ebp; 96 int sc_ebx; 97 int sc_edx; 98 int sc_ecx; 99 int sc_eax; 100 /* XXX */ 101 int sc_eip; 102 int sc_cs; 103 int sc_eflags; 104 int sc_esp; 105 int sc_ss; 106 107 int sc_onstack; /* sigstack state to restore */ 108 int __sc_mask13; /* signal mask to restore (old style) */ 109 110 int sc_trapno; /* XXX should be above */ 111 int sc_err; 112 113 sigset_t sc_mask; /* signal mask to restore (new style) */ 114}; 115 116/* 117 * The following macros are used to convert from a ucontext to sigcontext, 118 * and vice-versa. This is for building a sigcontext to deliver to old-style 119 * signal handlers, and converting back (in the event the handler modifies 120 * the context). 121 */ 122#define _MCONTEXT_TO_SIGCONTEXT(uc, sc) \ 123do { \ 124 (sc)->sc_gs = (uc)->uc_mcontext.__gregs[_REG_GS]; \ 125 (sc)->sc_fs = (uc)->uc_mcontext.__gregs[_REG_FS]; \ 126 (sc)->sc_es = (uc)->uc_mcontext.__gregs[_REG_ES]; \ 127 (sc)->sc_ds = (uc)->uc_mcontext.__gregs[_REG_DS]; \ 128 (sc)->sc_edi = (uc)->uc_mcontext.__gregs[_REG_EDI]; \ 129 (sc)->sc_esi = (uc)->uc_mcontext.__gregs[_REG_ESI]; \ 130 (sc)->sc_ebp = (uc)->uc_mcontext.__gregs[_REG_EBP]; \ 131 (sc)->sc_ebx = (uc)->uc_mcontext.__gregs[_REG_EBX]; \ 132 (sc)->sc_edx = (uc)->uc_mcontext.__gregs[_REG_EDX]; \ 133 (sc)->sc_ecx = (uc)->uc_mcontext.__gregs[_REG_ECX]; \ 134 (sc)->sc_eax = (uc)->uc_mcontext.__gregs[_REG_EAX]; \ 135 (sc)->sc_eip = (uc)->uc_mcontext.__gregs[_REG_EIP]; \ 136 (sc)->sc_cs = (uc)->uc_mcontext.__gregs[_REG_CS]; \ 137 (sc)->sc_eflags = (uc)->uc_mcontext.__gregs[_REG_EFL]; \ 138 (sc)->sc_esp = (uc)->uc_mcontext.__gregs[_REG_UESP]; \ 139 (sc)->sc_ss = (uc)->uc_mcontext.__gregs[_REG_SS]; \ 140 (sc)->sc_trapno = (uc)->uc_mcontext.__gregs[_REG_TRAPNO]; \ 141 (sc)->sc_err = (uc)->uc_mcontext.__gregs[_REG_ERR]; \ 142} while (/*CONSTCOND*/0) 143 144#define _SIGCONTEXT_TO_MCONTEXT(sc, uc) \ 145do { \ 146 (uc)->uc_mcontext.__gregs[_REG_GS] = (sc)->sc_gs; \ 147 (uc)->uc_mcontext.__gregs[_REG_FS] = (sc)->sc_fs; \ 148 (uc)->uc_mcontext.__gregs[_REG_ES] = (sc)->sc_es; \ 149 (uc)->uc_mcontext.__gregs[_REG_DS] = (sc)->sc_ds; \ 150 (uc)->uc_mcontext.__gregs[_REG_EDI] = (sc)->sc_edi; \ 151 (uc)->uc_mcontext.__gregs[_REG_ESI] = (sc)->sc_esi; \ 152 (uc)->uc_mcontext.__gregs[_REG_EBP] = (sc)->sc_ebp; \ 153 (uc)->uc_mcontext.__gregs[_REG_EBX] = (sc)->sc_ebx; \ 154 (uc)->uc_mcontext.__gregs[_REG_EDX] = (sc)->sc_edx; \ 155 (uc)->uc_mcontext.__gregs[_REG_ECX] = (sc)->sc_ecx; \ 156 (uc)->uc_mcontext.__gregs[_REG_EAX] = (sc)->sc_eax; \ 157 (uc)->uc_mcontext.__gregs[_REG_EIP] = (sc)->sc_eip; \ 158 (uc)->uc_mcontext.__gregs[_REG_CS] = (sc)->sc_cs; \ 159 (uc)->uc_mcontext.__gregs[_REG_EFL] = (sc)->sc_eflags; \ 160 (uc)->uc_mcontext.__gregs[_REG_UESP] = (sc)->sc_esp; \ 161 (uc)->uc_mcontext.__gregs[_REG_UESP] = (sc)->sc_esp; \ 162 (uc)->uc_mcontext.__gregs[_REG_SS] = (sc)->sc_ss; \ 163 (uc)->uc_mcontext.__gregs[_REG_TRAPNO] = (sc)->sc_trapno; \ 164 (uc)->uc_mcontext.__gregs[_REG_ERR] = (sc)->sc_err; \ 165} while (/*CONSTCOND*/0) 166#endif 167 168#define sc_sp sc_esp 169#define sc_fp sc_ebp 170#define sc_pc sc_eip 171#define sc_ps sc_eflags 172 173#endif /* _NETBSD_SOURCE */ 174#endif /* !_I386_SIGNAL_H_ */ 175