|
|
BSD 4.3tahoe
/* * Copyright (c) 1988 Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted * provided that the above copyright notice and this paragraph are * duplicated in all such forms and that any documentation, * advertising materials, and other materials related to such * distribution and use acknowledge that the software was developed * by the University of California, Berkeley. The name of the * University may not be used to endorse or promote products derived * from this software without specific prior written permission. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. * * This code is derived from software contributed to Berkeley by * Computer Consoles Inc. */ #if defined(LIBC_SCCS) && !defined(lint) .asciz "@(#)_setjmp.s 1.3 (Berkeley) 6/27/88" #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
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.