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