Home | History | Annotate | Line # | Download | only in gen
      1  1.2  skrll /*	$NetBSD: __setjmp14.S,v 1.2 2023/10/11 09:12:21 skrll Exp $	*/
      2  1.1   matt 
      3  1.1   matt #include "SYS.h"
      4  1.1   matt #include "assym.h"
      5  1.1   matt 
      6  1.1   matt #if defined(LIBC_SCCS)
      7  1.2  skrll __RCSID("$NetBSD: __setjmp14.S,v 1.2 2023/10/11 09:12:21 skrll Exp $")
      8  1.1   matt #endif
      9  1.1   matt 
     10  1.1   matt /*
     11  1.1   matt  * C library -- _setjmp, _longjmp
     12  1.1   matt  *
     13  1.1   matt  *	longjmp(a,v)
     14  1.1   matt  * will generate a "return(v?v:1)" from the last call to
     15  1.1   matt  *	setjmp(a)
     16  1.1   matt  * by restoring registers from the stack.
     17  1.1   matt  * The previous signal state is restored.
     18  1.1   matt  */
     19  1.1   matt 
     20  1.1   matt ENTRY(__setjmp14)
     21  1.1   matt 	l.sw	JB_PC(r3), lr		/* save return address */
     22  1.1   matt 	l.sw	JB_LR(r3), lr		/* save return address */
     23  1.1   matt 	l.sw	JB_SP(r3), r1		/* save stack pointer */
     24  1.1   matt 	l.sw	JB_FP(r3), r2		/* save frame pointer */
     25  1.1   matt 	l.sw	JB_R10(r3), r10		/* save callee saved register */
     26  1.1   matt 	l.sw	JB_R14(r3), r14		/* save callee saved register */
     27  1.1   matt 	l.sw	JB_R16(r3), r16		/* save callee saved register */
     28  1.1   matt 	l.sw	JB_R18(r3), r18		/* save callee saved register */
     29  1.1   matt 	l.sw	JB_R20(r3), r20		/* save callee saved register */
     30  1.1   matt 	l.sw	JB_R22(r3), r22		/* save callee saved register */
     31  1.1   matt 	l.sw	JB_R24(r3), r24		/* save callee saved register */
     32  1.1   matt 	l.sw	JB_R26(r3), r26		/* save callee saved register */
     33  1.1   matt 	l.sw	JB_R28(r3), r28		/* save callee saved register */
     34  1.1   matt 	l.sw	JB_R30(r3), r30		/* save callee saved register */
     35  1.1   matt 	l.addi	r4, r0, 1
     36  1.1   matt 	l.sw	JB_MAGIC(r3), r4	/* note we saved sigmask */
     37  1.1   matt 	l.addi	r5, r3, JB_SIGMASK	# &sigmask
     38  1.1   matt 	l.xor	r4, r4, r4
     39  1.2  skrll 	l.addi	r3, r0, 0
     40  1.1   matt 	_DOSYSCALL(__sigprocmask14)	# assume no error	XXX
     41  1.1   matt 	l.xor	r11, r11, r11
     42  1.1   matt 	l.jr	lr
     43  1.1   matt 	l.nop
     44  1.1   matt END(__setjmp14)
     45  1.1   matt 
     46  1.1   matt ENTRY(__longjmp14)
     47  1.1   matt 	l.lwz	lr, JB_LR(r3)		/* get return address */
     48  1.1   matt 	l.lwz	r1, JB_SP(r3)		/* get stack pointer */
     49  1.1   matt 	l.lwz	r2, JB_FP(r3)		/* get frame pointer */
     50  1.1   matt 	l.lwz	r10, JB_R10(r3)		/* get callee saved register */
     51  1.1   matt 	l.lwz	r14, JB_R14(r3)		/* get callee saved register */
     52  1.1   matt 	l.lwz	r16, JB_R16(r3)		/* get callee saved register */
     53  1.1   matt 	l.lwz	r18, JB_R18(r3)		/* get callee saved register */
     54  1.1   matt 	l.lwz	r20, JB_R20(r3)		/* get callee saved register */
     55  1.1   matt 	l.lwz	r22, JB_R22(r3)		/* get callee saved register */
     56  1.1   matt 	l.lwz	r24, JB_R24(r3)		/* get callee saved register */
     57  1.1   matt 	l.lwz	r26, JB_R26(r3)		/* get callee saved register */
     58  1.1   matt 	l.lwz	r28, JB_R28(r3)		/* get callee saved register */
     59  1.1   matt 	l.lwz	r30, JB_R30(r3)		/* get callee saved register */
     60  1.1   matt 	l.ori	r11, r4, 0
     61  1.1   matt 	l.xor	r5, r5, r5
     62  1.1   matt 	l.addi	r4, r3, JB_SIGMASK	# &sigmask
     63  1.1   matt 	l.addi	r3, r0, SIG_SETMASK
     64  1.1   matt 	_DOSYSCALL(__sigprocmask14)	# assume no error	XXX
     65  1.1   matt 	l.addi	r6, r0, 1
     66  1.1   matt 	l.sfeqi	r11, 0
     67  1.1   matt 	l.cmov	r11, r6, r11
     68  1.1   matt 	l.jr	lr
     69  1.1   matt 	l.nop
     70  1.1   matt END(__longjmp14)
     71