sigsetjmp.S revision 50476
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 50476 1999-08-28 00:22:10Z peter $
371849Swollman */
381849Swollman
395790Sdg#if defined(LIBC_RCS) && !defined(lint)
405790Sdg	.text
4150476Speter	.asciz "$FreeBSD: head/lib/libc/amd64/gen/sigsetjmp.S 50476 1999-08-28 00:22:10Z peter $"
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
621849SwollmanENTRY(sigsetjmp)
631849Swollman	movl	8(%esp),%eax
641849Swollman	movl	4(%esp),%ecx
653851Sbde	movl	%eax,32(%ecx)
661849Swollman	testl	%eax,%eax
6715731Sjdp	jz	2f
6815634Speter	PIC_PROLOGUE
691849Swollman	pushl	$0
7013545Sjulian#ifdef _THREAD_SAFE
7115634Speter	call	PIC_PLT(CNAME(_thread_sys_sigblock))
7213545Sjulian#else
7315634Speter	call	PIC_PLT(CNAME(sigblock))
7413545Sjulian#endif
751849Swollman	addl	$4,%esp
7615634Speter	PIC_EPILOGUE
771849Swollman	movl	4(%esp),%ecx
783851Sbde	movl	%eax,24(%ecx)
7915731Sjdp2:	movl	0(%esp),%edx
801849Swollman	movl	%edx, 0(%ecx)
811849Swollman	movl	%ebx, 4(%ecx)
821849Swollman	movl	%esp, 8(%ecx)
831849Swollman	movl	%ebp,12(%ecx)
841849Swollman	movl	%esi,16(%ecx)
851849Swollman	movl	%edi,20(%ecx)
863851Sbde	fnstcw	28(%ecx)
871849Swollman	xorl	%eax,%eax
881849Swollman	ret
891849Swollman
901849SwollmanENTRY(siglongjmp)
911849Swollman	movl	4(%esp),%edx
923851Sbde	cmpl	$0,32(%edx)
9315731Sjdp	jz	2f
9415634Speter	PIC_PROLOGUE
953851Sbde	pushl	24(%edx)
9613545Sjulian#ifdef _THREAD_SAFE
9715634Speter	call	PIC_PLT(CNAME(_thread_sys_sigsetmask))
9813545Sjulian#else
9915634Speter	call	PIC_PLT(CNAME(sigsetmask))
10013545Sjulian#endif
1011849Swollman	addl	$4,%esp
10215634Speter	PIC_EPILOGUE
10315731Sjdp2:	movl	4(%esp),%edx
1041849Swollman	movl	8(%esp),%eax
1051849Swollman	movl	0(%edx),%ecx
1061849Swollman	movl	4(%edx),%ebx
1071849Swollman	movl	8(%edx),%esp
1081849Swollman	movl	12(%edx),%ebp
1091849Swollman	movl	16(%edx),%esi
1101849Swollman	movl	20(%edx),%edi
1113851Sbde	fninit
1123851Sbde	fldcw	28(%edx)
1131849Swollman	testl	%eax,%eax
11415731Sjdp	jnz	1f
1151849Swollman	incl	%eax
11615731Sjdp1:	movl	%ecx,0(%esp)
1171849Swollman	ret
118