11573Srgrimes/*	$NetBSD: __setjmp14.S,v 1.2 2023/10/11 09:12:21 skrll Exp $	*/
21573Srgrimes
31573Srgrimes#include "SYS.h"
41573Srgrimes#include "assym.h"
5227753Stheraven
6227753Stheraven#if defined(LIBC_SCCS)
7227753Stheraven__RCSID("$NetBSD: __setjmp14.S,v 1.2 2023/10/11 09:12:21 skrll Exp $")
8227753Stheraven#endif
9227753Stheraven
101573Srgrimes/*
111573Srgrimes * C library -- _setjmp, _longjmp
121573Srgrimes *
131573Srgrimes *	longjmp(a,v)
141573Srgrimes * will generate a "return(v?v:1)" from the last call to
151573Srgrimes *	setjmp(a)
161573Srgrimes * by restoring registers from the stack.
171573Srgrimes * The previous signal state is restored.
18251069Semaste */
191573Srgrimes
201573SrgrimesENTRY(__setjmp14)
211573Srgrimes	l.sw	JB_PC(r3), lr		/* save return address */
221573Srgrimes	l.sw	JB_LR(r3), lr		/* save return address */
231573Srgrimes	l.sw	JB_SP(r3), r1		/* save stack pointer */
241573Srgrimes	l.sw	JB_FP(r3), r2		/* save frame pointer */
251573Srgrimes	l.sw	JB_R10(r3), r10		/* save callee saved register */
261573Srgrimes	l.sw	JB_R14(r3), r14		/* save callee saved register */
271573Srgrimes	l.sw	JB_R16(r3), r16		/* save callee saved register */
281573Srgrimes	l.sw	JB_R18(r3), r18		/* save callee saved register */
291573Srgrimes	l.sw	JB_R20(r3), r20		/* save callee saved register */
301573Srgrimes	l.sw	JB_R22(r3), r22		/* save callee saved register */
311573Srgrimes	l.sw	JB_R24(r3), r24		/* save callee saved register */
321573Srgrimes	l.sw	JB_R26(r3), r26		/* save callee saved register */
331573Srgrimes	l.sw	JB_R28(r3), r28		/* save callee saved register */
341573Srgrimes	l.sw	JB_R30(r3), r30		/* save callee saved register */
3577117Sobrien	l.addi	r4, r0, 1
3677117Sobrien	l.sw	JB_MAGIC(r3), r4	/* note we saved sigmask */
3777117Sobrien	l.addi	r5, r3, JB_SIGMASK	# &sigmask
3886170Sobrien	l.xor	r4, r4, r4
3986170Sobrien	l.addi	r3, r0, 0
4077117Sobrien	_DOSYSCALL(__sigprocmask14)	# assume no error	XXX
41102624Srobert	l.xor	r11, r11, r11
4216250Sache	l.jr	lr
43227753Stheraven	l.nop
441573SrgrimesEND(__setjmp14)
451573Srgrimes
46227753StheravenENTRY(__longjmp14)
471573Srgrimes	l.lwz	lr, JB_LR(r3)		/* get return address */
4892889Sobrien	l.lwz	r1, JB_SP(r3)		/* get stack pointer */
491573Srgrimes	l.lwz	r2, JB_FP(r3)		/* get frame pointer */
501573Srgrimes	l.lwz	r10, JB_R10(r3)		/* get callee saved register */
51227753Stheraven	l.lwz	r14, JB_R14(r3)		/* get callee saved register */
521573Srgrimes	l.lwz	r16, JB_R16(r3)		/* get callee saved register */
53227753Stheraven	l.lwz	r18, JB_R18(r3)		/* get callee saved register */
541573Srgrimes	l.lwz	r20, JB_R20(r3)		/* get callee saved register */
551573Srgrimes	l.lwz	r22, JB_R22(r3)		/* get callee saved register */
56227753Stheraven	l.lwz	r24, JB_R24(r3)		/* get callee saved register */
571573Srgrimes	l.lwz	r26, JB_R26(r3)		/* get callee saved register */
58227753Stheraven	l.lwz	r28, JB_R28(r3)		/* get callee saved register */
59227753Stheraven	l.lwz	r30, JB_R30(r3)		/* get callee saved register */
60227753Stheraven	l.ori	r11, r4, 0
61227753Stheraven	l.xor	r5, r5, r5
62227753Stheraven	l.addi	r4, r3, JB_SIGMASK	# &sigmask
631573Srgrimes	l.addi	r3, r0, SIG_SETMASK
641573Srgrimes	_DOSYSCALL(__sigprocmask14)	# assume no error	XXX
65227753Stheraven	l.addi	r6, r0, 1
661573Srgrimes	l.sfeqi	r11, 0
67227753Stheraven	l.cmov	r11, r6, r11
68228202Seadler	l.jr	lr
69228202Seadler	l.nop
70228202SeadlerEND(__longjmp14)
71228202Seadler