xref: /netbsd-src/lib/libc/arch/x86_64/gen/__setjmp14.S (revision df443a3d170449efe123fb072d89e978766444ac)
1/*	$NetBSD: __setjmp14.S,v 1.4 2024/04/04 00:46:30 riastradh Exp $	*/
2
3/*
4 * Copyright (c) 2001 Wasabi Systems, Inc.
5 * All rights reserved.
6 *
7 * Written by Frank van der Linden for Wasabi Systems, Inc.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
11 * are met:
12 * 1. Redistributions of source code must retain the above copyright
13 *    notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 *    notice, this list of conditions and the following disclaimer in the
16 *    documentation and/or other materials provided with the distribution.
17 * 3. All advertising materials mentioning features or use of this software
18 *    must display the following acknowledgement:
19 *      This product includes software developed for the NetBSD Project by
20 *      Wasabi Systems, Inc.
21 * 4. The name of Wasabi Systems, Inc. may not be used to endorse
22 *    or promote products derived from this software without specific prior
23 *    written permission.
24 *
25 * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND
26 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
27 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL WASABI SYSTEMS, INC
29 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35 * POSSIBILITY OF SUCH DAMAGE.
36 */
37
38
39#include <machine/asm.h>
40#include <machine/setjmp.h>
41
42#if defined(LIBC_SCCS)
43	RCSID("$NetBSD: __setjmp14.S,v 1.4 2024/04/04 00:46:30 riastradh Exp $")
44#endif
45
46/*
47 * C library -- _setjmp, _longjmp
48 *
49 *	longjmp(a,v)
50 * will generate a "return(v)" from the last call to
51 *	setjmp(a)
52 * by restoring registers from the stack.
53 * The previous signal state is restored.
54 */
55
56/*
57 * setjmp(jmp_buf env@rdi)
58 *
59 * ELF symbol: __setjmp14, because the size of jmp_buf changed on some
60 * platforms in 1.4.
61 */
62ENTRY(__setjmp14)
63	/*
64	 * Save the callee-saves registers: %rbx, %rbp, %r12-r15,
65	 * plus %rsp and the return address on the stack since it
66	 * will be overwritten if the caller makes any subroutine
67	 * calls before longjmp.
68	 */
69	movq	(%rsp),%r11
70	movq	%rbx,(_JB_RBX * 8)(%rdi)
71	movq	%rbp,(_JB_RBP * 8)(%rdi)
72	movq	%r12,(_JB_R12 * 8)(%rdi)
73	movq	%r13,(_JB_R13 * 8)(%rdi)
74	movq	%r14,(_JB_R14 * 8)(%rdi)
75	movq	%r15,(_JB_R15 * 8)(%rdi)
76	movq	%rsp,(_JB_RSP * 8)(%rdi)
77	movq	%r11,(_JB_PC  * 8)(%rdi)
78
79	leaq	(_JB_SIGMASK * 8)(%rdi),%rdx	/* oset@rdx */
80	xorl	%edi,%edi		/* how@edi := 0 (ignored) */
81	xorl	%esi,%esi		/* set@rsi := NULL */
82
83#ifdef __PIC__
84	call	PIC_PLT(_C_LABEL(__sigprocmask14))
85#else
86	call	_C_LABEL(__sigprocmask14)
87#endif
88	xorl	%eax,%eax
89	ret
90END(__setjmp14)
91
92/*
93 * longjmp(jmp_buf env@rdi, int val@esi)
94 *
95 * ELF symbol: __longjmp14, because the size of jmp_buf changed on some
96 * platforms in 1.4
97 */
98ENTRY(__longjmp14)
99	/*
100	 * Restore the callee-saves registers: %rbx, %rbp, %r12-r15,
101	 * plus %rsp and the return address on the stack.
102	 */
103	movq	(_JB_RBX * 8)(%rdi),%rbx
104	movq	(_JB_RBP * 8)(%rdi),%rbp
105	movq	(_JB_R12 * 8)(%rdi),%r12
106	movq	(_JB_R13 * 8)(%rdi),%r13
107	movq	(_JB_R14 * 8)(%rdi),%r14
108	movq	(_JB_R15 * 8)(%rdi),%r15
109	movq	(_JB_RSP * 8)(%rdi),%rsp
110	movq	(_JB_PC  * 8)(%rdi),%r11
111	movq	%r11,0(%rsp)
112
113	/*
114	 * Use  pushq %rsi  instead of  pushl %esi  in order to keep
115	 * 16-byte stack alignment, even though we only care about the
116	 * 32-bit int in esi.
117	 */
118	pushq	%rsi		/* save val@esi */
119
120	leaq	(_JB_SIGMASK * 8)(%rdi),%rsi	/* set@rsi */
121	movl	$3,%edi		/* how@edi := SIG_SETMASK */
122	xorl	%edx,%edx	/* oset@rdx := NULL */
123
124#ifdef __PIC__
125	call	PIC_PLT(_C_LABEL(__sigprocmask14))
126#else
127	call	_C_LABEL(__sigprocmask14)
128#endif
129
130	popq	%rax		/* restore val@eax */
131
132	testl	%eax,%eax	/* val@eax == 0? */
133	jz	1f		/* jump if val@eax == 0 */
134	ret			/* return val@eax */
1351:	incl	%eax		/* val@eax := 1 */
136	ret			/* return val@eax */
137END(__longjmp14)
138