setjmp.S revision 1.5
11.5Sthorpej/*	$NetBSD: setjmp.S,v 1.5 1995/12/13 19:37:06 thorpej Exp $	*/
21.5Sthorpej
31.1Spaulus/*-
41.1Spaulus * Copyright (c) 1990 The Regents of the University of California.
51.1Spaulus * All rights reserved.
61.1Spaulus *
71.1Spaulus * This code is derived from software contributed to Berkeley by
81.1Spaulus * the Systems Programming Group of the University of Utah Computer
91.1Spaulus * Science Department.
101.1Spaulus *
111.1Spaulus * Redistribution and use in source and binary forms, with or without
121.1Spaulus * modification, are permitted provided that the following conditions
131.1Spaulus * are met:
141.1Spaulus * 1. Redistributions of source code must retain the above copyright
151.1Spaulus *    notice, this list of conditions and the following disclaimer.
161.1Spaulus * 2. Redistributions in binary form must reproduce the above copyright
171.1Spaulus *    notice, this list of conditions and the following disclaimer in the
181.1Spaulus *    documentation and/or other materials provided with the distribution.
191.1Spaulus * 3. All advertising materials mentioning features or use of this software
201.1Spaulus *    must display the following acknowledgement:
211.1Spaulus *	This product includes software developed by the University of
221.1Spaulus *	California, Berkeley and its contributors.
231.1Spaulus * 4. Neither the name of the University nor the names of its contributors
241.1Spaulus *    may be used to endorse or promote products derived from this software
251.1Spaulus *    without specific prior written permission.
261.1Spaulus *
271.1Spaulus * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
281.1Spaulus * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
291.1Spaulus * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
301.1Spaulus * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
311.1Spaulus * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
321.1Spaulus * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
331.1Spaulus * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
341.1Spaulus * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
351.1Spaulus * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
361.1Spaulus * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
371.1Spaulus * SUCH DAMAGE.
381.1Spaulus */
391.1Spaulus
401.5Sthorpej#include "DEFS.h"
411.5Sthorpej
421.1Spaulus#if defined(LIBC_SCCS) && !defined(lint)
431.5Sthorpej#if 0
441.5Sthorpej	RCSID("from: @(#)setjmp.s	5.1 (Berkeley) 5/12/90")
451.5Sthorpej#else
461.5Sthorpej	RCSID("$NetBSD: setjmp.S,v 1.5 1995/12/13 19:37:06 thorpej Exp $")
471.5Sthorpej#endif
481.1Spaulus#endif /* LIBC_SCCS and not lint */
491.1Spaulus
501.1Spaulus/*
511.1Spaulus * C library -- setjmp, longjmp
521.1Spaulus *
531.1Spaulus *	longjmp(a,v)
541.1Spaulus * will generate a "return(v)" from
551.1Spaulus * the last call to
561.1Spaulus *	setjmp(a)
571.1Spaulus * by restoring registers from the stack,
581.1Spaulus * and a struct sigcontext, see <signal.h>
591.1Spaulus */
601.1Spaulus
611.1SpaulusENTRY(setjmp)
621.2Schopps	subl	#12,sp		/* space for sigstack args/rvals */
631.1Spaulus	clrl	sp@		/* don't change it... */
641.1Spaulus	movl	sp,sp@(4)	/* ...but return the current val */
651.2Schopps	jbsr	_sigaltstack	/* note: flags returned in sp@(8) */
661.1Spaulus	clrl	sp@		/* don't change mask, just return */
671.1Spaulus	jbsr	_sigblock	/*   old value */
681.2Schopps	movl	sp@(8),d1	/* old flags value */
691.2Schopps	andl	#1,d1		/* extract onstack flag */
701.2Schopps	addl	#12,sp
711.1Spaulus	movl	sp@(4),a0	/* save area pointer */
721.1Spaulus	movl	d1,a0@+		/* save old onstack value */
731.1Spaulus	movl	d0,a0@+		/* save old signal mask */
741.1Spaulus	lea	sp@(4),a1	/* adjust saved SP since we won't rts */
751.1Spaulus	movl	a1,a0@+		/* save old SP */
761.1Spaulus	movl	a6,a0@+		/* save old FP */
771.1Spaulus	clrl	a0@+		/* no AP */
781.1Spaulus	movl	sp@,a0@+	/* save old PC */
791.1Spaulus	clrl	a0@+		/* clean PS */
801.1Spaulus	moveml	#0x3CFC,a0@	/* save remaining non-scratch regs */
811.1Spaulus	clrl	d0		/* return 0 */
821.1Spaulus	rts
831.1Spaulus
841.1SpaulusENTRY(longjmp)
851.1Spaulus	movl	sp@(4),a0	/* save area pointer */
861.1Spaulus	tstl	a0@(8)		/* ensure non-zero SP */
871.1Spaulus	jeq	botch		/* oops! */
881.1Spaulus	movl	sp@(8),d0	/* grab return value */
891.1Spaulus	jne	ok		/* non-zero ok */
901.1Spaulus	moveq	#1,d0		/* else make non-zero */
911.1Spaulusok:
921.1Spaulus	moveml	a0@(28),#0x3CFC	/* restore non-scratch regs */
931.4Smycroft	movl	a0,sp@-		/* let sigreturn */
941.4Smycroft	jbsr	_sigreturn	/*   finish for us */
951.1Spaulus
961.1Spaulusbotch:
971.1Spaulus	jbsr	_longjmperror
981.1Spaulus	stop	#0
99