minix/lib/nbsd_libc/arch/powerpc/gen/__setjmp14.S

51 lines
953 B
ArmAsm
Raw Normal View History

/* $NetBSD: __setjmp14.S,v 1.5 2011/01/15 07:31:12 matt Exp $ */
#include "SYS.h"
#include "assym.h"
#if defined(LIBC_SCCS)
__RCSID("$NetBSD: __setjmp14.S,v 1.5 2011/01/15 07:31:12 matt Exp $")
#endif
/*
* C library -- _setjmp, _longjmp
*
* longjmp(a,v)
* will generate a "return(v?v:1)" from the last call to
* setjmp(a)
* by restoring registers from the stack.
* The previous signal state is restored.
*/
ENTRY(__setjmp14)
mr %r6,%r3
li %r3,SIG_BLOCK
li %r4,0
addi %r5,%r6,4*(1+24) # &sigmask
_DOSYSCALL(__sigprocmask14) # assume no error XXX
mflr %r11
mfcr %r12
mr %r10,%r1
mr %r9,%r2
stmw %r8,4(%r6) # save r8-r31
li %r3,0
blr
END(__setjmp14)
ENTRY(__longjmp14)
lmw %r8,4(%r3) # load r8-r31
mr %r6,%r4
mtlr %r11
mtcr %r12
mr %r2,%r9
mr %r1,%r10
addi %r4,%r3,4*(1+24) # &sigmask
li %r3,SIG_SETMASK
li %r5,0
_DOSYSCALL(__sigprocmask14) # assume no error XXX
or. %r3,%r6,%r6
bnelr
li %r3,1
blr
END(__longjmp14)