/* * Copyright (c) 1988 Regents of the University of California. * All rights reserved. * * This code is derived from software contributed to Berkeley by * Computer Consoles Inc. * * %sccs.include.redist.c% */ #if defined(LIBC_SCCS) && !defined(lint) .asciz "@(#)_setjmp.s 5.1 (Berkeley) 01/30/91" #endif /* LIBC_SCCS and not lint */ /* * C library -- _setjmp, _longjmp * * _longjmp(a,v) * will generate a "return(v)" from * the last call to * _setjmp(a) * by restoring registers from the stack, * The previous signal state is NOT restored. */ #include "DEFS.h" ENTRY(_setjmp, 0) movl 4(fp),r0 movl (fp),(r0) # save frame pointer of caller movl -8(fp),4(r0) # save pc of caller clrl r0 ret ENTRY(_longjmp, 0) movl 8(fp),r0 # return(v) movl 4(fp),r1 # fetch buffer tstl (r1) beql botch loop: cmpl (r1),(fp) beql done blssu botch movl $loop,-8(fp) ret # pop another frame done: cmpb *-8(fp),reiins # returning to an "rei"? bneq 1f movab 3f,-8(fp) # do return w/ psl-pc pop brw 2f 1: movab 4f,-8(fp) # do standard return 2: ret # unwind stack before signals enabled 3: addl2 $8,sp # compensate for PSL-PC push 4: jmp *4(r1) # done, return.... botch: callf $4,_longjmperror halt .data reiins: rei