sigsetjmp.S revision 55068
1/*- 2 * Copyright (c) 1990 The Regents of the University of California. 3 * All rights reserved. 4 * 5 * This code is derived from software contributed to Berkeley by 6 * William Jolitz. 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 1. Redistributions of source code must retain the above copyright 12 * notice, this list of conditions and the following disclaimer. 13 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in the 15 * documentation and/or other materials provided with the distribution. 16 * 3. All advertising materials mentioning features or use of this software 17 * must display the following acknowledgement: 18 * This product includes software developed by the University of 19 * California, Berkeley and its contributors. 20 * 4. Neither the name of the University nor the names of its contributors 21 * may be used to endorse or promote products derived from this software 22 * without specific prior written permission. 23 * 24 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 25 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 27 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 30 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 31 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 32 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 33 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 34 * SUCH DAMAGE. 35 * 36 * $FreeBSD: head/lib/libc/amd64/gen/sigsetjmp.S 55068 1999-12-24 00:03:00Z jasone $ 37 */ 38 39#if defined(LIBC_RCS) && !defined(lint) 40 .text 41 .asciz "$FreeBSD: head/lib/libc/amd64/gen/sigsetjmp.S 55068 1999-12-24 00:03:00Z jasone $" 42#endif /* LIBC_RCS and not lint */ 43 44#include "DEFS.h" 45#include "SYS.h" 46 47/*- 48 * TODO: 49 * Rename sigsetjmp to __sigsetjmp and siglongjmp to __siglongjmp, 50 * remove the other *jmp functions and define everything in terms 51 * of the renamed functions. This requires compiler support for 52 * the renamed functions (introduced in gcc-2.5.3; previous versions 53 * only supported *jmp with 0 or 1 leading underscores). 54 * 55 * Use sigprocmask() instead of sigblock() and sigsetmask(), and 56 * check for and handle errors. 57 * 58 * Restore _all_ the registers and the signal mask atomically. Can 59 * use sigreturn() if sigreturn() works. 60 */ 61 62ENTRY(__sigsetjmp) 63ENTRY(sigsetjmp) 64 movl 8(%esp),%eax 65 movl 4(%esp),%ecx 66 movl %eax,44(%ecx) 67 testl %eax,%eax 68 jz 2f 69 PIC_PROLOGUE 70 leal 28(%ecx), %eax 71 pushl %eax /* (sigset_t*)oset */ 72 pushl $0 /* (sigset_t*)set */ 73 pushl $1 /* SIG_BLOCK */ 74#ifdef _THREAD_SAFE 75 call PIC_PLT(CNAME(_thread_sys_sigprocmask)) 76#else 77 call PIC_PLT(CNAME(sigprocmask)) 78#endif 79 addl $12,%esp 80 PIC_EPILOGUE 81 movl 4(%esp),%ecx 822: movl 0(%esp),%edx 83 movl %edx, 0(%ecx) 84 movl %ebx, 4(%ecx) 85 movl %esp, 8(%ecx) 86 movl %ebp,12(%ecx) 87 movl %esi,16(%ecx) 88 movl %edi,20(%ecx) 89 fnstcw 24(%ecx) 90 xorl %eax,%eax 91 ret 92 93ENTRY(__siglongjmp) 94ENTRY(siglongjmp) 95 movl 4(%esp),%edx 96 cmpl $0,44(%edx) 97 jz 2f 98 PIC_PROLOGUE 99 pushl $0 /* (sigset_t*)oset */ 100 leal 28(%edx), %eax 101 pushl %eax /* (sigset_t*)set */ 102 pushl $3 /* SIG_SETMASK */ 103#ifdef _THREAD_SAFE 104 call PIC_PLT(CNAME(_thread_sys_sigprocmask)) 105#else 106 call PIC_PLT(CNAME(sigprocmask)) 107#endif 108 addl $12,%esp 109 PIC_EPILOGUE 110 movl 4(%esp),%edx 1112: movl 8(%esp),%eax 112 movl 0(%edx),%ecx 113 movl 4(%edx),%ebx 114 movl 8(%edx),%esp 115 movl 12(%edx),%ebp 116 movl 16(%edx),%esi 117 movl 20(%edx),%edi 118 fninit 119 fldcw 24(%edx) 120 testl %eax,%eax 121 jnz 1f 122 incl %eax 1231: movl %ecx,0(%esp) 124 ret 125