__setjmp14.S revision 1.2 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