sigsetjmp.S revision 56345
11849Swollman/*- 21849Swollman * Copyright (c) 1990 The Regents of the University of California. 31849Swollman * All rights reserved. 41849Swollman * 51849Swollman * This code is derived from software contributed to Berkeley by 61849Swollman * William Jolitz. 71849Swollman * 81849Swollman * Redistribution and use in source and binary forms, with or without 91849Swollman * modification, are permitted provided that the following conditions 101849Swollman * are met: 111849Swollman * 1. Redistributions of source code must retain the above copyright 121849Swollman * notice, this list of conditions and the following disclaimer. 131849Swollman * 2. Redistributions in binary form must reproduce the above copyright 141849Swollman * notice, this list of conditions and the following disclaimer in the 151849Swollman * documentation and/or other materials provided with the distribution. 161849Swollman * 3. All advertising materials mentioning features or use of this software 171849Swollman * must display the following acknowledgement: 181849Swollman * This product includes software developed by the University of 191849Swollman * California, Berkeley and its contributors. 201849Swollman * 4. Neither the name of the University nor the names of its contributors 211849Swollman * may be used to endorse or promote products derived from this software 221849Swollman * without specific prior written permission. 231849Swollman * 241849Swollman * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 251849Swollman * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 261849Swollman * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 271849Swollman * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 281849Swollman * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 291849Swollman * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 301849Swollman * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 311849Swollman * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 321849Swollman * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 331849Swollman * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 341849Swollman * SUCH DAMAGE. 351849Swollman * 3650476Speter * $FreeBSD: head/lib/libc/amd64/gen/sigsetjmp.S 56345 2000-01-20 21:58:27Z jasone $ 371849Swollman */ 381849Swollman 395790Sdg#if defined(LIBC_RCS) && !defined(lint) 405790Sdg .text 4150476Speter .asciz "$FreeBSD: head/lib/libc/amd64/gen/sigsetjmp.S 56345 2000-01-20 21:58:27Z jasone $" 425790Sdg#endif /* LIBC_RCS and not lint */ 431849Swollman 441849Swollman#include "DEFS.h" 451849Swollman#include "SYS.h" 461849Swollman 473851Sbde/*- 483851Sbde * TODO: 493851Sbde * Rename sigsetjmp to __sigsetjmp and siglongjmp to __siglongjmp, 503851Sbde * remove the other *jmp functions and define everything in terms 513851Sbde * of the renamed functions. This requires compiler support for 523851Sbde * the renamed functions (introduced in gcc-2.5.3; previous versions 533851Sbde * only supported *jmp with 0 or 1 leading underscores). 543851Sbde * 553851Sbde * Use sigprocmask() instead of sigblock() and sigsetmask(), and 563851Sbde * check for and handle errors. 573851Sbde * 583851Sbde * Restore _all_ the registers and the signal mask atomically. Can 593851Sbde * use sigreturn() if sigreturn() works. 603851Sbde */ 613851Sbde 6256345SjasoneENTRY(sigsetjmp) 631849Swollman movl 8(%esp),%eax 6451794Smarcel movl 4(%esp),%ecx 6551794Smarcel movl %eax,44(%ecx) 661849Swollman testl %eax,%eax 6715731Sjdp jz 2f 6815634Speter PIC_PROLOGUE 6951794Smarcel leal 28(%ecx), %eax 7051794Smarcel pushl %eax /* (sigset_t*)oset */ 7151794Smarcel pushl $0 /* (sigset_t*)set */ 7251794Smarcel pushl $1 /* SIG_BLOCK */ 7313545Sjulian#ifdef _THREAD_SAFE 7451794Smarcel call PIC_PLT(CNAME(_thread_sys_sigprocmask)) 7513545Sjulian#else 7651794Smarcel call PIC_PLT(CNAME(sigprocmask)) 7713545Sjulian#endif 7851794Smarcel addl $12,%esp 7915634Speter PIC_EPILOGUE 8051794Smarcel movl 4(%esp),%ecx 8115731Sjdp2: movl 0(%esp),%edx 821849Swollman movl %edx, 0(%ecx) 831849Swollman movl %ebx, 4(%ecx) 841849Swollman movl %esp, 8(%ecx) 851849Swollman movl %ebp,12(%ecx) 861849Swollman movl %esi,16(%ecx) 871849Swollman movl %edi,20(%ecx) 8851794Smarcel fnstcw 24(%ecx) 891849Swollman xorl %eax,%eax 901849Swollman ret 911849Swollman 9256345Sjasone#ifdef _THREAD_SAFE 9356345SjasoneENTRY(__siglongjmp) 9456345Sjasone#else 9556345SjasoneALTENTRY(__siglongjmp) 9656345SjasoneENTRY(siglongjmp) 9756276Sjasone#endif 981849Swollman movl 4(%esp),%edx 9951794Smarcel cmpl $0,44(%edx) 10015731Sjdp jz 2f 10115634Speter PIC_PROLOGUE 10251794Smarcel pushl $0 /* (sigset_t*)oset */ 10351794Smarcel leal 28(%edx), %eax 10451794Smarcel pushl %eax /* (sigset_t*)set */ 10551794Smarcel pushl $3 /* SIG_SETMASK */ 10613545Sjulian#ifdef _THREAD_SAFE 10751794Smarcel call PIC_PLT(CNAME(_thread_sys_sigprocmask)) 10813545Sjulian#else 10951794Smarcel call PIC_PLT(CNAME(sigprocmask)) 11013545Sjulian#endif 11151794Smarcel addl $12,%esp 11215634Speter PIC_EPILOGUE 11351794Smarcel movl 4(%esp),%edx 11451794Smarcel2: movl 8(%esp),%eax 1151849Swollman movl 0(%edx),%ecx 1161849Swollman movl 4(%edx),%ebx 1171849Swollman movl 8(%edx),%esp 1181849Swollman movl 12(%edx),%ebp 1191849Swollman movl 16(%edx),%esi 1201849Swollman movl 20(%edx),%edi 1213851Sbde fninit 12251794Smarcel fldcw 24(%edx) 1231849Swollman testl %eax,%eax 12415731Sjdp jnz 1f 1251849Swollman incl %eax 12615731Sjdp1: movl %ecx,0(%esp) 1271849Swollman ret 128