signal.h revision 1.16
11.16Sbjh21/* $NetBSD: signal.h,v 1.16 2003/04/28 23:16:19 bjh21 Exp $ */ 21.3Scgd 31.1Sbrezak/* 41.1Sbrezak * Copyright (c) 1982, 1986, 1989, 1991 Regents of the University of California. 51.1Sbrezak * All rights reserved. 61.1Sbrezak * 71.1Sbrezak * Redistribution and use in source and binary forms, with or without 81.1Sbrezak * modification, are permitted provided that the following conditions 91.1Sbrezak * are met: 101.1Sbrezak * 1. Redistributions of source code must retain the above copyright 111.1Sbrezak * notice, this list of conditions and the following disclaimer. 121.1Sbrezak * 2. Redistributions in binary form must reproduce the above copyright 131.1Sbrezak * notice, this list of conditions and the following disclaimer in the 141.1Sbrezak * documentation and/or other materials provided with the distribution. 151.1Sbrezak * 3. All advertising materials mentioning features or use of this software 161.1Sbrezak * must display the following acknowledgement: 171.1Sbrezak * This product includes software developed by the University of 181.1Sbrezak * California, Berkeley and its contributors. 191.1Sbrezak * 4. Neither the name of the University nor the names of its contributors 201.1Sbrezak * may be used to endorse or promote products derived from this software 211.1Sbrezak * without specific prior written permission. 221.1Sbrezak * 231.1Sbrezak * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 241.1Sbrezak * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 251.1Sbrezak * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 261.1Sbrezak * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 271.1Sbrezak * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 281.1Sbrezak * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 291.1Sbrezak * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 301.1Sbrezak * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 311.1Sbrezak * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 321.1Sbrezak * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 331.1Sbrezak * SUCH DAMAGE. 341.1Sbrezak * 351.3Scgd * @(#)signal.h 7.16 (Berkeley) 3/17/91 361.1Sbrezak */ 371.1Sbrezak 381.2Smycroft#ifndef _I386_SIGNAL_H_ 391.2Smycroft#define _I386_SIGNAL_H_ 401.1Sbrezak 411.16Sbjh21#include <sys/featuretest.h> 421.16Sbjh21 431.1Sbrezaktypedef int sig_atomic_t; 441.1Sbrezak 451.16Sbjh21#if defined(_NETBSD_SOURCE) 461.1Sbrezak/* 471.1Sbrezak * Get the "code" values 481.1Sbrezak */ 491.1Sbrezak#include <machine/trap.h> 501.1Sbrezak 511.1Sbrezak/* 521.1Sbrezak * Information pushed on stack when a signal is delivered. 531.1Sbrezak * This is used by the kernel to restore state following 541.1Sbrezak * execution of the signal handler. It is also made available 551.1Sbrezak * to the handler to allow it to restore state properly if 561.1Sbrezak * a non-standard exit is performed. 571.1Sbrezak */ 581.12Sthorpej#if defined(__LIBC12_SOURCE__) || defined(_KERNEL) 591.10Smycroftstruct sigcontext13 { 601.5Smycroft int sc_gs; 611.5Smycroft int sc_fs; 621.2Smycroft int sc_es; 631.2Smycroft int sc_ds; 641.2Smycroft int sc_edi; 651.2Smycroft int sc_esi; 661.2Smycroft int sc_ebp; 671.2Smycroft int sc_ebx; 681.2Smycroft int sc_edx; 691.2Smycroft int sc_ecx; 701.2Smycroft int sc_eax; 711.6Smycroft /* XXX */ 721.2Smycroft int sc_eip; 731.2Smycroft int sc_cs; 741.2Smycroft int sc_eflags; 751.2Smycroft int sc_esp; 761.2Smycroft int sc_ss; 771.5Smycroft 781.5Smycroft int sc_onstack; /* sigstack state to restore */ 791.13Sthorpej int sc_mask; /* signal mask to restore (old style) */ 801.6Smycroft 811.6Smycroft int sc_trapno; /* XXX should be above */ 821.6Smycroft int sc_err; 831.10Smycroft}; 841.10Smycroft#endif 851.9Smycroft 861.10Smycroftstruct sigcontext { 871.10Smycroft int sc_gs; 881.10Smycroft int sc_fs; 891.10Smycroft int sc_es; 901.10Smycroft int sc_ds; 911.10Smycroft int sc_edi; 921.10Smycroft int sc_esi; 931.10Smycroft int sc_ebp; 941.10Smycroft int sc_ebx; 951.10Smycroft int sc_edx; 961.10Smycroft int sc_ecx; 971.10Smycroft int sc_eax; 981.10Smycroft /* XXX */ 991.10Smycroft int sc_eip; 1001.10Smycroft int sc_cs; 1011.10Smycroft int sc_eflags; 1021.10Smycroft int sc_esp; 1031.10Smycroft int sc_ss; 1041.10Smycroft 1051.10Smycroft int sc_onstack; /* sigstack state to restore */ 1061.14Sthorpej int __sc_mask13; /* signal mask to restore (old style) */ 1071.10Smycroft 1081.10Smycroft int sc_trapno; /* XXX should be above */ 1091.10Smycroft int sc_err; 1101.10Smycroft 1111.10Smycroft sigset_t sc_mask; /* signal mask to restore (new style) */ 1121.1Sbrezak}; 1131.15Sthorpej 1141.15Sthorpej/* 1151.15Sthorpej * The following macros are used to convert from a ucontext to sigcontext, 1161.15Sthorpej * and vice-versa. This is for building a sigcontext to deliver to old-style 1171.15Sthorpej * signal handlers, and converting back (in the event the handler modifies 1181.15Sthorpej * the context). 1191.15Sthorpej */ 1201.15Sthorpej#define _MCONTEXT_TO_SIGCONTEXT(uc, sc) \ 1211.15Sthorpejdo { \ 1221.15Sthorpej (sc)->sc_gs = (uc)->uc_mcontext.__gregs[_REG_GS]; \ 1231.15Sthorpej (sc)->sc_fs = (uc)->uc_mcontext.__gregs[_REG_FS]; \ 1241.15Sthorpej (sc)->sc_es = (uc)->uc_mcontext.__gregs[_REG_ES]; \ 1251.15Sthorpej (sc)->sc_ds = (uc)->uc_mcontext.__gregs[_REG_DS]; \ 1261.15Sthorpej (sc)->sc_edi = (uc)->uc_mcontext.__gregs[_REG_EDI]; \ 1271.15Sthorpej (sc)->sc_esi = (uc)->uc_mcontext.__gregs[_REG_ESI]; \ 1281.15Sthorpej (sc)->sc_ebp = (uc)->uc_mcontext.__gregs[_REG_EBP]; \ 1291.15Sthorpej (sc)->sc_ebx = (uc)->uc_mcontext.__gregs[_REG_EBX]; \ 1301.15Sthorpej (sc)->sc_edx = (uc)->uc_mcontext.__gregs[_REG_EDX]; \ 1311.15Sthorpej (sc)->sc_ecx = (uc)->uc_mcontext.__gregs[_REG_ECX]; \ 1321.15Sthorpej (sc)->sc_eax = (uc)->uc_mcontext.__gregs[_REG_EAX]; \ 1331.15Sthorpej (sc)->sc_eip = (uc)->uc_mcontext.__gregs[_REG_EIP]; \ 1341.15Sthorpej (sc)->sc_cs = (uc)->uc_mcontext.__gregs[_REG_CS]; \ 1351.15Sthorpej (sc)->sc_eflags = (uc)->uc_mcontext.__gregs[_REG_EFL]; \ 1361.15Sthorpej (sc)->sc_esp = (uc)->uc_mcontext.__gregs[_REG_UESP]; \ 1371.15Sthorpej (sc)->sc_ss = (uc)->uc_mcontext.__gregs[_REG_SS]; \ 1381.15Sthorpej (sc)->sc_trapno = (uc)->uc_mcontext.__gregs[_REG_TRAPNO]; \ 1391.15Sthorpej (sc)->sc_err = (uc)->uc_mcontext.__gregs[_REG_ERR]; \ 1401.15Sthorpej} while (/*CONSTCOND*/0) 1411.15Sthorpej 1421.15Sthorpej#define _SIGCONTEXT_TO_MCONTEXT(sc, uc) \ 1431.15Sthorpejdo { \ 1441.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_GS] = (sc)->sc_gs; \ 1451.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_FS] = (sc)->sc_fs; \ 1461.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_ES] = (sc)->sc_es; \ 1471.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_DS] = (sc)->sc_ds; \ 1481.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_EDI] = (sc)->sc_edi; \ 1491.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_ESI] = (sc)->sc_esi; \ 1501.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_EBP] = (sc)->sc_ebp; \ 1511.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_EBX] = (sc)->sc_ebx; \ 1521.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_EDX] = (sc)->sc_edx; \ 1531.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_ECX] = (sc)->sc_ecx; \ 1541.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_EAX] = (sc)->sc_eax; \ 1551.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_EIP] = (sc)->sc_eip; \ 1561.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_CS] = (sc)->sc_cs; \ 1571.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_EFL] = (sc)->sc_eflags; \ 1581.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_UESP] = (sc)->sc_esp; \ 1591.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_UESP] = (sc)->sc_esp; \ 1601.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_SS] = (sc)->sc_ss; \ 1611.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_TRAPNO] = (sc)->sc_trapno; \ 1621.15Sthorpej (uc)->uc_mcontext.__gregs[_REG_ERR] = (sc)->sc_err; \ 1631.15Sthorpej} while (/*CONSTCOND*/0) 1641.1Sbrezak 1651.1Sbrezak#define sc_sp sc_esp 1661.1Sbrezak#define sc_fp sc_ebp 1671.1Sbrezak#define sc_pc sc_eip 1681.2Smycroft#define sc_ps sc_eflags 1691.1Sbrezak 1701.16Sbjh21#endif /* _NETBSD_SOURCE */ 1711.4Sjtc#endif /* !_I386_SIGNAL_H_ */ 172