xref: /netbsd-src/lib/libc/arch/sh3/gen/sigsetjmp.S (revision d5e6e0f5aa59e3fa0532ded5e86a7be567df07ef)
1/*	$NetBSD: sigsetjmp.S,v 1.11 2024/07/17 07:11:57 uwe Exp $	*/
2
3/*-
4 * Copyright (c) 1990 The Regents of the University of California.
5 * All rights reserved.
6 *
7 * This code is derived from software contributed to Berkeley by
8 * William Jolitz.
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 * 1. Redistributions of source code must retain the above copyright
14 *    notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 *    notice, this list of conditions and the following disclaimer in the
17 *    documentation and/or other materials provided with the distribution.
18 * 3. Neither the name of the University nor the names of its contributors
19 *    may be used to endorse or promote products derived from this software
20 *    without specific prior written permission.
21 *
22 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
23 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32 * SUCH DAMAGE.
33 *
34 *	from: @(#)setjmp.s	5.1 (Berkeley) 4/23/90
35 */
36
37#include <machine/asm.h>
38#include <machine/setjmp.h>
39
40#if defined(LIBC_SCCS)
41	RCSID("$NetBSD: sigsetjmp.S,v 1.11 2024/07/17 07:11:57 uwe Exp $")
42#endif
43
44ENTRY(__sigsetjmp14)
45	tst	r5, r5
46	bt	2f			/* if (savemask == 0) */
47
48	/* identical to longjmp except that _JB_HAS_MASK is in the argument */
49	PIC_PROLOGUE(.L_got_1)
50	sts.l	pr, @-sp
51	mov.l	r4, @-sp
52	mov.l	r5, @-sp
53
54	mov.l	.L___sigprocmask14_1, r0
55	mov	r4, r6
56	mov	#0, r4			/* how is ignored */
57	mov	#0, r5			/* set = NULL */
581:	CALL	r0
59	 add	#(_JB_SIGMASK * 4), r6	/* oset = &sigmask */
60
61	mov.l	@sp+, r5
62	mov.l	@sp+, r4
63	lds.l	@sp+, pr
64	PIC_EPILOGUE
65
662:	/* identical to _setjmp except that _JB_HAS_MASK is in the argument */
67	add	#((_JB_HAS_MASK + 1) * 4), r4
68	mov.l	r5, @-r4		/* has signal mask? */
69	mov.l	r15, @-r4
70	mov.l	r14, @-r4
71	mov.l	r13, @-r4
72	mov.l	r12, @-r4
73	mov.l	r11, @-r4
74	mov.l	r10, @-r4
75	mov.l	r9, @-r4
76	mov.l	r8, @-r4
77	sts.l	pr, @-r4
78	rts
79	 xor	r0, r0
80
81	.align	2
82.L_got_1:		PIC_GOT_DATUM
83.L___sigprocmask14_1:	CALL_DATUM(_C_LABEL(__sigprocmask14), 1b)
84	SET_ENTRY_SIZE(__sigsetjmp14)
85
86
87ENTRY(__siglongjmp14)
88	// return value can't be zero, adjust to 1 if it is
89	tst	r5, r5
90	bf/s	0f
91	 mov.l	@(_JB_REG_PR * 4, r4), r0
92	mov	#1, r5
930:
94	// restore context first (callee-saved regs)
95	mov.l	@(_JB_REG_R8  * 4, r4), r8
96	mov.l	@(_JB_REG_R9  * 4, r4), r9
97	mov.l	@(_JB_REG_R10 * 4, r4), r10
98	mov.l	@(_JB_REG_R11 * 4, r4), r11
99	mov.l	@(_JB_REG_R12 * 4, r4), r12
100	mov.l	@(_JB_REG_R13 * 4, r4), r13
101	mov.l	@(_JB_REG_R14 * 4, r4), r14
102	mov.l	@(_JB_REG_R15 * 4, r4), r15
103
104	// do we need to restore signal mask?
105	mov.l	@(_JB_HAS_MASK * 4, r4), r7
106	tst	r7, r7
107	bf/s	0f
108	 mov	#0, r6		// sigprocmask: oset = NULL
109	// ... no, just the registers
110	lds	r0, pr
111	rts
112	 mov	r5, r0
1130:
114	// create a frame
115	mov.l	r5, @-sp	// future return value (pre-adjusted)
116	mov.l	r0, @-sp	// caller's PR from the jumpbuf
117	PIC_PROLOGUE(.L_got_2)
118
119	// restore signal mask from &a[_JB_SIGMASK]
120	mov	r4, r5
121	mov.l	.L___sigprocmask14_2, r0
122	add	#(_JB_SIGMASK * 4), r5	// set = &a[_JB_SIGMASK]
1231:	CALL	r0
124	 mov	#3, r4			// how = SIG_SETMASK
125
126	// return "from" setjmp
127	PIC_EPILOGUE
128	lds.l	@sp+, pr
129	rts
130	 mov.l	@sp+, r0
131
132	.align	2
133.L_got_2:		PIC_GOT_DATUM
134.L___sigprocmask14_2:	CALL_DATUM(_C_LABEL(__sigprocmask14), 1b)
135	SET_ENTRY_SIZE(__siglongjmp14)
136