setjmp.S revision 1.11
11.11Sagc/*	$NetBSD: setjmp.S,v 1.11 2003/08/07 16:42:11 agc 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.11Sagc * 3. Neither the name of the University nor the names of its contributors
201.1Spaulus *    may be used to endorse or promote products derived from this software
211.1Spaulus *    without specific prior written permission.
221.1Spaulus *
231.1Spaulus * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
241.1Spaulus * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
251.1Spaulus * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
261.1Spaulus * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
271.1Spaulus * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
281.1Spaulus * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
291.1Spaulus * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
301.1Spaulus * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
311.1Spaulus * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
321.1Spaulus * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
331.1Spaulus * SUCH DAMAGE.
341.1Spaulus */
351.1Spaulus
361.6Sthorpej#include <machine/asm.h>
371.5Sthorpej
381.1Spaulus#if defined(LIBC_SCCS) && !defined(lint)
391.5Sthorpej#if 0
401.5Sthorpej	RCSID("from: @(#)setjmp.s	5.1 (Berkeley) 5/12/90")
411.5Sthorpej#else
421.11Sagc	RCSID("$NetBSD: setjmp.S,v 1.11 2003/08/07 16:42:11 agc Exp $")
431.5Sthorpej#endif
441.1Spaulus#endif /* LIBC_SCCS and not lint */
451.1Spaulus
461.1Spaulus/*
471.1Spaulus * C library -- setjmp, longjmp
481.1Spaulus *
491.1Spaulus *	longjmp(a,v)
501.1Spaulus * will generate a "return(v)" from
511.1Spaulus * the last call to
521.1Spaulus *	setjmp(a)
531.1Spaulus * by restoring registers from the stack,
541.1Spaulus * and a struct sigcontext, see <signal.h>
551.1Spaulus */
561.1Spaulus
571.1SpaulusENTRY(setjmp)
581.10Sthorpej	lea	%sp@(-12),%sp	/* space for sigstack args/rvals */
591.10Sthorpej	clrl	%sp@		/* don't change it... */
601.10Sthorpej	movl	%sp,%sp@(4)	/* ...but return the current val */
611.9Sitohy	jbsr	PIC_PLT(_C_LABEL(__sigaltstack14))
621.9Sitohy				/* note: flags returned in sp@(8) */
631.10Sthorpej	clrl	%sp@		/* don't change mask, just return */
641.9Sitohy	jbsr	PIC_PLT(_C_LABEL(sigblock)) /*  old value */
651.10Sthorpej	movl	%sp@(8),%d1	/* old flags value */
661.10Sthorpej	andl	#1,%d1		/* extract onstack flag */
671.10Sthorpej	lea	%sp@(12),%sp
681.10Sthorpej	movl	%sp@(4),%a0	/* save area pointer */
691.10Sthorpej	movl	%d1,%a0@+	/* save old onstack value */
701.10Sthorpej	movl	%d0,%a0@+	/* save old signal mask */
711.10Sthorpej	lea	%sp@(4),%a1	/* adjust saved SP since we won't rts */
721.10Sthorpej	movl	%a1,%a0@+	/* save old SP */
731.10Sthorpej	movl	%a6,%a0@+	/* save old FP */
741.10Sthorpej	clrl	%a0@+		/* no AP */
751.10Sthorpej	movl	%sp@,%a0@+	/* save old PC */
761.10Sthorpej	clrl	%a0@+		/* clean PS */
771.10Sthorpej	moveml	#0x3CFC,%a0@	/* save remaining non-scratch regs */
781.10Sthorpej	clrl	%d0		/* return 0 */
791.1Spaulus	rts
801.1Spaulus
811.1SpaulusENTRY(longjmp)
821.10Sthorpej	movl	%sp@(4),%a0	/* save area pointer */
831.10Sthorpej	tstl	%a0@(8)		/* ensure non-zero SP */
841.1Spaulus	jeq	botch		/* oops! */
851.10Sthorpej	movl	%sp@(8),%d0	/* grab return value */
861.1Spaulus	jne	ok		/* non-zero ok */
871.10Sthorpej	moveq	#1,%d0		/* else make non-zero */
881.1Spaulusok:
891.10Sthorpej	moveml	%a0@(28),#0x3CFC /* restore non-scratch regs */
901.10Sthorpej	movl	%a0,%sp@-	 /* let sigreturn */
911.9Sitohy	jbsr	PIC_PLT(_C_LABEL(sigreturn)) /*  finish for us */
921.1Spaulus
931.1Spaulusbotch:
941.9Sitohy	jbsr	PIC_PLT(_C_LABEL(longjmperror))
951.1Spaulus	stop	#0
96