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